*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#fff;--color-bg-dark:#1a1a1a;--color-bg-muted:#f4f4f4;--color-text:#1a1a1a;--color-text-light:#fff;--color-text-muted:#666;--color-accent:#8b7355;--color-border:#e0e0e0;--font-serif:"Noto Serif JP",serif;--font-sans:"Noto Sans JP",sans-serif;--container:1120px;--radius:4px;--transition:0.3s ease}html{scroll-behavior:smooth}body{font-family:var(--font-sans);font-weight:300;color:var(--color-text);background:var(--color-bg);line-height:1.8;-webkit-font-smoothing:antialiased}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}ul{list-style:none}.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}.section{padding-block:96px}.section-dark{background:var(--color-bg-dark);color:var(--color-text-light)}.section-header{text-align:center;margin-bottom:64px}.section-label{font-size:.7rem;letter-spacing:.3em;color:var(--color-accent);margin-bottom:12px;font-weight:500}.section-dark .section-label{color:#c4a97a}.section-title{font-family:var(--font-serif);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;line-height:1.4}.btn{display:inline-block;padding:14px 36px;font-size:.85rem;letter-spacing:.15em;font-weight:500;border-radius:var(--radius);transition:var(--transition);cursor:pointer}.btn-dark{background:var(--color-text);color:#fff;border:1px solid var(--color-text)}.btn-dark:hover{background:#333;border-color:#333}.btn-outline{border:1px solid hsla(0,0%,100%,.7);color:#fff}.btn-outline:hover{background:hsla(0,0%,100%,.15);border-color:#fff}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background var(--transition),box-shadow var(--transition)}.site-header.scrolled{background:rgba(26,26,26,.96);box-shadow:0 2px 20px rgba(0,0,0,.2)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}.logo{font-size:.85rem;font-weight:500;letter-spacing:.3em;color:#fff}.nav-menu ul{display:flex;gap:40px}.nav-menu a{font-size:.8rem;letter-spacing:.15em;color:hsla(0,0%,100%,.8);font-weight:400;transition:color var(--transition)}.nav-menu a:hover{color:#fff}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.hamburger span{display:block;width:24px;height:1.5px;background:#fff;transition:var(--transition)}.hamburger.active span:first-child{transform:translateY(6.5px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.hero{position:relative;height:100svh;min-height:600px;display:flex;align-items:center;background:linear-gradient(160deg,#2c2c2c,#1a1a1a 60%,#3a2e20);overflow:hidden}.hero:before{background:radial-gradient(ellipse at 70% 40%,rgba(139,115,85,.25) 0,transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(80,60,40,.3) 0,transparent 50%)}.hero:after,.hero:before{content:"";position:absolute;inset:0;pointer-events:none}.hero:after{background-image:linear-gradient(hsla(0,0%,100%,.03) 1px,transparent 0),linear-gradient(90deg,hsla(0,0%,100%,.03) 1px,transparent 0);background-size:60px 60px}.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.5) 0,transparent 70%)}.hero-content{position:relative;z-index:2;max-width:640px}.hero-eyebrow{font-size:.75rem;letter-spacing:.3em;color:var(--color-accent);margin-bottom:20px;font-weight:500}.hero-title{font-family:var(--font-serif);font-size:clamp(2.4rem,6vw,4.5rem);font-weight:700;color:#fff;line-height:1.3;margin-bottom:24px}.hero-title br{display:none}@media (max-width:767px){.hero-title br{display:block}}.hero-sub{font-size:clamp(.9rem,2vw,1rem);color:hsla(0,0%,100%,.7);margin-bottom:40px;font-weight:300;letter-spacing:.05em}.hero-scroll-indicator{position:absolute;bottom:36px;right:48px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}.hero-scroll-indicator span{font-size:.6rem;letter-spacing:.3em;color:hsla(0,0%,100%,.5);writing-mode:vertical-rl}.scroll-line{width:1px;height:60px;background:linear-gradient(180deg,hsla(0,0%,100%,.5),transparent);animation:scrollLine 2s ease-in-out infinite}@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}.concept{background:var(--color-bg)}.concept-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:40px;gap:40px}.concept-card{--cc-px:32px;--cc-pt:40px;padding:var(--cc-pt) var(--cc-px);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:box-shadow var(--transition),transform var(--transition)}.concept-card-img{display:none;margin:calc(-1 * var(--cc-pt)) calc(-1 * var(--cc-px)) 24px;height:180px;background-size:cover;background-position:50%}.concept-card-img.has-image{display:block}.concept-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.08);transform:translateY(-4px)}a.concept-card--link{display:block;text-decoration:none;color:inherit;cursor:pointer}a.concept-card--link:after{content:"→";display:block;margin-top:16px;font-size:.8rem;color:var(--color-accent);letter-spacing:.05em;opacity:0;transform:translateX(-4px);transition:opacity .3s ease,transform .3s ease}a.concept-card--link:hover:after{opacity:1;transform:translateX(0)}.concept-icon{font-size:.5rem;color:var(--color-accent);margin-bottom:20px;letter-spacing:.5em}.concept-card h3{font-family:var(--font-serif);font-size:1.05rem;font-weight:700;margin-bottom:12px}.concept-card p{font-size:.875rem;color:var(--color-text-muted);line-height:1.9}.spots-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:2px;gap:2px}.spot-card{background:#242424;overflow:hidden;transition:var(--transition)}.spot-card:hover .spot-img{transform:scale(1.04)}.spot-img{position:relative;height:220px;overflow:hidden;transition:transform .5s ease}.spot-img--1{background:linear-gradient(135deg,#3d2b1a,#6b4c2e 50%,#9e7350)}.spot-img--2{background:linear-gradient(135deg,#1a3d2b,#2e6b4c 50%,#50997a)}.spot-img--3{background:linear-gradient(135deg,#2b1a3d,#4c2e6b 50%,#7a50a0)}.spot-img--4{background:linear-gradient(135deg,#3d1a1a,#6b2e2e 50%,#a05050)}.spot-real-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}.spot-tag{position:absolute;top:16px;left:16px;font-size:.65rem;letter-spacing:.15em;background:rgba(0,0,0,.5);color:hsla(0,0%,100%,.9);padding:4px 10px;border-radius:2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spot-body{padding:24px 28px 28px}.spot-body h3{font-family:var(--font-serif);font-size:1.05rem;font-weight:700;margin-bottom:10px;color:#fff}.spot-desc{font-size:.85rem;color:hsla(0,0%,100%,.6);line-height:1.8;margin-bottom:16px}.spot-info{font-size:.75rem;color:hsla(0,0%,100%,.4);letter-spacing:.05em}.shops-page .site-header{background:rgba(26,26,26,.97);box-shadow:0 2px 20px rgba(0,0,0,.2)}.nav-current{color:#fff!important;border-bottom:1px solid hsla(0,0%,100%,.5)}.page-hero{padding-top:120px;padding-bottom:56px;background:var(--color-bg-dark);position:relative;overflow:hidden}.page-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(139,115,85,.2) 0,transparent 60%);pointer-events:none}.page-hero-back{font-size:.75rem;letter-spacing:.1em;margin-bottom:24px}.page-hero-back a{color:hsla(0,0%,100%,.5);transition:color var(--transition)}.page-hero-back a:hover{color:hsla(0,0%,100%,.9)}.page-hero-label{font-size:.7rem;letter-spacing:.35em;color:var(--color-accent);margin-bottom:10px;font-weight:500}.page-hero-title{font-family:var(--font-serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;color:#fff;margin-bottom:14px;line-height:1.3}.page-hero-lead{font-size:.875rem;color:hsla(0,0%,100%,.55);max-width:480px}.genre-filter-bar{position:-webkit-sticky;position:sticky;top:64px;z-index:50;background:hsla(0,0%,100%,.97);border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.genre-filter-inner{display:flex;gap:4px;padding-block:12px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.genre-filter-inner::-webkit-scrollbar{display:none}.genre-btn{flex-shrink:0;background:none;border:1px solid var(--color-border);color:var(--color-text-muted);font-family:var(--font-sans);font-size:.78rem;font-weight:400;letter-spacing:.1em;padding:7px 18px;border-radius:20px;cursor:pointer;transition:var(--transition);white-space:nowrap}.genre-btn:hover{border-color:var(--color-accent);color:var(--color-text)}.genre-btn.active{background:var(--color-text);border-color:var(--color-text);color:#fff;font-weight:500}.recommend-section{padding-block:64px;background:var(--color-bg-muted)}.recommend-header{margin-bottom:32px}.recommend-title{font-family:var(--font-serif);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:700}.recommend-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:20px;gap:20px}.rec-card{background:var(--color-bg);border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border);transition:box-shadow var(--transition),transform var(--transition)}.rec-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.09);transform:translateY(-3px)}.rec-img{position:relative;height:160px;display:flex;align-items:flex-end;padding:12px;gap:8px}.rec-badge{font-size:.65rem;letter-spacing:.15em;background:rgba(0,0,0,.45);color:hsla(0,0%,100%,.9);padding:3px 10px;border-radius:2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rec-body{padding:18px 20px 20px}.rec-name{font-family:var(--font-serif);font-size:1rem;font-weight:700;margin-bottom:8px}.rec-desc{font-size:.82rem;line-height:1.8;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.rec-desc,.rec-meta{color:var(--color-text-muted)}.rec-meta{display:flex;gap:10px;font-size:.76rem;margin-top:5px}.dir-section{padding-block:64px;background:var(--color-bg)}.dir-header{margin-bottom:32px}.dir-title{font-family:var(--font-serif);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:700;display:flex;align-items:baseline;gap:10px}.dir-count{font-size:.85rem;font-weight:300;color:var(--color-text-muted);font-family:var(--font-sans)}.dir-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:24px;gap:24px}.dir-card{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:box-shadow var(--transition),transform var(--transition);scroll-margin-top:140px}.dir-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.09);transform:translateY(-3px)}.dir-card.highlight{outline:2px solid var(--color-accent);outline-offset:2px}.dir-img{position:relative;height:140px;display:flex;align-items:flex-start;padding:12px;gap:8px}.dir-badge{font-size:.65rem;letter-spacing:.15em;background:rgba(0,0,0,.45);color:hsla(0,0%,100%,.9);padding:3px 10px;border-radius:2px}.dir-pick{font-size:.6rem;letter-spacing:.2em;background:var(--color-accent);color:#fff;padding:3px 8px;border-radius:2px}.dir-body{padding:18px 20px 20px}.dir-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.dir-name{font-size:1.05rem;line-height:1.3}.dir-desc{font-size:.83rem;line-height:1.85;margin-bottom:14px}.dir-details{gap:6px}.dir-detail{gap:12px}.meta-label{width:64px;color:var(--color-text-muted);font-size:.72rem}.dir-tags{margin-top:12px}.dir-tag{font-size:.65rem;letter-spacing:.08em;border:1px solid var(--color-border);padding:2px 8px;border-radius:2px}.dir-sns{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.sns-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:3px;border:1px solid var(--color-border);color:var(--color-text-muted);font-size:.72rem;font-weight:500;letter-spacing:.05em;text-decoration:none;transition:color .2s ease,border-color .2s ease,background .2s ease}.sns-btn:before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.5;flex-shrink:0}.sns-btn:hover{color:var(--sns-color,#555);border-color:var(--sns-color,#555);background:color-mix(in srgb,var(--sns-color,#555) 6%,transparent)}.dir-card,.rec-card,.shop-item{position:relative}.outside-hours:after{content:"";position:absolute;inset:0;background:hsla(35,12%,80%,.48);border-radius:var(--radius);pointer-events:none;z-index:5}.dir-empty{text-align:center;color:var(--color-text-muted);font-size:.875rem;padding:48px 0}.hidden{display:none}.spots-dir-section{padding:60px 0 80px;background:var(--color-bg)}.spot-card-link{display:block;color:inherit;text-decoration:none}.spot-card-link:hover .spot-card{box-shadow:0 6px 24px rgba(0,0,0,.14);transform:translateY(-3px)}.spot-card-link:hover .spot-img{transform:scale(1.04)}.spots-footer{text-align:center;margin-top:40px}.spot-dir-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:28px;gap:28px;margin-top:24px}.spot-dir-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.05);transition:box-shadow var(--transition),transform var(--transition);display:flex;flex-direction:column}.spot-dir-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.12);transform:translateY(-3px)}.spot-dir-img{height:180px;position:relative;overflow:hidden}.dir-badge{position:absolute;top:14px;left:14px;background:rgba(0,0,0,.55);color:#fff;font-size:.72rem;letter-spacing:.12em;padding:4px 10px;border-radius:3px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dir-body{padding:22px 24px 24px;flex:1 1;display:flex;flex-direction:column}.dir-top{margin-bottom:10px}.dir-name{font-family:var(--font-serif);font-size:1.1rem;font-weight:700;line-height:1.4;color:var(--color-text)}.dir-desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.8;margin-bottom:16px}.dir-details{border-top:1px solid var(--color-border);padding-top:12px;margin-bottom:14px;display:flex;flex-direction:column;gap:7px}.dir-detail{display:flex;gap:10px;font-size:.8rem;line-height:1.5;color:var(--color-text-muted)}.meta-label{font-weight:500;color:var(--color-text);white-space:nowrap;flex-shrink:0;min-width:52px}.dir-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.dir-tag{font-size:.72rem;background:var(--color-bg-muted);color:var(--color-text-muted);padding:3px 10px;border-radius:20px}.btn-ai,.dir-tag{letter-spacing:.04em}.btn-ai{display:flex;align-items:center;gap:8px;margin-top:auto;padding:11px 16px;background:var(--color-bg-dark);color:var(--color-text-light);border-radius:6px;font-size:.82rem;font-weight:500;text-decoration:none;transition:background var(--transition),transform var(--transition)}.btn-ai:hover{background:#2e2e2e;transform:translateX(2px)}.btn-ai-icon{font-size:.85rem;opacity:.65;flex-shrink:0}.btn-ai-text{flex:1 1}.btn-ai-arrow{opacity:.5;flex-shrink:0;transition:transform var(--transition)}.btn-ai:hover .btn-ai-arrow{transform:translateX(4px);opacity:.9}.spot-dir-card.highlight{outline:2px solid var(--color-accent);outline-offset:3px}.nearby-link{display:block;text-decoration:none;color:inherit;border-radius:var(--radius)}.nearby-link--no-url{cursor:default}.nearby-link:not(.nearby-link--no-url):hover .nearby-card{box-shadow:0 10px 36px rgba(0,0,0,.13);transform:translateY(-5px)}.nearby-link:not(.nearby-link--no-url):hover .nearby-img{transform:scale(1.04)}.nearby-link-icon{position:absolute;top:12px;right:14px;font-size:.95rem;color:hsla(0,0%,100%,.75);line-height:1;transition:color var(--transition),transform var(--transition)}.nearby-link:hover .nearby-link-icon{color:#fff;transform:translate(2px,-2px)}.nearby{background:var(--color-bg)}.section-lead{margin-top:12px;font-size:.875rem;color:var(--color-text-muted);max-width:540px;margin-inline:auto}.nearby-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:28px;gap:28px}.nearby-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border);transition:box-shadow var(--transition),transform var(--transition)}.nearby-img{height:180px;position:relative;overflow:hidden;transition:transform .5s ease}.nearby-img--ghibli{background:linear-gradient(135deg,#1a3a1a,#2e6b3a 50%,#5aaa6a)}.nearby-img--moricoro{background:linear-gradient(135deg,#1a2e3a,#2e5a6b 50%,#5a99aa)}.nearby-img--toyota{background:linear-gradient(135deg,#3a1a1a,#6b2e2e 50%,#aa5a5a)}.nearby-badge{position:absolute;top:14px;left:14px;font-size:.65rem;letter-spacing:.15em;background:rgba(0,0,0,.45);color:hsla(0,0%,100%,.9);padding:4px 10px;border-radius:2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nearby-body{padding:20px 22px 24px}.nearby-access{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--color-accent);letter-spacing:.05em;margin-bottom:8px}.access-icon{font-size:.55rem}.nearby-body h3{font-family:var(--font-serif);font-size:1.05rem;font-weight:700;margin-bottom:10px}.nearby-body p{font-size:.845rem;color:var(--color-text-muted);line-height:1.85}.shops{background:var(--color-bg-muted)}.shops-list{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:24px;gap:24px}.shop-item-link{display:block;color:inherit;text-decoration:none}.shop-item-link:hover .shop-item{box-shadow:0 4px 20px rgba(0,0,0,.09);transform:translateY(-2px)}.shops-footer{margin-top:40px;text-align:center}.shop-item{background:var(--color-bg);border-radius:var(--radius);padding:28px 32px;border:1px solid var(--color-border);transition:box-shadow var(--transition);overflow:hidden}.shop-item--has-img{padding-top:0}.shop-item-img{height:180px;background-size:cover;background-position:50%;margin:0 -32px 24px;transition:transform .5s cubic-bezier(.16,1,.3,1)}.shop-item-link:hover .shop-item-img{transform:scale(1.04)}.shop-item:hover{box-shadow:0 4px 20px rgba(0,0,0,.07)}.shop-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px}.shop-category{display:inline-block;font-size:.65rem;letter-spacing:.15em;color:var(--color-accent);border:1px solid var(--color-accent);padding:2px 8px;border-radius:2px;margin-bottom:6px}.shop-name{font-family:var(--font-serif);font-size:1.1rem;font-weight:700}.shop-status{flex-shrink:0;font-size:.7rem;letter-spacing:.1em;padding:3px 10px;border-radius:2px;margin-top:4px}.shop-status.open{background:rgba(60,130,80,.1);color:#3c8250}.shop-status.closed{background:rgba(180,60,60,.1);color:#b43c3c}.shop-details{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--color-border);padding-top:16px}.shop-detail{display:flex;gap:16px;font-size:.82rem}.detail-label{flex-shrink:0;width:80px;color:var(--color-text-muted);font-size:.75rem}.share-float{position:fixed;right:24px;bottom:80px;z-index:900;gap:10px}.share-float,.share-float-menu{display:flex;flex-direction:column;align-items:center}.share-float-menu{gap:8px;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .25s ease,transform .25s ease}.share-float-menu.open{opacity:1;transform:translateY(0);pointer-events:auto}.share-float-toggle{width:52px;height:52px;border-radius:50%;background:#1a1a1a;color:#fff;border:none;cursor:pointer;font-size:.52rem;font-family:var(--font-sans);letter-spacing:.12em;font-weight:500;box-shadow:0 4px 20px rgba(0,0,0,.28);transition:transform .2s ease,background .2s ease;line-height:1}.share-float-toggle.active,.share-float-toggle:hover{background:#2e2e2e;transform:scale(1.06)}.share-float-btn{width:44px;height:44px;border-radius:50%;border:1px solid hsla(0,0%,100%,.14);background:hsla(0,0%,5%,.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;cursor:pointer;font-size:.58rem;font-family:var(--font-sans);font-weight:500;letter-spacing:.06em;box-shadow:0 2px 12px rgba(0,0,0,.22);transition:background .2s ease,transform .2s ease;line-height:1}.share-float-btn:hover{background:rgba(38,38,38,.96);transform:scale(1.08)}.share-float-menu .share-float-btn:first-child{transition-delay:0s}.share-float-menu .share-float-btn:nth-child(2){transition-delay:.04s}.share-float-menu .share-float-btn:nth-child(3){transition-delay:.08s}.share-float-menu .share-float-btn:nth-child(4){transition-delay:.12s}@media (max-width:768px){.share-float{right:16px;bottom:64px}}.site-footer{background:var(--color-bg-dark);color:hsla(0,0%,100%,.4);padding-block:48px;text-align:center}.footer-logo{font-size:.8rem;letter-spacing:.4em;color:hsla(0,0%,100%,.6);margin-bottom:12px}.footer-copy{font-size:.72rem;letter-spacing:.05em}.header-actions{display:flex;align-items:center;gap:16px}.lang-switcher{background:none;border:1px solid hsla(0,0%,100%,.4);color:hsla(0,0%,100%,.8);font-family:var(--font-sans);font-size:.7rem;font-weight:500;letter-spacing:.15em;padding:4px 10px;border-radius:2px;cursor:pointer;transition:var(--transition);line-height:1}.lang-switcher:hover{border-color:hsla(0,0%,100%,.9);color:#fff}.map-section{background:#111}.map-wrapper{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid hsla(0,0%,100%,.08)}.google-map-embed{width:100%;height:480px;border:0;display:block}.map-note{margin-top:20px;font-size:.8rem;color:hsla(0,0%,100%,.45);text-align:center;letter-spacing:.05em}@keyframes fadeUpIn{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}.fade-in{opacity:0;transform:translateY(32px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}.fade-in.visible{opacity:1;transform:translateY(0)}.concept-grid .concept-card:first-child{transition-delay:0s}.concept-grid .concept-card:nth-child(2){transition-delay:.15s}.concept-grid .concept-card:nth-child(3){transition-delay:.3s}.spots-grid .spot-card:first-child{transition-delay:0s}.spots-grid .spot-card:nth-child(2){transition-delay:.15s}.spots-grid .spot-card:nth-child(3){transition-delay:.3s}.spots-grid .spot-card:nth-child(4){transition-delay:.45s}.shops-list .shop-item:first-child{transition-delay:0s}.shops-list .shop-item:nth-child(2){transition-delay:.15s}.shops-list .shop-item:nth-child(3){transition-delay:.3s}.shops-list .shop-item:nth-child(4){transition-delay:.45s}.nearby-grid .nearby-card:first-child{transition-delay:0s}.nearby-grid .nearby-card:nth-child(2){transition-delay:.15s}.nearby-grid .nearby-card:nth-child(3){transition-delay:.3s}.hero-content .btn,.hero-eyebrow,.hero-scroll-indicator,.hero-sub,.hero-title{opacity:0;animation-fill-mode:forwards;animation-timing-function:cubic-bezier(.16,1,.3,1);animation-duration:1s;animation-name:fadeUpIn}.hero-eyebrow{animation-delay:.25s}.hero-title{animation-delay:.5s}.hero-sub{animation-delay:.72s}.hero-content .btn{animation-delay:.9s}.hero-scroll-indicator{animation-delay:1.1s}@media (max-width:900px){.section{padding-block:72px}.concept-grid{gap:20px;max-width:540px;margin-inline:auto}.concept-grid,.nearby-grid,.spots-grid{grid-template-columns:1fr}.nearby-grid{max-width:540px;margin-inline:auto}.dir-grid,.recommend-row,.shops-list{grid-template-columns:1fr}.shops-list{max-width:540px;margin-inline:auto}}@media (max-width:640px){.section{padding-block:56px}.section-header{margin-bottom:40px}.google-map-embed{height:320px}.hamburger,.nav-menu{display:flex}.nav-menu{position:fixed;top:64px;left:0;right:0;bottom:0;background:hsla(0,0%,8%,.98);align-items:center;justify-content:center;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);z-index:99}.nav-menu.open{transform:translateX(0)}.nav-menu ul{flex-direction:column;align-items:center;gap:36px}.nav-menu a{font-size:1.1rem;letter-spacing:.25em;color:hsla(0,0%,100%,.85)}.hero-scroll-indicator{display:none}.hero-content{padding-inline:0}.concept-card{--cc-px:24px;--cc-pt:28px;padding:var(--cc-pt) var(--cc-px)}.spot-img{height:180px}.shop-item,.spot-body{padding:20px}.shop-detail{flex-direction:column;gap:2px}.detail-label{width:auto}.spot-dir-grid{grid-template-columns:1fr;gap:24px}}.rec-card-link{display:block;color:inherit;text-decoration:none}.dir-card[data-detail-href]:hover,.rec-card-link:hover .rec-card{box-shadow:0 8px 32px rgba(0,0,0,.12);transform:translateY(-2px);transition:transform .2s ease,box-shadow .2s ease}.shop-detail-notfound{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:12px;padding:60px 20px}.shop-detail-notfound-msg{font-size:1.2rem;font-weight:500}.shop-detail-notfound-sub{color:var(--color-text-muted);font-size:.9rem;margin-bottom:12px}.shop-detail-hero{position:relative;min-height:420px;display:flex;align-items:flex-end;margin-top:64px}.shop-detail-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.2) 0,rgba(0,0,0,.65))}.shop-detail-hero-content{position:relative;z-index:1;padding:48px 0 40px;color:#fff}.shop-detail-back{display:inline-block;font-size:.78rem;letter-spacing:.1em;color:hsla(0,0%,100%,.7);text-decoration:none;margin-bottom:20px;transition:color .2s}.shop-detail-back:hover{color:#fff}.shop-detail-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px}.shop-detail-badge{font-size:.72rem;letter-spacing:.15em;background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.3);padding:3px 10px;border-radius:2px;color:hsla(0,0%,100%,.9)}.shop-detail-name{font-family:var(--font-serif);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;line-height:1.3;margin-bottom:8px}.shop-detail-catchcopy{font-size:1rem;color:hsla(0,0%,100%,.8);font-weight:300;letter-spacing:.05em}.shop-detail-body{padding:56px 0 80px}.shop-detail-grid{display:grid;grid-template-columns:1fr 340px;grid-gap:48px;gap:48px;align-items:start}.shop-detail-main{display:flex;flex-direction:column;gap:40px}.shop-detail-section{display:flex;flex-direction:column;gap:16px}.shop-detail-sec-title{font-family:var(--font-serif);font-size:1.1rem;font-weight:700;letter-spacing:.05em;padding-bottom:10px;border-bottom:1px solid var(--color-border);margin-bottom:4px}.shop-detail-desc{font-size:.95rem;line-height:1.9;color:var(--color-text)}.shop-detail-long-desc{font-size:.92rem;line-height:1.9;color:#444;white-space:pre-line}.shop-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:12px;gap:12px}.shop-gallery-item{aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius);background:var(--color-bg-muted)}.shop-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.shop-gallery-item:hover img{transform:scale(1.04)}.shop-detail-aside{position:-webkit-sticky;position:sticky;top:84px}.shop-info-card{background:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:var(--radius);padding:28px 24px}.shop-info-title{font-family:var(--font-serif);font-size:.85rem;letter-spacing:.2em;font-weight:700;margin-bottom:20px;color:var(--color-text)}.shop-info-dl{display:grid;grid-template-columns:auto 1fr;grid-gap:10px 16px;gap:10px 16px;margin-bottom:20px}.shop-info-dl dt{font-size:.75rem;letter-spacing:.1em;color:var(--color-text-muted);padding-top:2px;white-space:nowrap}.shop-info-dl dd{font-size:.88rem;line-height:1.6;color:var(--color-text)}@media (max-width:900px){.shop-detail-grid{grid-template-columns:1fr}.shop-detail-aside{position:static}}@media (max-width:640px){.shop-detail-hero{min-height:320px}.shop-detail-hero-content{padding:32px 0 28px}.shop-gallery-grid{grid-template-columns:repeat(2,1fr)}}.auth-overlay{position:fixed;inset:0;background:#f0ede8;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:40px 36px;width:100%;max-width:400px;box-shadow:0 4px 24px rgba(0,0,0,.07)}.auth-title{font-family:var(--font-serif);font-size:1.2rem;font-weight:700;margin-bottom:6px}.auth-note{font-size:.82rem;color:var(--color-text-muted);margin-bottom:24px}.auth-error{background:rgba(180,60,60,.08);border:1px solid rgba(180,60,60,.25);color:#b43c3c;padding:10px 14px;border-radius:4px;font-size:.85rem;margin-bottom:16px}.btn-primary{background:var(--color-text);color:#fff;border:1px solid var(--color-text)}.btn-primary:hover{background:#333;border-color:#333}.btn-danger{background:rgba(180,60,60,.08);color:#b43c3c;border:1px solid rgba(180,60,60,.3)}.btn-danger:hover{background:rgba(180,60,60,.16)}.btn-sm{padding:4px 12px;font-size:.78rem}.btn-full{width:100%;display:block;text-align:center}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.78rem;font-weight:500;color:var(--color-text-muted);margin-bottom:5px;letter-spacing:.03em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.9rem;font-family:var(--font-sans);background:#fff;color:var(--color-text);transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent)}.form-group input:disabled{background:#f4f4f4;color:#999}.admin-body{display:flex;min-height:100vh;background:#f7f5f2}.admin-sidebar{width:220px;flex-shrink:0;background:#1a1a1a;color:#fff;display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto}.admin-sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid hsla(0,0%,100%,.08);margin-bottom:8px}.admin-sidebar-title{font-family:var(--font-serif);font-size:.95rem;font-weight:700;letter-spacing:.12em;color:#fff}.admin-sidebar-sub{font-size:.68rem;letter-spacing:.12em;color:hsla(0,0%,100%,.4);margin-top:3px}.sidebar-section{padding:4px 12px 12px}.sidebar-section--footer{margin-top:auto;padding-top:12px;border-top:1px solid hsla(0,0%,100%,.08)}.admin-sidebar .mode-btn{display:block;width:100%;padding:11px 14px;border-radius:5px;font-size:.83rem;letter-spacing:.04em;color:hsla(0,0%,100%,.6);text-align:left;background:none;border:none;cursor:pointer;margin-bottom:3px;transition:background .18s,color .18s;text-decoration:none}.admin-sidebar .mode-btn:hover{background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.9)}.admin-sidebar .mode-btn.active{background:hsla(0,0%,100%,.13);color:#fff;font-weight:500}.admin-logout-btn{display:block;width:100%;padding:9px 14px;border-radius:5px;font-size:.78rem;letter-spacing:.04em;color:hsla(0,0%,100%,.45);background:none;border:1px solid hsla(0,0%,100%,.15);cursor:pointer;transition:background .18s,color .18s,border-color .18s}.admin-logout-btn:hover{background:hsla(0,0%,100%,.06);color:hsla(0,0%,100%,.7);border-color:hsla(0,0%,100%,.3)}.admin-main{flex:1 1;min-width:0;overflow:auto}.admin-main .btn-outline{border-color:var(--color-border);color:var(--color-text)}.admin-main .btn-outline:hover{background:#f0ede8;border-color:#aaa}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:8px}.admin-table{border-collapse:collapse;font-size:.875rem}.admin-table td,.admin-table th{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-border)}.admin-table th{font-size:.75rem;letter-spacing:.05em;color:var(--color-text-muted);font-weight:500}.admin-table th,.admin-table tr:hover td{background:#fafafa}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-dialog{background:#fff;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.18);display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:1rem;font-weight:700;margin:0}.modal-close{background:none;border:none;font-size:1rem;cursor:pointer;color:var(--color-text-muted);padding:4px 8px}.modal-body{padding:20px 24px;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--color-border)}.page-container{min-height:100vh}.page-title{font-family:var(--font-serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;color:#fff;line-height:1.3;margin-top:8px}.section-alt{background:var(--color-bg-muted)}.genre-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}.genre-tab{padding:8px 20px;border:1px solid var(--color-border);border-radius:20px;background:var(--color-bg);color:var(--color-text-muted);font-size:.82rem;letter-spacing:.05em;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}.genre-tab:hover{border-color:var(--color-accent);color:var(--color-accent)}.genre-tab.active{background:var(--color-text);border-color:var(--color-text);color:#fff}.rec-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:24px;gap:24px}.dir-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:10px}.shop-genre-badge{letter-spacing:.12em;background:var(--color-bg-muted);color:var(--color-text-muted)}.shop-genre-badge,.shop-open-badge{font-size:.68rem;padding:3px 10px;border-radius:2px;font-weight:500}.shop-open-badge{letter-spacing:.1em;background:#e8f5e9;color:#2e7d32}.dir-hours{margin-top:6px}.dir-closed,.dir-hours{font-size:.8rem;color:var(--color-text-muted)}.dir-closed{margin-top:4px}.shop-sns-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.sns-link{font-size:.75rem;letter-spacing:.08em;padding:4px 12px;border:1px solid var(--color-border);border-radius:3px;color:var(--color-text-muted);transition:border-color var(--transition),color var(--transition);text-transform:uppercase}.sns-link:hover{border-color:var(--color-accent);color:var(--color-accent)}.spots-dir-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:28px;gap:28px;margin-top:24px}.spot-dir-body{padding:22px 24px 24px;flex:1 1;display:flex;flex-direction:column}.spot-dir-category{font-size:.7rem;letter-spacing:.18em;color:var(--color-accent);font-weight:500;margin-bottom:6px;text-transform:uppercase}.spot-dir-name{font-family:var(--font-serif);font-size:1.1rem;font-weight:700;line-height:1.4;color:var(--color-text);margin-bottom:10px}.spot-dir-desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.8;margin-bottom:16px}.spot-dir-info{display:grid;grid-template-columns:auto 1fr;grid-gap:4px 14px;gap:4px 14px;font-size:.8rem;color:var(--color-text-muted);border-top:1px solid var(--color-border);padding-top:12px;margin-bottom:14px}.spot-dir-info dt{font-weight:500;color:var(--color-text);white-space:nowrap}.spot-dir-info dd{margin:0}.spot-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.tag{font-size:.72rem;background:var(--color-bg-muted);color:var(--color-text-muted);padding:3px 10px;border-radius:20px;letter-spacing:.04em}@media (max-width:768px){.spots-dir-grid{grid-template-columns:1fr}.genre-tabs{gap:6px}.genre-tab{padding:7px 14px;font-size:.78rem}.rec-grid{grid-template-columns:1fr}}