.reading-progress{position:fixed;top:0;left:0;width:0%;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));z-index:1001;transition:width 0.1s linear;box-shadow:0 0 10px rgba(230,57,70,0.4),0 0 20px rgba(230,57,70,0.2);will-change:width}:root{--color-primary:#e63946;--color-primary-dark:#c1121f;--color-secondary:#457b9d;--color-accent:#f4a261;--color-accent-light:#fae1dd;--color-text:#1d3557;--color-text-light:#6c757d;--color-text-muted:#adb5bd;--color-bg:#ffffff;--color-bg-alt:#f8f9fa;--color-bg-warm:#fff5f5;--color-border:#e9ecef;--color-success:#2d6a4f;--color-danger:#e63946;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--font-sans:'Noto Sans KR',-apple-system,BlinkMacSystemFont,'Segoe UI','Malgun Gothic',sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:2rem;--font-size-4xl:2.5rem;--container-max:1200px;--container-narrow:800px;--header-height:70px;--shadow-sm:0 1px 3px rgba(0,0,0,0.08);--shadow-md:0 4px 12px rgba(0,0,0,0.06);--shadow-lg:0 8px 24px rgba(0,0,0,0.08);--shadow-xl:0 12px 36px rgba(0,0,0,0.1);--shadow-glow:0 0 20px rgba(230,57,70,0.15);--transition-fast:0.15s ease;--transition-base:0.25s ease;--transition-slow:0.4s cubic-bezier(0.34,1.56,0.64,1);--transition-spring:0.5s cubic-bezier(0.34,1.56,0.64,1);--radius-sm:6px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--header-height)}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.7;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none;transition:color 0.2s ease}a:hover{color:var(--color-primary)}img{max-width:100%;height:auto;display:block}img:not([src]),img[src=""],img.loading{background:var(--color-bg-alt);background-image:linear-gradient(90deg,var(--color-bg-alt)0%,var(--color-border)50%,var(--color-bg-alt)100%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}img.blur-up{filter:blur(10px);transition:filter 0.4s ease}img.blur-up.loaded{filter:blur(0)}ul,ol{list-style:none}.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-4)}.fade-in-up{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}.fade-in-up.visible{opacity:1;transform:translateY(0)}.fade-in-up-d1{transition-delay:0.1s}.fade-in-up-d2{transition-delay:0.2s}.fade-in-up-d3{transition-delay:0.3s}.fade-in-up-d4{transition-delay:0.4s}.fade-in-up-d5{transition-delay:0.5s}.fade-in-up-d6{transition-delay:0.6s}.scale-in{opacity:0;transform:scale(0.92);transition:opacity 0.5s ease,transform 0.5s ease}.scale-in.visible{opacity:1;transform:scale(1)}@media(prefers-reduced-motion:reduce){.fade-in-up,.scale-in{opacity:1;transform:none;transition:none}}.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,0.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--color-border);height:var(--header-height);transition:box-shadow 0.3s ease}.site-header.scrolled{box-shadow:var(--shadow-sm)}.site-header .container{display:flex;justify-content:space-between;align-items:center;height:100%}.site-logo{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);text-decoration:none;transition:opacity 0.2s ease}.site-logo:hover{opacity:0.8;color:var(--color-text)}.site-logo-icon{font-size:1.6rem;line-height:1}.site-logo-text{font-size:var(--font-size-base)}@media(min-width:768px){.site-logo-text{font-size:var(--font-size-lg)}}.nav-menu{display:none;list-style:none;gap:var(--space-1);align-items:center}@media(min-width:768px){.nav-menu{display:flex}}.nav-link{font-size:var(--font-size-sm);font-weight:500;padding:var(--space-2)var(--space-3);border-radius:var(--radius-full);transition:all 0.2s ease;white-space:nowrap}.nav-link:hover{background:var(--color-bg-alt);color:var(--color-primary)}.nav-link[aria-current="page"]{background:var(--color-accent-light);color:var(--color-primary);font-weight:600}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:background 0.2s}.mobile-menu-btn:hover{background:var(--color-bg-alt)}@media(min-width:768px){.mobile-menu-btn{display:none}}.mobile-menu-btn span{display:block;width:22px;height:2px;background:var(--color-text);position:relative;transition:all 0.3s}.mobile-menu-btn span::before,.mobile-menu-btn span::after{content:'';position:absolute;width:100%;height:2px;background:var(--color-text);left:0;transition:all 0.3s}.mobile-menu-btn span::before{top:-7px}.mobile-menu-btn span::after{top:7px}.mobile-menu-btn.active span{background:transparent}.mobile-menu-btn.active span::before{top:0;transform:rotate(45deg)}.mobile-menu-btn.active span::after{top:0;transform:rotate(-45deg)}.mobile-menu{display:none;position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:rgba(255,255,255,0.98);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:var(--space-8)var(--space-4);z-index:999;overflow-y:auto}.mobile-menu.open{display:block}.mobile-nav-list{display:flex;flex-direction:column;gap:var(--space-2)}.mobile-nav-link{display:block;padding:var(--space-4)var(--space-6);font-size:var(--font-size-lg);font-weight:500;border-radius:var(--radius-md);transition:all 0.2s ease}.mobile-nav-link:hover{background:var(--color-bg-alt);color:var(--color-primary)}.hero{padding:var(--space-20)0 var(--space-16);text-align:center;background:linear-gradient(135deg,var(--color-accent-light)0%,#fff5f5 50%,#f0f4ff 100%);position:relative;overflow:hidden;isolation:isolate}.hero::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%,rgba(230,57,70,0.04)0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(69,123,157,0.04)0%,transparent 50%),radial-gradient(circle at 50% 80%,rgba(244,162,97,0.03)0%,transparent 40%);pointer-events:none;animation:heroBgDrift 12s ease-in-out infinite alternate}.hero::after{content:'🍜';position:absolute;font-size:4rem;opacity:0.06;top:10%;right:8%;pointer-events:none;animation:heroFloat 8s ease-in-out infinite}@keyframes heroBgDrift{0%{transform:translate(0,0)rotate(0deg)}100%{transform:translate(3%,2%)rotate(3deg)}}@keyframes heroFloat{0%,100%{transform:translateY(0)rotate(0deg)}33%{transform:translateY(-15px)rotate(5deg)}66%{transform:translateY(8px)rotate(-3deg)}}.hero .container{position:relative;z-index:1}.hero h1{font-size:clamp(2rem,5vw,var(--font-size-4xl));font-weight:800;line-height:1.2;margin-bottom:var(--space-4);letter-spacing:-0.02em;color:var(--color-text);animation:heroTitleIn 0.8s ease both}@keyframes heroTitleIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero h1 .highlight{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.hero h1 .highlight::after{content:'';position:absolute;bottom:2px;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),transparent);border-radius:var(--radius-full);opacity:0.3}.hero p{font-size:var(--font-size-lg);color:var(--color-text-light);max-width:640px;margin:0 auto var(--space-8);line-height:1.8;animation:heroContentIn 0.8s 0.15s ease both}@keyframes heroContentIn{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.hero-stats{display:flex;gap:var(--space-8);justify-content:center;flex-wrap:wrap;margin-top:var(--space-10);animation:heroContentIn 0.8s 0.3s ease both}.hero-stat{background:rgba(255,255,255,0.8);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.9);padding:var(--space-6)var(--space-8);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-md);min-width:140px;transition:all var(--transition-base)}.hero-stat:hover{transform:translateY(-4px)scale(1.02);box-shadow:var(--shadow-lg);border-color:rgba(230,57,70,0.2)}.hero-stat-number{font-size:var(--font-size-3xl);font-weight:800;color:var(--color-primary);display:block;line-height:1.2;transition:all var(--transition-base)}.hero-stat:hover .hero-stat-number{transform:scale(1.05)}.hero-stat-label{font-size:var(--font-size-sm);color:var(--color-text-light);margin-top:var(--space-1)}.search-form{max-width:560px;margin:0 auto;animation:heroContentIn 0.8s 0.45s ease both}.search-input-group{display:flex;gap:var(--space-2);background:white;border:2px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-2);transition:all 0.25s ease;box-shadow:var(--shadow-sm)}.search-input-group:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 4px rgba(230,57,70,0.1),var(--shadow-glow);transform:scale(1.01)}.search-input-group input{flex:1;border:none;outline:none;padding:var(--space-3)var(--space-4);font-size:var(--font-size-base);background:transparent}.search-input-group input::placeholder{color:var(--color-text-muted);transition:color var(--transition-base)}.search-input-group:focus-within input::placeholder{color:var(--color-text-light)}.search-input-group button{background:var(--color-primary);color:white;border:none;padding:var(--space-3)var(--space-6);border-radius:var(--radius-full);font-weight:600;cursor:pointer;transition:all 0.2s ease;font-size:var(--font-size-sm);position:relative;overflow:hidden}.search-input-group button:hover{background:var(--color-primary-dark);transform:scale(1.02)}.search-input-group button:active{transform:scale(0.97)}.quick-search-tags{display:flex;gap:var(--space-2);justify-content:center;flex-wrap:wrap;margin-top:var(--space-6);animation:heroContentIn 0.8s 0.6s ease both}.quick-search-tag{font-size:var(--font-size-sm);padding:var(--space-2)var(--space-4);background:white;border:1px solid var(--color-border);border-radius:var(--radius-full);transition:all 0.2s ease;cursor:pointer}.quick-search-tag:hover{background:var(--color-primary);color:white;border-color:var(--color-primary);transform:translateY(-2px)scale(1.03);box-shadow:0 4px 12px rgba(230,57,70,0.25)}.quick-search-tag:active{transform:translateY(0)scale(0.97)}.section{padding:var(--space-16)0}.section-header{text-align:center;margin-bottom:var(--space-10)}.section-label{display:inline-block;font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:var(--space-2);background:var(--color-accent-light);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);transition:all var(--transition-base)}.section-header:hover .section-label{transform:scale(1.05)}.section-header h2{font-size:var(--font-size-3xl);font-weight:700;line-height:1.3;color:var(--color-text)}.section-header p{font-size:var(--font-size-base);color:var(--color-text-light);margin-top:var(--space-2);max-width:600px;margin-left:auto;margin-right:auto}.article-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}@media(min-width:640px){.article-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.article-grid{grid-template-columns:repeat(3,1fr)}}.article-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:all 0.3s ease;cursor:pointer}.article-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-6px)}.article-card:active{transform:translateY(-2px)scale(0.99)}.article-card-image{width:100%;padding-top:60%;position:relative;background:var(--color-bg-alt);overflow:hidden}.article-card-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease,filter 0.4s ease}.article-card:hover .article-card-image img{transform:scale(1.08)}.article-card-body{padding:var(--space-6)}.article-card-category{display:inline-block;font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary);background:var(--color-accent-light);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);margin-bottom:var(--space-3)}.article-card-title{font-size:var(--font-size-lg);font-weight:700;line-height:1.4;margin-bottom:var(--space-2)}.article-card-title a{color:var(--color-text);text-decoration:none}.article-card-title a:hover{color:var(--color-primary)}.article-card-excerpt{font-size:var(--font-size-sm);color:var(--color-text-light);line-height:1.6;margin-bottom:var(--space-4);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.article-card-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);padding-top:var(--space-3);border-top:1px solid var(--color-border);display:flex;gap:var(--space-4)}.view-toggle-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);background:white;border:2px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-light);text-decoration:none;transition:all 0.2s ease;cursor:pointer}.view-toggle-btn:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.view-toggle-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:white;box-shadow:0 2px 8px rgba(230,57,70,0.25)}.article-grid-gallery{grid-template-columns:1fr !important;gap:var(--space-6)}@media(min-width:640px){.article-grid-gallery{grid-template-columns:repeat(2,1fr)!important}}.article-card-gallery{position:relative;border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.article-card-gallery .article-card-image{padding-top:56%;width:100%}.article-card-gallery .article-card-image img{transition:transform 0.6s ease}.article-card-gallery:hover .article-card-image img{transform:scale(1.1)}.article-card-gallery .card-img-overlay{padding:var(--space-8)var(--space-5)var(--space-5)}.article-card-gallery .card-img-hover-btn{font-size:var(--font-size-base);padding:var(--space-3)var(--space-8)}.article-card-gallery .article-card-body{padding:var(--space-5)var(--space-6)var(--space-6);flex:1;display:flex;flex-direction:column}.article-card-gallery .article-card-title{font-size:var(--font-size-xl);line-height:1.35;margin-bottom:var(--space-3)}.article-card-gallery .article-card-excerpt{-webkit-line-clamp:3;font-size:var(--font-size-base);margin-bottom:var(--space-4);flex:1}.article-card-gallery .article-card-meta{margin-top:auto}.card-img-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--space-6)var(--space-4)var(--space-4);background:linear-gradient(transparent,rgba(0,0,0,0.6));z-index:2;transition:opacity 0.3s ease}.card-img-badge{display:inline-block;font-size:var(--font-size-xs);font-weight:700;color:white;background:var(--color-primary);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);letter-spacing:0.02em;box-shadow:0 2px 8px rgba(0,0,0,0.2)}.card-img-hover{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.45);display:flex;align-items:center;justify-content:center;z-index:3;opacity:0;transition:opacity 0.35s ease;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.article-card:hover .card-img-hover{opacity:1}.card-img-hover-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-6);background:white;color:var(--color-primary);font-weight:700;font-size:var(--font-size-sm);border-radius:var(--radius-full);transform:translateY(10px);transition:all 0.3s ease;box-shadow:0 4px 16px rgba(0,0,0,0.25)}.article-card:hover .card-img-hover-btn{transform:translateY(0)}.card-img-hover-btn:hover{background:var(--color-primary);color:white}.featured-card{display:grid;grid-template-columns:1fr;gap:0;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all 0.3s ease}.featured-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}@media(min-width:768px){.featured-card{grid-template-columns:1fr 1fr}}.featured-card-image{width:100%;padding-top:60%;position:relative;background:var(--color-bg-alt);overflow:hidden}@media(min-width:768px){.featured-card-image{padding-top:0;height:100%;min-height:350px}}.featured-card-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}.featured-card:hover .featured-card-image img{transform:scale(1.06)}.featured-card-body{padding:var(--space-8)var(--space-10);display:flex;flex-direction:column;justify-content:center}.featured-card-category{font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary);background:var(--color-accent-light);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);display:inline-block;margin-bottom:var(--space-4);align-self:flex-start}.featured-card-title{font-size:var(--font-size-2xl);font-weight:700;line-height:1.3;margin-bottom:var(--space-4)}.featured-card-title a{color:var(--color-text);text-decoration:none}.featured-card-title a:hover{color:var(--color-primary)}.featured-card-excerpt{font-size:var(--font-size-base);color:var(--color-text-light);line-height:1.8;margin-bottom:var(--space-6)}.restaurant-grid-gallery{grid-template-columns:1fr !important;gap:var(--space-6)}@media(min-width:640px){.restaurant-grid-gallery{grid-template-columns:repeat(2,1fr)!important}}.restaurant-card-gallery{position:relative;border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.restaurant-card-gallery .restaurant-card-image{padding-top:56%;width:100%}.restaurant-card-gallery .restaurant-card-image img{transition:transform 0.6s ease}.restaurant-card-gallery:hover .restaurant-card-image img{transform:scale(1.1)}.restaurant-card-gallery .card-img-overlay{padding:var(--space-8)var(--space-5)var(--space-5)}.restaurant-card-gallery .card-img-hover-btn{font-size:var(--font-size-base);padding:var(--space-3)var(--space-8)}.restaurant-card-gallery .restaurant-card-body{padding:var(--space-5)var(--space-6)var(--space-6);flex:1;display:flex;flex-direction:column}.restaurant-card-gallery .restaurant-card-title{font-size:var(--font-size-xl);line-height:1.35;margin-bottom:var(--space-3)}.restaurant-card-gallery .restaurant-card-meta{font-size:var(--font-size-base);margin-bottom:var(--space-2)}.restaurant-card-gallery .restaurant-card-rating{font-size:var(--font-size-base);margin-top:auto}.restaurant-card:hover .card-img-hover,.restaurant-card-gallery:hover .card-img-hover{opacity:1}.restaurant-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}@media(min-width:640px){.restaurant-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.restaurant-grid{grid-template-columns:repeat(3,1fr)}}.restaurant-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:all 0.3s ease;cursor:pointer}.restaurant-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-6px)}.restaurant-card:active{transform:translateY(-2px)scale(0.99)}.restaurant-card-image{width:100%;padding-top:60%;position:relative;background:var(--color-bg-alt);overflow:hidden}.restaurant-card-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}.restaurant-card:hover .restaurant-card-image img{transform:scale(1.08)}.restaurant-card-body{padding:var(--space-6)}.restaurant-card-title{font-size:var(--font-size-lg);font-weight:700;line-height:1.4;margin-bottom:var(--space-2)}.restaurant-card-title a{color:var(--color-text);text-decoration:none}.restaurant-card-title a:hover{color:var(--color-primary)}.restaurant-card-meta{font-size:var(--font-size-sm);color:var(--color-text-light);display:flex;gap:var(--space-2);flex-wrap:wrap}.restaurant-card-rating{font-size:var(--font-size-sm);color:#f59e0b;font-weight:600;margin-top:var(--space-2)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-6);font-size:var(--font-size-base);font-weight:600;border-radius:var(--radius-full);transition:all 0.25s ease;cursor:pointer;border:none;text-decoration:none;white-space:nowrap;position:relative;overflow:hidden}.btn:active{transform:scale(0.96)!important}.btn-primary{background:var(--color-primary);color:white;box-shadow:0 4px 12px rgba(230,57,70,0.3)}.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-3px);box-shadow:0 8px 24px rgba(230,57,70,0.4);color:white}.btn-secondary{background:white;color:var(--color-text);border:2px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:white;transform:translateY(-3px);box-shadow:0 6px 16px rgba(230,57,70,0.3)}.site-footer{background:var(--color-text);color:rgba(255,255,255,0.8);padding:var(--space-16)0 var(--space-8);margin-top:var(--space-16);position:relative}.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent),var(--color-secondary))}.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8);margin-bottom:var(--space-10)}@media(min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.footer-grid{grid-template-columns:repeat(4,1fr)}}.footer-section h2{font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-4);color:white;position:relative;padding-bottom:var(--space-2)}.footer-section h2::after{content:'';position:absolute;bottom:0;left:0;width:24px;height:2px;background:var(--color-primary);border-radius:var(--radius-full)}.footer-section ul{list-style:none}.footer-section li{margin-bottom:var(--space-2)}.footer-section a{font-size:var(--font-size-sm);color:rgba(255,255,255,0.6);transition:color 0.2s ease,padding-left 0.2s ease;text-decoration:none;display:inline-block}.footer-section a:hover{color:white;padding-left:4px}.footer-bottom{text-align:center;padding-top:var(--space-6);border-top:1px solid rgba(255,255,255,0.1);font-size:var(--font-size-sm);color:rgba(255,255,255,0.4)}.text-center{text-align:center}.mt-8{margin-top:var(--space-8)}.mt-10{margin-top:var(--space-10)}.mt-12{margin-top:var(--space-12)}.mb-8{margin-bottom:var(--space-8)}.mb-12{margin-bottom:var(--space-12)}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:white;padding:var(--space-2)var(--space-4);z-index:9999;transition:top 0.2s ease}.skip-link:focus{top:0}a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}}.main-content{min-height:60vh;animation:pageFadeIn 0.4s ease}@keyframes pageFadeIn{from{opacity:0}to{opacity:1}}.article-layout{display:grid;grid-template-columns:1fr;gap:var(--space-8);margin:2rem auto;padding:0 var(--space-4)}@media(min-width:1024px){.article-layout{grid-template-columns:260px 1fr;padding:0}}@media(min-width:1200px){.article-layout{grid-template-columns:280px minmax(0,800px);justify-content:center}}.article-toc-wrapper{display:none}@media(min-width:1024px){.article-toc-wrapper{display:block;position:sticky;top:calc(var(--header-height)+ var(--space-4));align-self:start;max-height:calc(100vh - var(--header-height)- var(--space-8));overflow-y:auto;scrollbar-width:thin}.article-toc-wrapper::-webkit-scrollbar{width:4px}.article-toc-wrapper::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}}.article-toc{padding:var(--space-5);background:var(--color-bg-alt);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all var(--transition-base)}.article-toc:hover{border-color:rgba(230,57,70,0.15);box-shadow:var(--shadow-sm)}.article-toc-title{font-size:var(--font-size-xs);font-weight:700;color:var(--color-text);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:0.05em;display:flex;align-items:center;gap:var(--space-2);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.article-toc-list{list-style:none;padding:0;margin:0}.article-toc-item{margin-bottom:2px}.article-toc-link{display:block;padding:var(--space-1)var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-light);text-decoration:none;border-radius:var(--radius-sm);transition:all 0.2s ease;border-left:3px solid transparent;line-height:1.4}.article-toc-link:hover{color:var(--color-primary);background:rgba(230,57,70,0.04);border-left-color:var(--color-primary)}.article-toc-link.active{color:var(--color-primary);font-weight:600;border-left-color:var(--color-primary);background:rgba(230,57,70,0.07)}.article-toc-link.h3{padding-left:var(--space-5);font-size:var(--font-size-xs)}.article-toc-mobile{display:block;margin-bottom:var(--space-6)}@media(min-width:1024px){.article-toc-mobile{display:none}}.article-toc-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-3)var(--space-4);background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);transition:all 0.2s ease}.article-toc-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.article-toc-toggle-icon{transition:transform 0.3s ease;font-size:0.8rem}.article-toc-toggle.open .article-toc-toggle-icon{transform:rotate(180deg)}.article-toc-mobile-content{display:none;padding:var(--space-3)var(--space-4);background:var(--color-bg-alt);border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-md)var(--radius-md)}.article-toc-mobile-content.open{display:block}.article-toc-mobile-content .article-toc-list{margin:0}.article-content{line-height:1.8;color:var(--color-text);font-size:var(--font-size-base)}.article-content h1,.article-content h2,.article-content h3{margin-top:var(--space-8);margin-bottom:var(--space-4);font-weight:700;line-height:1.3;scroll-margin-top:calc(var(--header-height)+ var(--space-6))}.article-content h1{font-size:var(--font-size-3xl)}.article-content h2{font-size:var(--font-size-2xl);border-bottom:2px solid var(--color-primary);padding-bottom:var(--space-2);position:relative}.article-content h2::after{content:'';position:absolute;bottom:-2px;left:0;width:60px;height:2px;background:var(--color-accent)}.article-content h3{font-size:var(--font-size-xl)}.article-content p{margin-bottom:var(--space-4)}.article-content ul,.article-content ol{margin-bottom:var(--space-4);padding-left:var(--space-6)}.article-content li{margin-bottom:var(--space-2)}.article-content img{border-radius:var(--radius-md);margin:var(--space-6)0}.img-reveal{opacity:0;transform:translateY(24px)scale(0.97);transition:opacity 0.7s ease,transform 0.7s cubic-bezier(0.34,1.56,0.64,1);will-change:opacity,transform}.img-reveal.visible{opacity:1;transform:translateY(0)scale(1)}.share-section{margin-top:var(--space-10);padding-top:var(--space-6);border-top:1px solid var(--color-border)}.share-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-light);margin-bottom:var(--space-3)}.share-buttons{display:flex;gap:var(--space-2);flex-wrap:wrap}.share-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;border:none;cursor:pointer;transition:all 0.2s ease;text-decoration:none;white-space:nowrap}.share-btn:hover{transform:translateY(-2px)}.share-btn:active{transform:translateY(0)scale(0.96)}.share-btn-twitter{background:#1da1f2;color:white}.share-btn-twitter:hover{background:#1991db;box-shadow:0 4px 12px rgba(29,161,242,0.35);color:white}.share-btn-facebook{background:#1877f2;color:white}.share-btn-facebook:hover{background:#166fe5;box-shadow:0 4px 12px rgba(24,119,242,0.35);color:white}.share-btn-copy{background:var(--color-bg-alt);color:var(--color-text);border:1px solid var(--color-border)}.share-btn-copy:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow-sm)}.share-btn-copy.copied{background:var(--color-success);border-color:var(--color-success);color:white}[data-theme="dark"] .share-btn-twitter{background:#1a8cd8}[data-theme="dark"] .share-btn-facebook{background:#1565c0}.category-tag{padding:var(--space-2)var(--space-5);background:white;color:var(--color-text);border:2px solid var(--color-border);border-radius:var(--radius-full);text-decoration:none;font-weight:500;transition:all 0.2s ease;display:inline-block}.category-tag:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-2px)scale(1.03);box-shadow:var(--shadow-sm)}.category-tag:active{transform:translateY(0)scale(0.97)}.category-tag.active{background:var(--color-primary);color:white;border-color:var(--color-primary)}.pagination{margin-top:var(--space-10)}.pagination-list{display:flex;gap:var(--space-1);justify-content:center;list-style:none;padding:0}.pagination-list a,.pagination-list span{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:var(--space-2)var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;text-decoration:none;transition:all 0.2s ease}.pagination-list a{background:white;color:var(--color-text);border:1px solid var(--color-border)}.pagination-list a:hover{background:var(--color-bg-alt);border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.pagination-list a:active{transform:translateY(0)}.pagination-list .current{background:var(--color-primary);color:white;border:1px solid var(--color-primary)}.pagination-list .ellipsis{background:none;border:none;color:var(--color-text-muted)}.breadcrumb{background:var(--color-bg-alt);padding:var(--space-3)0;font-size:var(--font-size-sm)}.breadcrumb-list{display:flex;gap:var(--space-2);list-style:none;flex-wrap:wrap}.breadcrumb-item{display:flex;align-items:center;gap:var(--space-2)}.breadcrumb-item + .breadcrumb-item::before{content:'›';color:var(--color-text-muted)}.breadcrumb-item a{color:var(--color-text-light);text-decoration:none}.breadcrumb-item a:hover{color:var(--color-primary)}.breadcrumb-item.active span{color:var(--color-text);font-weight:500}[data-theme="dark"]{--color-primary:#ff6b7a;--color-primary-dark:#e63946;--color-secondary:#5da9d9;--color-accent:#e9a05c;--color-accent-light:#4a2830;--color-text:#e8e8e8;--color-text-light:#a0a0a0;--color-text-muted:#707070;--color-bg:#1a1a2e;--color-bg-alt:#16213e;--color-bg-warm:#2a1a1a;--color-border:#2a2a4a}[data-theme="dark"] .site-header{background:rgba(26,26,46,0.97)}[data-theme="dark"] .hero{background:linear-gradient(135deg,#2a1a1a 0%,#1a1a2e 50%,#16213e 100%)}[data-theme="dark"] .hero-stat{background:rgba(26,26,46,0.9);border-color:rgba(255,255,255,0.1)}[data-theme="dark"] .article-card,[data-theme="dark"] .restaurant-card,[data-theme="dark"] .featured-card{background:var(--color-bg-alt)}[data-theme="dark"] .search-input-group{background:var(--color-bg-alt)}.theme-toggle{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:var(--space-2);border-radius:var(--radius-sm);transition:all 0.2s ease;line-height:1;color:var(--color-text)}.theme-toggle:hover{background:var(--color-bg-alt);transform:rotate(20deg)}.card-img-placeholder{width:100%;height:100%;position:absolute;top:0;left:0;display:flex;align-items:center;justify-content:center;font-size:3rem}.card-img-placeholder.ramen{background:linear-gradient(135deg,#ffecd2 0%,#fcb69f 100%)}.card-img-placeholder.sushi{background:linear-gradient(135deg,#a8edea 0%,#fed6e3 100%)}.card-img-placeholder.izakaya{background:linear-gradient(135deg,#fbc2eb 0%,#a6c1ee 100%)}.card-img-placeholder.yakiniku{background:linear-gradient(135deg,#f6d365 0%,#fda085 100%)}.card-img-placeholder.tempura{background:linear-gradient(135deg,#ffecd2 0%,#fcb69f 100%)}.card-img-placeholder.okonomiyaki{background:linear-gradient(135deg,#a1c4fd 0%,#c2e9fb 100%)}.card-img-placeholder.seafood{background:linear-gradient(135deg,#89f7fe 0%,#66a6ff 100%)}.card-img-placeholder.guide{background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%)}.card-img-placeholder.travel{background:linear-gradient(135deg,#e0c3fc 0%,#8ec5fc 100%)}.card-img-placeholder.gourmet{background:linear-gradient(135deg,#ffecd2 0%,#fcb69f 100%)}.card-img-placeholder.default{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.scroll-top-btn{position:fixed;bottom:24px;right:24px;z-index:999;width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:white;border:none;cursor:pointer;font-size:1.25rem;box-shadow:var(--shadow-lg);transition:all 0.3s ease;opacity:0;transform:translateY(20px);pointer-events:none;display:flex;align-items:center;justify-content:center}.scroll-top-btn.visible{opacity:1;transform:translateY(0);pointer-events:auto}.scroll-top-btn:hover{background:var(--color-primary-dark);transform:translateY(-3px);box-shadow:var(--shadow-xl)}.scroll-top-btn.visible:hover{transform:translateY(-3px)}.footer-area-list{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1)var(--space-2)}@media(min-width:640px){.footer-area-list{grid-template-columns:1fr}}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:rgba(0,0,0,0.92);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity 0.3s ease,visibility 0.3s ease;cursor:zoom-out;padding:var(--space-4)}.lightbox-overlay.active{opacity:1;visibility:visible}.lightbox-overlay .lightbox-image{max-width:95vw;max-height:90vh;width:auto;height:auto;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 20px 60px rgba(0,0,0,0.5);transform:scale(0.9);transition:transform 0.35s cubic-bezier(0.34,1.56,0.64,1)}.lightbox-overlay.active .lightbox-image{transform:scale(1)}.lightbox-overlay .lightbox-caption{position:absolute;bottom:var(--space-8);left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.8);font-size:var(--font-size-sm);background:rgba(0,0,0,0.6);padding:var(--space-2)var(--space-4);border-radius:var(--radius-full);max-width:80vw;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.lightbox-overlay .lightbox-close{position:absolute;top:var(--space-6);right:var(--space-6);width:44px;height:44px;background:rgba(0,0,0,0.5);border:2px solid rgba(255,255,255,0.2);border-radius:50%;color:white;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s ease;z-index:1;line-height:1}.lightbox-overlay .lightbox-close:hover{background:var(--color-primary);border-color:var(--color-primary);transform:scale(1.1)}.lightbox-trigger,.gallery-trigger{cursor:pointer;transition:filter 0.2s ease}.gallery-listing-trigger{cursor:pointer;pointer-events:auto;transition:filter 0.2s ease}.gallery-listing-trigger:hover{filter:brightness(0.85)}.lightbox-trigger:hover,.gallery-trigger:hover{filter:brightness(0.85)}.article-content img.lightbox-trigger{cursor:pointer}@media(prefers-reduced-motion:reduce){.lightbox-overlay,.lightbox-overlay .lightbox-image,.lightbox-overlay .lightbox-close,.lightbox-trigger{transition:none !important}}@media(max-width:768px){.lightbox-overlay .lightbox-caption{bottom:var(--space-4);font-size:var(--font-size-xs);padding:var(--space-1)var(--space-3)}.lightbox-overlay .lightbox-close{top:var(--space-3);right:var(--space-3);width:36px;height:36px;font-size:1.25rem}.lightbox-overlay .lightbox-nav{width:36px;height:36px}.lightbox-overlay .lightbox-prev{left:var(--space-2)}.lightbox-overlay .lightbox-next{right:var(--space-2)}}.gallery-section{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border)}.gallery-section-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-5);color:var(--color-text);display:flex;align-items:center;gap:var(--space-3)}.gallery-count{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-light);background:var(--color-bg-alt);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full)}.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}@media(min-width:640px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.gallery-grid{grid-template-columns:repeat(4,1fr)}}.gallery-item{position:relative;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;aspect-ratio:16 / 9;background:var(--color-bg-alt);transition:all 0.3s ease}.gallery-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease}.gallery-item:hover img{transform:scale(1.08)}.gallery-item-featured{grid-column:1 / -1;aspect-ratio:16 / 7}@media(min-width:640px){.gallery-item-featured{grid-column:1 / 3;aspect-ratio:16 / 9}}@media(min-width:1024px){.gallery-item-featured{grid-column:1 / 3;grid-row:1 / 3;aspect-ratio:auto}}.gallery-item-badge{position:absolute;top:var(--space-2);left:var(--space-2);font-size:var(--font-size-xs);font-weight:700;color:white;background:var(--color-primary);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);box-shadow:0 2px 8px rgba(0,0,0,0.3);letter-spacing:0.02em;z-index:2}.lightbox-overlay .lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:rgba(0,0,0,0.5);border:2px solid rgba(255,255,255,0.15);border-radius:50%;color:white;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all 0.2s ease;z-index:2}.lightbox-overlay .lightbox-nav:hover{background:var(--color-primary);border-color:var(--color-primary);transform:translateY(-50%)scale(1.1)}.lightbox-overlay .lightbox-prev{left:var(--space-6)}.lightbox-overlay .lightbox-next{right:var(--space-6)}@media(prefers-reduced-motion:reduce){.gallery-item,.gallery-item img,.gallery-item-badge{transition:none !important}}@media(max-width:1024px){.restaurant-grid{grid-template-columns:repeat(2,1fr)!important}}@media(max-width:768px){.hero{padding:var(--space-12)0 var(--space-10)}.section{padding:var(--space-10)0}.section-header h2{font-size:var(--font-size-2xl)}.featured-card-body{padding:var(--space-6)}.featured-card-title{font-size:var(--font-size-xl)}.hero-stat{min-width:100px;padding:var(--space-4)var(--space-5)}.hero-stat-number{font-size:var(--font-size-2xl)}.restaurant-grid{grid-template-columns:1fr !important}.restaurants-page aside{flex:1 1 100% !important;position:static !important}.hero::after{display:none}}.glossary-term-card{transition:all 0.3s ease !important;cursor:default !important;position:relative;overflow:hidden}.glossary-term-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--color-primary);transition:height 0.3s ease;border-radius:0 var(--radius-sm)var(--radius-sm)0}.glossary-term-card:hover{transform:translateY(-3px)!important;box-shadow:var(--shadow-lg)!important;border-color:rgba(230,57,70,0.2)!important}.glossary-term-card:hover::before{height:100%}[data-theme="dark"] .glossary-term-card:hover{border-color:rgba(255,107,122,0.3)!important;box-shadow:0 8px 24px rgba(0,0,0,0.3)!important}[data-theme="dark"] .glossary-term-card::before{background:var(--color-primary)}.glossary-index{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;margin-bottom:var(--space-8);padding:var(--space-4);background:var(--color-bg-alt);border-radius:var(--radius-md)}.glossary-index-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-light);text-decoration:none;transition:all 0.2s ease;background:transparent}.glossary-index-link:hover{background:var(--color-primary);color:white;transform:scale(1.1)}.glossary-index-link.has-terms{color:var(--color-primary);background:var(--color-accent-light)}.glossary-index-link.has-terms:hover{background:var(--color-primary);color:white}.glossary-index-link.no-terms{color:var(--color-text-muted);cursor:default;opacity:0.4}.hero-float-item{position:absolute;pointer-events:none;font-size:2.5rem;opacity:0.08;animation:heroFloatItem 10s ease-in-out infinite;z-index:0}.hero-float-item:nth-child(2){top:20%;left:5%;animation-delay:-3s;font-size:3rem}.hero-float-item:nth-child(3){bottom:15%;right:12%;animation-delay:-6s;font-size:2rem}.hero-float-item:nth-child(4){top:60%;left:20%;animation-delay:-2s;font-size:1.8rem}.hero-float-item:nth-child(5){top:30%;right:25%;animation-delay:-8s;font-size:2.2rem}@keyframes heroFloatItem{0%,100%{transform:translateY(0)rotate(0deg)}25%{transform:translateY(-12px)rotate(5deg)}50%{transform:translateY(-6px)rotate(-3deg)}75%{transform:translateY(-18px)rotate(4deg)}}.info-card{padding:var(--space-6);background:var(--color-bg-alt);border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all var(--transition-base)}.info-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(230,57,70,0.2)}.info-card strong{display:block;font-size:var(--font-size-sm);color:var(--color-primary);margin-bottom:var(--space-2)}.info-card p{margin:0;color:var(--color-text-light);line-height:1.6}.cookie-consent-banner{position:fixed;bottom:0;left:0;right:0;z-index:9998;background:var(--color-text);color:rgba(255,255,255,0.9);padding:var(--space-4)0;box-shadow:0 -4px 20px rgba(0,0,0,0.15);transform:translateY(100%);transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1)}.cookie-consent-banner.visible{transform:translateY(0)}.cookie-consent-banner .container{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.cookie-consent-banner p{font-size:var(--font-size-sm);line-height:1.6;margin:0;flex:1;min-width:200px}.cookie-consent-banner .btn-group{display:flex;gap:var(--space-3);flex-shrink:0}.cookie-consent-btn{padding:var(--space-2)var(--space-5);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all 0.2s ease;border:2px solid transparent}.cookie-consent-btn.accept{background:var(--color-primary);color:white;border-color:var(--color-primary)}.cookie-consent-btn.accept:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(230,57,70,0.3)}.cookie-consent-btn.decline{background:transparent;color:rgba(255,255,255,0.7);border-color:rgba(255,255,255,0.3)}.cookie-consent-btn.decline:hover{color:white;border-color:rgba(255,255,255,0.6);background:rgba(255,255,255,0.1)}@media(max-width:640px){.cookie-consent-banner{padding:var(--space-3)0}.cookie-consent-banner .container{flex-direction:column;text-align:center}.cookie-consent-banner p{font-size:var(--font-size-xs)}.cookie-consent-btn{padding:var(--space-2)var(--space-4);font-size:var(--font-size-xs)}}[data-theme="dark"] .cookie-consent-banner{background:var(--color-bg-alt);border-top:1px solid var(--color-border)}