/* TABINAVI v3 */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700;900&family=Sora:wght@400;500;600&display=swap');
:root{--acc:#e8603a;--teal:#00c2a8;--vio:#9b5de5;--bg:#0d0d0f;--bg2:#141416;--bg3:#1c1c20;--card:#1e1e22;--bdr:#2a2a30;--txt:#f0efe8;--muted:#8a8a96;--fh:'Outfit',sans-serif;--fb:'Sora',sans-serif;--r:18px;--sh:0 8px 40px rgba(0,0,0,.55);}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--fb);background:var(--bg);color:var(--txt);min-height:100vh;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
.page{display:none !important;}.page.active{display:block !important;}

/* Header */
#header{position:sticky;top:0;z-index:300;height:54px;background:rgba(13,13,15,.92);border-bottom:1px solid var(--bdr);backdrop-filter:blur(16px);display:flex;align-items:center;padding:0 24px;gap:14px;}
.logo{font-family:var(--fh);font-weight:900;font-size:1.15rem;background:linear-gradient(90deg,var(--acc),#f0a500);-webkit-background-clip:text;-webkit-text-fill-color:transparent;cursor:pointer;}
#header nav{display:flex;gap:2px;align-items:center;flex:1;justify-content:center;}
#header nav button{background:none;border:none;cursor:pointer;color:var(--muted);font-family:var(--fb);font-size:.82rem;padding:5px 12px;border-radius:7px;transition:all .18s;}
#header nav button:hover{color:var(--txt);background:var(--bg3);}
.hd-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.hd-book-btn{padding:7px 16px;font-size:.82rem;}
.lang-wrap{position:relative;}
.lang-btn{background:var(--bg3);border:1px solid var(--bdr);border-radius:7px;padding:5px 10px;cursor:pointer;display:flex;align-items:center;gap:5px;color:var(--txt);font-size:.8rem;font-family:var(--fb);transition:all .18s;white-space:nowrap;}
.lang-btn:hover,.lang-btn.open{border-color:var(--acc);}
.lang-arrow{font-size:.65rem;color:var(--muted);transition:transform .18s;}
.lang-btn.open .lang-arrow{transform:rotate(180deg);}
.lang-drop{position:absolute;right:0;top:calc(100% + 6px);background:var(--card);border:1px solid var(--bdr);border-radius:10px;padding:5px;z-index:500;width:148px;box-shadow:var(--sh);display:none;}
.lang-drop.open{display:block;}
.lang-opt{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border-radius:6px;cursor:pointer;font-size:.82rem;transition:background .15s;}
.lang-opt:hover{background:var(--bg3);}
.lang-opt.sel{border-left:3px solid var(--acc);color:var(--acc);}

/* Buttons */
.btn-primary{background:linear-gradient(135deg,var(--acc),#d44a28);color:#fff;border:none;border-radius:10px;padding:10px 22px;font-family:var(--fb);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:6px;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(232,96,58,.4);}
.btn-outline{background:transparent;color:var(--txt);border:1.5px solid var(--bdr);border-radius:10px;padding:10px 22px;font-family:var(--fb);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:6px;}
.btn-outline:hover{border-color:var(--acc);color:var(--acc);}
.btn-ghost{background:transparent;color:var(--txt);border:1.5px solid rgba(255,255,255,.15);border-radius:10px;padding:10px 22px;font-family:var(--fb);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;}
.btn-ghost:hover{border-color:rgba(255,255,255,.4);}
.btn-lg{padding:14px 32px;font-size:.95rem;border-radius:12px;}

/* Hero */
#hero{position:relative;min-height:auto;display:block;padding:0;overflow:hidden;}
.hero-bg{position:absolute;inset:0;pointer-events:none;}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--bdr) 1px,transparent 1px),linear-gradient(90deg,var(--bdr) 1px,transparent 1px);background-size:60px 60px;opacity:.25;}
.hero-glow1{position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:800px;background:radial-gradient(circle,rgba(232,96,58,.15) 0%,transparent 70%);}
.hero-glow2{position:absolute;bottom:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(0,194,168,.08) 0%,transparent 70%);}
.hero-content{position:relative;z-index:1;}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(232,96,58,.12);border:1px solid rgba(232,96,58,.3);border-radius:20px;padding:5px 14px;font-size:.8rem;font-weight:600;color:var(--acc);margin-bottom:20px;}
#hero h1{font-family:var(--fh);font-weight:900;font-size:clamp(2.8rem,7vw,4.8rem);line-height:1.05;margin-bottom:18px;}
.grad{background:linear-gradient(90deg,var(--acc),#f0a500);-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.hero-sub{font-size:clamp(.9rem,2vw,1.05rem);color:var(--muted);max-width:520px;line-height:1.7;margin-bottom:28px;}
.hero-stats{display:flex;align-items:center;gap:16px;margin-bottom:32px;flex-wrap:wrap;}
.stat{display:flex;flex-direction:column;gap:2px;}
.stat-n{font-family:var(--fh);font-weight:900;font-size:1.3rem;}
.stat-l{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;}
.stat-div{width:1px;height:36px;background:var(--bdr);}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;}

/* Section */
.section{padding:80px 0;}.section-dark{background:var(--bg2);}
.pw{max-width:1100px;margin:0 auto;padding:0 24px;}
.section-header{text-align:center;margin-bottom:48px;}
.section-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(232,96,58,.1);border:1px solid rgba(232,96,58,.25);border-radius:20px;padding:4px 14px;font-size:.78rem;font-weight:600;color:var(--acc);margin-bottom:14px;}
.section-header h2{font-family:var(--fh);font-weight:900;font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:10px;}
.section-header p{color:var(--muted);font-size:.95rem;max-width:520px;margin:0 auto;}

/* Exp Grid */
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.exp-card{background:var(--card);border:1.5px solid var(--bdr);border-radius:22px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;}
.exp-card:hover{transform:translateY(-6px);box-shadow:var(--sh);border-color:var(--acc);}
.exp-thumb{height:200px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.exp-asakusa{background:linear-gradient(135deg,#2d1a0e 0%,#5c3317 50%,#3d1f08 100%);}
.exp-shinjuku{background:linear-gradient(135deg,#1a0d2e 0%,#3d1f5c 50%,#1f0d3d 100%);}
.exp-jdm{background:linear-gradient(135deg,#071f1c 0%,#0d3d35 50%,#071f1c 100%);}
.exp-emoji{font-size:5rem;filter:drop-shadow(0 4px 16px rgba(0,0,0,.5));}
.exp-series-badge{position:absolute;top:12px;left:12px;padding:4px 10px;border-radius:20px;font-size:.72rem;font-weight:700;color:#fff;}
.exp-body{padding:18px;}
.exp-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px;}
.tag{font-size:.7rem;padding:2px 8px;border-radius:20px;font-weight:600;}
.tag-acc{background:rgba(232,96,58,.15);color:var(--acc);}
.tag-vio{background:rgba(155,93,229,.15);color:var(--vio);}
.tag-teal{background:rgba(0,194,168,.15);color:var(--teal);}
.exp-card-title{font-family:var(--fh);font-weight:700;font-size:1rem;margin-bottom:5px;line-height:1.3;}
.exp-loc{font-size:.8rem;color:var(--muted);margin-bottom:8px;}
.exp-card-desc{color:var(--muted);font-size:.84rem;line-height:1.6;margin-bottom:12px;}
.exp-foot{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--bdr);}
.exp-rating{display:flex;align-items:center;gap:4px;font-size:.83rem;}
.star{color:#f0a500;}.exp-rc{color:var(--muted);font-size:.76rem;}
.exp-price{font-family:var(--fh);font-weight:700;font-size:.95rem;}
.exp-per{font-size:.73rem;color:var(--muted);font-weight:400;}

/* Guides */
.guides-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.guide-card{background:var(--card);border:1px solid var(--bdr);border-radius:18px;padding:24px;text-align:center;transition:all .2s;}
.guide-card:hover{border-color:var(--acc);transform:translateY(-4px);box-shadow:var(--sh);}
.guide-av{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--acc),#f0a500);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 14px;}
.guide-name{font-family:var(--fh);font-weight:700;font-size:1rem;margin-bottom:4px;}
.guide-role{color:var(--teal);font-size:.78rem;font-weight:600;margin-bottom:10px;}
.guide-langs{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;margin-bottom:12px;}
.guide-lang{background:var(--bg3);border:1px solid var(--bdr);border-radius:20px;padding:2px 9px;font-size:.72rem;color:var(--muted);}
.guide-bio{color:var(--muted);font-size:.82rem;line-height:1.6;}

/* Reviews */
.reviews-overall{display:flex;align-items:center;gap:10px;justify-content:center;margin-top:10px;}
.rev-big-num{font-family:var(--fh);font-weight:900;font-size:2.2rem;}
.rev-big-label{color:var(--muted);font-size:.86rem;}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.review-card{background:var(--card);border:1px solid var(--bdr);border-radius:16px;padding:20px;}
.rev-stars{color:#f0a500;font-size:.9rem;margin-bottom:8px;}
.rev-text{color:var(--muted);font-size:.84rem;line-height:1.6;margin-bottom:14px;}
.rev-author{display:flex;align-items:center;gap:10px;}
.rev-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--vio),var(--teal));display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;}
.rev-name{font-weight:600;font-size:.84rem;}.rev-source{font-size:.72rem;color:var(--muted);}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:10px;max-width:720px;margin:0 auto;}
.faq-item{background:var(--card);border:1px solid var(--bdr);border-radius:14px;overflow:hidden;}
.faq-q{width:100%;background:none;border:none;padding:18px 20px;text-align:left;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:var(--fb);font-size:.9rem;color:var(--txt);gap:12px;}
.faq-q:hover{background:var(--bg3);}
.faq-icon{color:var(--muted);font-size:1rem;transition:transform .2s;flex-shrink:0;}
.faq-item.open .faq-icon{transform:rotate(45deg);color:var(--acc);}
.faq-a{display:none;padding:0 20px 18px;color:var(--muted);font-size:.86rem;line-height:1.7;}
.faq-item.open .faq-a{display:block;}

/* Contact */
.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.contact-card{background:var(--card);border:1.5px solid var(--bdr);border-radius:16px;padding:20px;display:flex;align-items:center;gap:14px;transition:all .2s;cursor:pointer;}
.contact-card:hover{border-color:var(--acc);transform:translateY(-3px);box-shadow:var(--sh);}
.contact-icon{font-size:2rem;flex-shrink:0;}
.contact-info h4{font-family:var(--fh);font-weight:700;font-size:.95rem;margin-bottom:2px;}
.contact-info p{color:var(--muted);font-size:.78rem;}

/* Detail */
.det-wrap{max-width:1000px;margin:0 auto;padding:20px 24px 80px;}
.det-back{display:inline-flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;color:var(--muted);font-size:.86rem;margin-bottom:16px;font-family:var(--fb);padding:0;transition:color .18s;}
.det-back:hover{color:var(--txt);}
.det-hero{height:320px;border-radius:18px;overflow:hidden;margin-bottom:24px;position:relative;display:flex;align-items:flex-end;}
.det-hero-asakusa{background:linear-gradient(135deg,#2d1a0e,#5c3317,#3d1f08);}
.det-hero-shinjuku{background:linear-gradient(135deg,#1a0d2e,#3d1f5c,#1f0d3d);}
.det-hero-jdm{background:linear-gradient(135deg,#071f1c,#0d3d35,#071f1c);}
.det-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.7));}
.det-hero-inner{position:relative;z-index:1;padding:28px 32px;}
.det-hero-inner h1{font-family:var(--fh);font-weight:900;font-size:clamp(1.6rem,4vw,2.4rem);line-height:1.2;color:#fff;}
.det-hero-inner h1 small{font-size:.55em;opacity:.8;display:block;margin-top:4px;}
.det-series-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:700;color:#fff;margin-bottom:12px;}
.det-layout{display:grid;grid-template-columns:1fr 280px;gap:28px;}
@media(max-width:800px){.det-layout{grid-template-columns:1fr;}}
.det-loc{color:var(--muted);font-size:.86rem;margin-bottom:16px;}
.det-desc{color:var(--muted);line-height:1.8;margin-bottom:18px;font-size:.93rem;}
.det-tabs{display:flex;gap:2px;margin-bottom:18px;border-bottom:1px solid var(--bdr);}
.det-tab{background:none;border:none;cursor:pointer;padding:8px 14px;font-family:var(--fb);font-size:.83rem;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .18s;}
.det-tab.active{color:var(--acc);border-bottom-color:var(--acc);}
.tab-panel{display:none;}.tab-panel.active{display:block;}
.hl-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:10px;}
.hl-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.hl-list li{font-size:.88rem;padding:8px 12px;background:var(--bg3);border-radius:8px;line-height:1.5;}
.meet-box{background:var(--bg3);border-radius:12px;padding:14px 16px;margin-bottom:18px;}
.meet-box h4{font-family:var(--fh);font-weight:700;font-size:.85rem;margin-bottom:6px;color:var(--teal);}
.meet-box p{color:var(--muted);font-size:.84rem;}
.inc-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;}
.inc-box{background:var(--bg3);border-radius:12px;padding:14px;}
.inc-box h4{font-size:.82rem;font-weight:700;margin-bottom:10px;}
.inc-list{list-style:none;display:flex;flex-direction:column;gap:6px;}
.inc-list li{font-size:.82rem;color:var(--muted);}
.inc-yes li::before{content:"✓ ";color:var(--teal);}
.inc-no li::before{content:"✕ ";color:#e55;}
.itin-list{display:flex;flex-direction:column;}
.itin-item{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid var(--bdr);}
.itin-item:last-child{border-bottom:none;}
.itin-time{font-family:var(--fh);font-weight:700;font-size:.82rem;color:var(--acc);min-width:54px;flex-shrink:0;padding-top:2px;}
.itin-content h4{font-family:var(--fh);font-weight:700;font-size:.9rem;margin-bottom:3px;}
.itin-content p{color:var(--muted);font-size:.82rem;line-height:1.5;}

/* Sidebar */
.det-sidebar{position:sticky;top:70px;align-self:start;}
.book-card{background:var(--card);border:1.5px solid var(--bdr);border-radius:18px;padding:22px;}
.book-price{font-family:var(--fh);font-weight:900;font-size:1.6rem;margin-bottom:4px;}
.book-per{font-size:.75rem;color:var(--muted);font-weight:400;margin-left:4px;}
.book-rating{font-size:.86rem;margin-bottom:14px;}
.plan-mini-wrap{margin:14px 0;padding:12px;background:var(--bg3);border-radius:10px;}
.plan-mini-label{font-size:.75rem;color:var(--muted);margin-bottom:8px;}
.plan-mini{display:flex;justify-content:space-between;align-items:center;padding:9px 10px;border-radius:8px;cursor:pointer;font-size:.82rem;border:1.5px solid var(--bdr);background:var(--bg2);margin-bottom:6px;transition:all .15s;}
.plan-mini:last-child{margin-bottom:0;}
.plan-mini:hover,.plan-mini.selected{border-color:var(--acc);background:rgba(232,96,58,.08);}
.cancel-note{text-align:center;font-size:.75rem;color:var(--muted);margin-top:10px;}
.why-mini-card{background:var(--bg3);border:1px solid var(--bdr);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:10px;}
.why-mini-item{display:flex;gap:10px;align-items:flex-start;font-size:.82rem;color:var(--muted);line-height:1.5;}
.why-mini-item span{font-size:1.1rem;flex-shrink:0;}

/* JDM Plans */
.jdm-plan-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}
.jdm-plan-card{background:var(--bg3);border:1.5px solid var(--bdr);border-radius:16px;padding:20px;position:relative;}
.jdm-special{border-color:rgba(232,96,58,.4);background:linear-gradient(135deg,rgba(232,96,58,.06),var(--bg3));}
.jdm-random{border-color:rgba(0,194,168,.3);}
.jdm-plan-badge{position:absolute;top:-1px;right:16px;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:0 0 8px 8px;background:var(--acc);color:#fff;}
.jdm-badge-green{background:var(--teal);}
.jdm-plan-icon{font-size:2.2rem;margin:8px 0 10px;}
.jdm-plan-card h4{font-family:var(--fh);font-weight:700;font-size:.95rem;margin-bottom:8px;}
.jdm-plan-price{font-family:var(--fh);font-weight:900;font-size:1.3rem;margin-bottom:4px;}
.jdm-plan-price span{font-size:.75rem;color:var(--muted);font-weight:400;margin-left:4px;}
.plan-list-sm{list-style:none;display:flex;flex-direction:column;gap:5px;margin:12px 0 16px;}
.plan-list-sm li{font-size:.8rem;color:var(--muted);}
.plan-btn-sm{width:100%;padding:9px;font-size:.82rem;}

/* Bonus */
.bonus-wrap{background:var(--bg3);border:1px solid var(--bdr);border-radius:18px;padding:24px;}
.bonus-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:14px;}
.bonus-item{display:flex;flex-direction:column;gap:5px;}
.bonus-num{font-family:var(--fh);font-weight:900;font-size:1.3rem;color:rgba(232,96,58,.3);}
.bonus-item h5{font-family:var(--fh);font-weight:700;font-size:.84rem;}
.bonus-item p{color:var(--muted);font-size:.78rem;line-height:1.5;}

/* Map */
.map-wrap{background:var(--card);border:1px solid var(--bdr);border-radius:14px;padding:20px;}
.map-points{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:10px;}
.map-pin{background:var(--bg3);border:1px solid var(--bdr);border-radius:8px;padding:6px 12px;font-size:.8rem;font-weight:600;}
.pin-start{border-color:var(--acc);color:var(--acc);}.pin-end{border-color:var(--teal);color:var(--teal);}
.map-arrow{color:var(--muted);font-size:.9rem;}
.map-note{text-align:center;color:var(--muted);font-size:.76rem;}

/* Sticky */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--card);border-top:1px solid var(--bdr);padding:12px 24px;transform:translateY(100%);transition:transform .3s;box-shadow:0 -8px 30px rgba(0,0,0,.4);}
.sticky-cta.visible{transform:translateY(0);}
.sticky-inner{display:flex;align-items:center;justify-content:space-between;max-width:600px;margin:0 auto;}
.sticky-info{display:flex;align-items:baseline;gap:6px;}
.sticky-label{color:var(--muted);font-size:.8rem;}
.sticky-price{font-family:var(--fh);font-weight:900;font-size:1.3rem;}
.sticky-per{color:var(--muted);font-size:.8rem;}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.75);backdrop-filter:blur(5px);align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;}
.modal-overlay.open{display:flex;}
.modal{background:var(--card);border:1px solid var(--bdr);border-radius:22px;width:100%;max-width:440px;padding:28px;position:relative;animation:slideUp .22s ease;max-height:90vh;overflow-y:auto;}
@keyframes slideUp{from{transform:translateY(20px);opacity:0;}to{transform:translateY(0);opacity:1;}}
.modal-close{position:absolute;top:14px;right:14px;background:none;border:1px solid var(--bdr);border-radius:7px;width:30px;height:30px;cursor:pointer;color:var(--muted);font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .18s;}
.modal-close:hover{border-color:var(--acc);color:var(--acc);}
.modal h3{font-family:var(--fh);font-weight:700;font-size:1.1rem;margin-bottom:18px;}
.modal-step{display:none;}.modal-step.active{display:block;}
.plan-choice-grid{display:flex;flex-direction:column;gap:10px;}
.plan-choice{display:flex;align-items:center;gap:14px;padding:14px;background:var(--bg3);border:1.5px solid var(--bdr);border-radius:14px;cursor:pointer;transition:all .18s;}
.plan-choice:hover,.plan-choice.selected{border-color:var(--acc);background:rgba(232,96,58,.08);}
.pc-emoji{font-size:1.8rem;}
.pc-info h4{font-family:var(--fh);font-weight:700;font-size:.92rem;margin-bottom:2px;}
.pc-info p{color:var(--muted);font-size:.78rem;}
.pc-check{margin-left:auto;color:var(--muted);font-size:1.1rem;font-weight:700;}
.plan-choice.selected .pc-check{color:var(--acc);}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.cal-header button{background:var(--bg3);border:1px solid var(--bdr);border-radius:6px;width:30px;height:30px;cursor:pointer;color:var(--txt);font-size:.9rem;display:flex;align-items:center;justify-content:center;}
.cal-header button:hover{border-color:var(--acc);}
.cal-header span{font-weight:600;font-size:.9rem;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:14px;}
.cal-day-name{text-align:center;font-size:.68rem;color:var(--muted);padding:4px;}
.cal-day{text-align:center;padding:7px 3px;border-radius:7px;font-size:.82rem;cursor:pointer;transition:all .14s;}
.cal-day.avail:hover{background:var(--bg3);}
.cal-day.sel{background:var(--acc)!important;color:#fff!important;}
.cal-day.unavail{color:var(--bdr);cursor:not-allowed;}
.guest-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg3);border-radius:10px;padding:12px 16px;margin-bottom:14px;}
.guest-ctrl{display:flex;align-items:center;gap:12px;}
.guest-ctrl button{background:var(--bg2);border:1px solid var(--bdr);border-radius:6px;width:28px;height:28px;cursor:pointer;color:var(--txt);font-size:1rem;display:flex;align-items:center;justify-content:center;}
.guest-ctrl button:hover{border-color:var(--acc);}
.guest-count{font-family:var(--fh);font-weight:700;font-size:1.15rem;min-width:20px;text-align:center;}
.confirm-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--bdr);font-size:.88rem;}
.confirm-row span:first-child{color:var(--muted);}
.confirm-total{display:flex;justify-content:space-between;padding:12px 0 0;font-family:var(--fh);font-weight:700;font-size:1.1rem;}
.stripe-note{background:rgba(0,194,168,.08);border:1px solid rgba(0,194,168,.25);border-radius:10px;padding:10px 14px;font-size:.78rem;color:var(--teal);margin-top:14px;line-height:1.5;}
.success-icon{font-size:3.5rem;text-align:center;margin-bottom:12px;}
.success-msg{text-align:center;color:var(--muted);font-size:.88rem;margin-bottom:18px;line-height:1.6;}

/* Footer */
#footer{background:var(--bg2);border-top:1px solid var(--bdr);padding:40px 0 0;}
.footer-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:30px;}
.footer-brand p{color:var(--muted);font-size:.84rem;margin-top:8px;}
.footer-links{display:flex;flex-direction:column;gap:10px;}
.footer-links a{color:var(--muted);font-size:.83rem;transition:color .15s;}
.footer-links a:hover{color:var(--acc);}
.footer-social{display:flex;gap:10px;}
.social-btn{background:var(--bg3);border:1px solid var(--bdr);border-radius:8px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .18s;}
.social-btn:hover{border-color:var(--acc);}
.footer-bottom{border-top:1px solid var(--bdr);padding:16px 24px;text-align:center;}
.footer-bottom p{color:var(--muted);font-size:.78rem;}

/* Notif */
#notif{position:fixed;bottom:90px;right:22px;background:var(--card);border:1px solid var(--bdr);border-radius:11px;padding:11px 18px;font-size:.85rem;z-index:9999;box-shadow:var(--sh);transform:translateY(80px);opacity:0;transition:all .3s ease;pointer-events:none;}
#notif.show{transform:translateY(0);opacity:1;}

/* Responsive */
@media(max-width:900px){.exp-grid,.guides-grid,.reviews-grid{grid-template-columns:1fr 1fr;}.contact-grid{grid-template-columns:1fr 1fr;}.bonus-grid{grid-template-columns:1fr 1fr;}.jdm-plan-cards{grid-template-columns:1fr;}}
@media(max-width:640px){#header nav{display:none;}.exp-grid,.guides-grid,.reviews-grid{grid-template-columns:1fr;}.inc-grid{grid-template-columns:1fr;}.hero-actions{flex-direction:column;}.btn-lg{width:100%;}.bonus-grid{grid-template-columns:1fr 1fr;}}

/* ═══════════════════════════════════════════════════════════
   AUTH — ヘッダーボタン
═══════════════════════════════════════════════════════════ */
#hd-auth {
  display: flex;
  align-items: center;
  gap: 8px;
}
.hd-login-btn {
  padding: 7px 16px;
  font-size: .85rem;
  border-radius: 8px;
}
.hd-register-btn {
  padding: 7px 16px;
  font-size: .85rem;
}

/* ユーザーメニュー */
.hd-user { position: relative; }
.hd-user-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 6px 12px;
  cursor: pointer;
  color: var(--fg);
  font-size: .88rem;
  transition: background .18s;
}
.hd-user-btn:hover { background: #252528; }
.hd-user-av {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--acc), #f0a500);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .85rem;
  font-weight: 700;
  color: #fff;
}
.hd-user-name { font-weight: 600; max-width: 90px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.hd-user-drop {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 200px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
  overflow: hidden;
  z-index: 200;
}
.hd-user-drop.open { display: block; }
.hd-user-info {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
}
.hd-user-email { font-size: .78rem; color: var(--muted); display: block; margin-bottom: 4px; }
.hd-role-badge {
  font-size: .72rem;
  background: var(--acc);
  color: #fff;
  padding: 2px 8px;
  border-radius: 20px;
  font-weight: 600;
}
.hd-drop-item {
  width: 100%;
  text-align: left;
  padding: 11px 16px;
  background: none;
  border: none;
  color: var(--fg);
  font-size: .88rem;
  cursor: pointer;
  transition: background .15s;
}
.hd-drop-item:hover { background: #252528; }

/* ═══════════════════════════════════════════════════════════
   AUTH MODAL
═══════════════════════════════════════════════════════════ */
.auth-modal {
  max-width: 420px;
  padding: 0;
  overflow-y: auto;     /* hiddenからautoに変更 */
  max-height: 90vh;     /* 画面の90%まで */
}

/* タブ */
.auth-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
}
.auth-tab-btn {
  flex: 1;
  padding: 14px;
  background: none;
  border: none;
  color: var(--muted);
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  transition: color .18s, border-bottom .18s;
  border-bottom: 2px solid transparent;
}
.auth-tab-btn.active {
  color: var(--acc);
  border-bottom-color: var(--acc);
}
.auth-tab-btn:hover:not(.active) { color: var(--fg); }

/* フォーム */
.auth-form {
  display: none;
  padding: 28px 28px 24px;
  flex-direction: column;
  gap: 0;
}
.auth-form.active { display: flex; }
.auth-logo {
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--acc);
  font-family: 'Outfit', sans-serif;
  text-align: center;
  margin-bottom: 4px;
}
.auth-subtitle {
  text-align: center;
  color: var(--muted);
  font-size: .88rem;
  margin-bottom: 22px;
}

/* エラー・サクセス */
.auth-error {
  background: rgba(220, 38, 38, .12);
  border: 1px solid rgba(220, 38, 38, .3);
  color: #fca5a5;
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .87rem;
  margin-bottom: 14px;
  line-height: 1.5;
}
.auth-success {
  background: rgba(22, 163, 74, .12);
  border: 1px solid rgba(22, 163, 74, .3);
  color: #86efac;
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .87rem;
  margin-bottom: 14px;
  line-height: 1.5;
}

/* フォームパーツ */
.form-group { margin-bottom: 20px; }
.form-label {
  display: block;
  font-size: .83rem;
  font-weight: 600;
  color: var(--fg);
  margin-bottom: 6px;
}
.form-required { color: var(--acc); margin-left: 2px; }
.form-hint {
  font-size: .75rem;
  color: var(--muted);
  font-weight: 400;
  margin-left: 6px;
}
.form-input {
  width: 100%;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 11px 14px;
  font-size: .92rem;
  color: var(--fg);
  font-family: 'Sora', sans-serif;
  transition: border-color .18s, box-shadow .18s;
  box-sizing: border-box;
}
.form-input:focus {
  outline: none;
  border-color: var(--acc);
  box-shadow: 0 0 0 3px rgba(232, 96, 58, .15);
}
.form-input::placeholder { color: var(--muted); }
.form-select { cursor: pointer; }

/* パスワードラッパー */
.pw-wrap { position: relative; }
.pw-wrap .form-input { padding-right: 44px; }
.pw-toggle {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1rem;
  padding: 0;
  color: var(--muted);
  line-height: 1;
}

/* 強度バー */
.pw-strength {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 7px;
}
.pw-strength-track {
  flex: 1;
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
}
.pw-strength-bar {
  height: 100%;
  width: 0;
  border-radius: 2px;
  transition: width .3s, background .3s;
}
.pw-strength-label { font-size: .75rem; font-weight: 600; min-width: 24px; }

/* 送信ボタン */
.auth-submit {
  width: 100%;
  padding: 13px;
  font-size: 1rem;
  margin-top: 6px;
  border-radius: 10px;
}
.auth-submit:disabled {
  opacity: .6;
  cursor: not-allowed;
}

/* フッターリンク */
.auth-switch {
  text-align: center;
  font-size: .83rem;
  color: var(--muted);
  margin-top: 14px;
  margin-bottom: 0;
}
.auth-terms {
  text-align: center;
  font-size: .76rem;
  color: var(--muted);
  margin-top: 10px;
  line-height: 1.6;
  margin-bottom: 0;
}
.auth-link {
  background: none;
  border: none;
  color: var(--acc);
  cursor: pointer;
  font-size: inherit;
  text-decoration: underline;
  padding: 0;
}
.auth-link:hover { opacity: .8; }

/* ═══════════════════════════════════════════════════════════
   レスポンシブ
═══════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
  #hd-auth { gap: 6px; }
  .hd-login-btn, .hd-register-btn { padding: 6px 10px; font-size: .8rem; }
  .hd-user-name { display: none; }
  .auth-form { padding: 20px 18px 18px; }
}

/* ═══════════════════════════════════════════════════════════
   BOOKING — Phase 3 追加スタイル
═══════════════════════════════════════════════════════════ */

/* ゲスト入力欄（未ログイン時） */
#guest-info-fields .form-group { margin-bottom: 12px; }
#guest-info-fields .form-input  { padding: 9px 12px; font-size: .9rem; }

/* メモ欄 */
textarea.form-input {
  min-height: 62px;
  padding: 9px 12px;
  font-size: .9rem;
  line-height: 1.5;
}

/* 予約番号ボックス */
.booking-ref-box {
  background: rgba(232, 96, 58, .1);
  border: 1px solid rgba(232, 96, 58, .3);
  border-radius: 10px;
  padding: 12px 18px;
  text-align: center;
  color: var(--muted);
  font-size: .9rem;
  margin: 12px 0;
}
.booking-ref-box strong {
  color: var(--acc);
  font-size: 1.2rem;
  letter-spacing: 1px;
  display: block;
  margin-top: 4px;
}

/* 決済ボタン無効時 */
#confirm-pay-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
}

/* ═══════════════════════════════════════════════════════════
   ROLE SELECT — 登録フォームのロール選択UI
═══════════════════════════════════════════════════════════ */
.role-select-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.role-option {
  display: block;
  cursor: pointer;
}
.role-option input[type="radio"] {
  display: none;
}
.role-option-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 14px 10px;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  background: var(--bg2);
  transition: all .18s;
  text-align: center;
}
.role-option input:checked + .role-option-body {
  border-color: var(--acc);
  background: rgba(232, 96, 58, .08);
  box-shadow: 0 0 0 3px rgba(232, 96, 58, .12);
}
.role-option-body:hover {
  border-color: var(--acc);
  background: rgba(232, 96, 58, .05);
}
.role-option-icon  { font-size: 1.6rem; }
.role-option-title { font-size: .88rem; font-weight: 700; color: var(--fg); }
.role-option-desc  { font-size: .75rem; color: var(--muted); }

/* ガイド申請の注意書き */
.guide-apply-notice {
  display: flex;
  gap: 10px;
  background: rgba(155, 93, 229, .1);
  border: 1px solid rgba(155, 93, 229, .3);
  border-radius: 9px;
  padding: 11px 14px;
  margin-bottom: 14px;
  align-items: flex-start;
  font-size: .85rem;
  color: #c4b5fd;
  line-height: 1.55;
}
.guide-apply-notice span { font-size: 1rem; flex-shrink: 0; margin-top: 1px; }
.guide-apply-notice p   { margin: 0; }

/* ═══════════════════════════════════════════════════════════
   「ガイドになる」ボタン & ガイド登録モーダル
═══════════════════════════════════════════════════════════ */

/* ヘッダーの「ガイドになる」ボタン — 新規登録と同じサイズ */
.hd-guide-btn {
  padding: 7px 16px;
  font-size: .85rem;
}

/* ガイド登録モーダル — ヘッダー部分 */
/* ═══════════════════════════════════════════════════════════
   GUIDE MODAL
═══════════════════════════════════════════════════════════ */

/* モーダル本体 — auth-modalクラスを外したので独立したスタイル */
.guide-modal {
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 0;        /* ヘッダーとbodyで個別に設定 */
}

/* ヘッダー部分 */
.guide-modal-hd {
  padding: 32px 32px 24px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(135deg, rgba(0,194,168,.06) 0%, rgba(232,96,58,.04) 100%);
}
.guide-modal-title {
  font-family: 'Outfit', sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--fg);
  margin: 6px 0 4px;
}
.guide-modal-sub {
  font-size: .85rem;
  color: var(--muted);
  line-height: 1.5;
  margin: 0;
}

/* フォーム本体エリア */
.guide-modal-body {
  padding: 24px 32px 28px;
}

/* セクション区切りラベル */
.guide-section-label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  margin: 0 0 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

/* 2カラムグリッド */
.guide-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* 送信ボタン */
.guide-submit-btn {
  width: 100%;
  padding: 14px;
  font-size: 1rem;
  border-radius: 10px;
  margin-top: 8px;
}
.guide-submit-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
}

/* フッターリンク */
.guide-modal-footer {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.guide-modal-footer p {
  text-align: center;
  font-size: .83rem;
  color: var(--muted);
  margin: 0;
}

/* ログイン済み時はガイドボタンを隠す */
body.logged-in .hd-guide-btn { display: none; }

@media (max-width: 640px) {
  .hd-guide-btn { display: none; }
  .guide-modal-hd  { padding: 24px 20px 18px; }
  .guide-modal-body { padding: 18px 20px 22px; }
  .guide-two-col { grid-template-columns: 1fr; gap: 0; }
}

/* ═══════════════════════════════════════════════════════════
   STRIPE PAYMENT STEP
═══════════════════════════════════════════════════════════ */
.stripe-element-wrap {
  min-height: 120px;
  margin: 14px 0;
}
.payment-amount-box {
  background: rgba(232,96,58,.08);
  border: 1px solid rgba(232,96,58,.25);
  border-radius: 10px;
  padding: 12px 16px;
  text-align: center;
  color: var(--muted);
  font-size: .9rem;
  margin-bottom: 4px;
}
.payment-amount-box strong {
  color: var(--acc);
  font-size: 1.4rem;
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  display: block;
  margin-top: 4px;
}
#stripe-pay-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
}

/* ═══════════════════════════════════════════════════════════
   PHASE 8 — パフォーマンス・アクセシビリティ最適化
═══════════════════════════════════════════════════════════ */

/* 画像遅延読み込みのフォールバック */
img[loading="lazy"] { opacity: 0; transition: opacity .3s; }
img[loading="lazy"].loaded { opacity: 1; }

/* フォーカスリング（アクセシビリティ） */
:focus-visible {
  outline: 2px solid var(--acc);
  outline-offset: 2px;
  border-radius: 4px;
}

/* スムーズスクロール */
html { scroll-behavior: smooth; }

/* テキスト選択色 */
::selection { background: rgba(232,96,58,.3); color: var(--fg); }

/* CLS防止: アニメーション要素の最小高さ */
.exp-grid      { min-height: 400px; }
.guides-grid   { min-height: 200px; }
.reviews-grid  { min-height: 200px; }

/* 言語切替スムーズ */
[data-i18n], [data-i18n-html] {
  transition: opacity .15s;
}

/* スキップナビゲーション（アクセシビリティ） */
.skip-nav {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--acc);
  color: #fff;
  padding: 8px 16px;
  z-index: 9999;
  border-radius: 0 0 8px 0;
  font-size: .9rem;
  transition: top .2s;
}
.skip-nav:focus { top: 0; }

/* プリント用スタイル */
@media print {
  .g-sidebar, .g-mobile-header, .a-sidebar, .sticky-cta,
  #hd-guide-btn, .modal-overlay { display: none !important; }
  body { background: #fff; color: #000; }
}

/* ═══════════════════════════════════════════════════════════
   HERO 2-COLUMN LAYOUT
═══════════════════════════════════════════════════════════ */

/* 2カラムラッパー */
.hero-two-col {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 40px;
}

/* 右カラム: 体験カードスタック */
.hero-exp-col {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.hero-exp-header { margin-bottom: 20px; }
.hero-exp-title {
  font-family: 'Outfit', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  margin: 8px 0 6px;
}
.hero-exp-sub { font-size: .88rem; color: var(--muted); }

/* 横向きコンパクトカード */
.hero-exp-stack { display: flex; flex-direction: column; gap: 12px; }

.hero-exp-card {
  display: flex;
  flex-direction: column;
  background: var(--card);
  border: 1px solid var(--bdr);
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer;
  transition: all .2s;
}
.hero-exp-card:hover {
  border-color: var(--acc);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
}

.hero-exp-thumb {
  display: none;
}
.hero-exp-thumb .exp-series-badge {
  display: none;
}

.hero-exp-body {
  flex: 1;
  padding: 16px 18px;
  min-width: 0;
}
.hero-exp-body .exp-tags { margin-bottom: 5px; }
.hero-exp-body .exp-tags .tag { font-size: .65rem; padding: 1px 6px; }
.hero-exp-name {
  font-size: .9rem;
  font-weight: 700;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hero-exp-body .exp-loc {
  font-size: .75rem;
  color: var(--muted);
  margin-bottom: 4px;
}
.hero-exp-desc {
  font-size: .78rem;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.hero-exp-body .exp-foot { margin-top: 0; }
.hero-exp-body .exp-foot .exp-price { font-size: .88rem; }
.hero-exp-body .exp-foot .exp-rating { font-size: .82rem; }

/* hero-cta_reviewsのi18nキー追加対応 */

/* レスポンシブ */
@media (max-width: 1024px) {
  .hero-two-col { grid-template-columns: 1fr; gap: 40px; padding: 0 24px; }
  .hero-exp-col { order: -1; }
  .hero-exp-stack { flex-direction: row; overflow-x: auto; padding-bottom: 8px; }
  .hero-exp-card { min-width: 260px; flex-direction: column; }
  .hero-exp-thumb { width: 100%; height: 80px; }
}
@media (max-width: 640px) {
  .hero-exp-stack { flex-direction: column; }
  .hero-exp-card { flex-direction: row; min-width: unset; }
  .hero-exp-thumb { width: 90px; height: auto; }
}

/* ═══════════════════════════════════════════════════════════
   GUIDE CARD — 予約ボタン追加
═══════════════════════════════════════════════════════════ */
.guide-book-btn {
  width: 100%;
  margin-top: 14px;
  padding: 10px;
  background: rgba(232,96,58,.1);
  border: 1.5px solid rgba(232,96,58,.3);
  border-radius: 9px;
  color: var(--acc);
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .18s;
  font-family: 'Sora', sans-serif;
}
.guide-book-btn:hover {
  background: var(--acc);
  border-color: var(--acc);
  color: #fff;
}

/* ═══ TOUGE TOUR ═══ */
.det-hero-touge {
  background: linear-gradient(135deg, #0a0a05, #1a1a00, #2a2000, #1a0a00);
  position: relative;
  overflow: hidden;
}
.det-hero-touge::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(255,200,0,.12) 0%, transparent 60%),
              radial-gradient(ellipse at 80% 30%, rgba(255,100,0,.08) 0%, transparent 50%);
}

/* ═══════════════════════════════════════════════════════════
   FULL-WIDTH HERO — 中央揃え + 4カラム横並び
═══════════════════════════════════════════════════════════ */

/* hero全体: 縦積み・中央揃え */
#hero {
  position: relative;
  min-height: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
  overflow: hidden;
}

/* 中央テキストエリア */
.hero-center {
  position: relative;
  z-index: 1;
  width: 100%;
  text-align: center;
  padding: 64px 24px 0;
}

/* ── Experience Your Own Japan. ── */
.hero-exp-eyebrow {
  font-family: 'Outfit', sans-serif;
  font-size: clamp(2rem, 4.5vw, 3.8rem);
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -.02em;
  margin-bottom: 22px;
  background: linear-gradient(135deg, #ffffff 0%, #f0efe8 40%, rgba(232,96,58,.9) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* stats 中央揃え */
.hero-stats-center {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-bottom: 52px;
  flex-wrap: wrap;
}
.hero-stats-center .stat    { display: flex; flex-direction: column; align-items: center; }
.hero-stats-center .stat-n  { font-family: 'Outfit', sans-serif; font-size: 1.6rem; font-weight: 900; color: var(--fg); line-height: 1; }
.hero-stats-center .stat-l  { font-size: .78rem; color: var(--muted); margin-top: 2px; }
.hero-stats-center .stat-div{ width: 1px; height: 32px; background: var(--bdr); }

/* ── 4カラム ツアーグリッド (横並び) ── */
.home-tour-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)); /* minmax(0,1fr)で等幅確定 */
  width: 100%;
  border-top: 1px solid var(--bdr);
}

.home-tour-col {
  border-right: 1px solid var(--bdr);
  cursor: pointer;
  min-width: 0;       /* グリッドの幅溢れを防ぐ */
  overflow: hidden;   /* カラム自体もはみ出し禁止 */
  transition: background .2s;
}
.home-tour-col:last-child { border-right: none; }
.home-tour-col:hover { background: rgba(255,255,255,.03); }

/* 写真エリア — 固定高さ・overflow:hidden徹底 */
.home-tour-img {
  height: 240px;
  position: relative;   /* スライダートラックのabsoluteの基準 */
  overflow: hidden;     /* 必須: はみ出し禁止 */
  border-bottom: 1px solid var(--bdr);
  background: #0a0a0c;
}
/* 絵文字（写真なしツアー用）は中央配置 */
.home-tour-img:not(.home-tour-slider) {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.home-img-asakusa  { background: linear-gradient(160deg,#2d1a0e 0%,#7a4520 50%,#3d1f08 100%); }
.home-img-shinjuku { background: linear-gradient(160deg,#1a0d2e 0%,#5a2880 50%,#2a1050 100%); }
.home-img-jdm      { background: #0a0a0c; }
.home-img-touge    { background: linear-gradient(160deg,#1a1500 0%,#3d3000 50%,#251800 100%); }

/* 絵文字（写真なしツアー） */
.home-tour-img-emoji {
  font-size: 3.2rem;
  line-height: 1;
  filter: drop-shadow(0 4px 16px rgba(0,0,0,.6));
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  display: block;
}
.home-tour-col:hover .home-tour-img-emoji { transform: scale(1.15); }

/* ジャンルラベル */
.home-tour-img-label {
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(0,0,0,.6);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  padding: 3px 10px;
  border-radius: 20px;
}

/* ホバーで出てくる予約ボタン */
.home-tour-hover-btn {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  opacity: 0;
  transition: all .22s ease;
  background: var(--acc);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 9px 20px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  font-family: 'Sora', sans-serif;
  box-shadow: 0 4px 16px rgba(232,96,58,.45);
  pointer-events: none;
}
.home-tour-col:hover .home-tour-hover-btn {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

/* テキスト情報エリア */
.home-tour-info {
  padding: 16px 18px 20px;
  text-align: left;
}
.home-tour-title {
  font-size: .9rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 4px;
  color: var(--fg);
}
.home-tour-loc {
  font-size: .75rem;
  color: var(--muted);
  margin-bottom: 8px;
}
.home-tour-desc {
  font-size: .78rem;
  color: var(--muted);
  line-height: 1.65;
  margin-bottom: 10px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── 4カラム ガイドグリッド ── */
.home-guide-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  width: 100%;
  border-top: 1px solid rgba(255,255,255,.08);
}
.home-guide-col {
  border-right: 1px solid rgba(255,255,255,.08);
  padding-bottom: 24px;
}
.home-guide-col:last-child { border-right: none; }

/* ガイド写真エリア */
.home-guide-img {
  height: 220px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
  transition: filter .2s;
}
.home-guide-img-1 { background: linear-gradient(160deg,#0d1a2e,#1c3555,#0a1520); }
.home-guide-img-2 { background: linear-gradient(160deg,#1a0d2e,#362050,#150a28); }
.home-guide-img-3 { background: linear-gradient(160deg,#071f1c,#103535,#051510); }
.home-guide-img-4 { background: linear-gradient(160deg,#1a1000,#352200,#120c00); }

.home-guide-img-emoji {
  font-size: 3rem;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.5));
  transition: transform .22s;
}
.home-guide-col:hover .home-guide-img-emoji { transform: scale(1.1); }
.home-guide-img-placeholder {
  color: rgba(255,255,255,.2);
  font-size: .75rem;
  font-weight: 600;
}

/* ガイド情報 */
.home-guide-info { padding: 16px 18px 0; }
.guide-langs-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 5px 0 7px;
}

/* ガイド予約ボタン */
.guide-book-btn {
  width: 100%;
  margin-top: 14px;
  padding: 10px;
  background: rgba(232,96,58,.1);
  border: 1.5px solid rgba(232,96,58,.3);
  border-radius: 9px;
  color: var(--acc);
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .18s;
  font-family: 'Sora', sans-serif;
}
.guide-book-btn:hover {
  background: var(--acc);
  border-color: var(--acc);
  color: #fff;
}

/* ── レスポンシブ ── */
@media (max-width: 960px) {
  .home-tour-grid  { grid-template-columns: 1fr 1fr; }
  .home-guide-grid { grid-template-columns: 1fr 1fr; }
  .home-tour-col, .home-guide-col { border-bottom: 1px solid var(--bdr); }
  .home-tour-col:nth-child(even), .home-guide-col:nth-child(even) { border-right: none; }
}
@media (max-width: 520px) {
  .home-tour-grid, .home-guide-grid { grid-template-columns: 1fr; }
  .home-tour-col, .home-guide-col   { border-right: none; }
}

/* ═══════════════════════════════════════════════════════════
   PHOTO SLIDERS（ツアー写真スライダー）
═══════════════════════════════════════════════════════════ */

/* ガイド写真 */
.home-guide-img .guide-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform .4s ease;
}
.home-guide-col:hover .guide-photo { transform: scale(1.04); }

/* ツアースライダー */
.home-tour-slider {
  position: relative;
  overflow: hidden;
}
.slider-track {
  position: absolute;
  inset: 0;
  display: flex;
  transition: transform .45s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.slider-img {
  min-width: 100%;
  width: 100%;
  height: 100%;
  flex-shrink: 0;
  display: block;
  /* 通常: 縮小して全体が見えるように */
  object-fit: contain;
  object-position: center center;
  background: #0a0a0c;
  transform: scale(0.8);
  transform-origin: center center;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
}

/* ホバー時: 拡大してカバー表示 */
.home-tour-col:hover .slider-img {
  transform: scale(1.05);
  object-fit: cover;
}

/* 矢印ボタン */
.slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .2s;
  z-index: 10;
}
.home-tour-col:hover .slider-arrow { opacity: 1; }
.slider-prev { left: 8px; }
.slider-next { right: 8px; }
.slider-arrow:hover { background: rgba(232,96,58,.8); border-color: transparent; }

/* ドットインジケーター */
.slider-dots {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 5px;
  z-index: 10;
}
.s-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  cursor: pointer;
  transition: all .2s;
}
.s-dot.active {
  background: #fff;
  width: 16px;
  border-radius: 3px;
}

/* ═══════════════════════════════════════════════════════════
   DET-HERO フォトスライダー（詳細ページ背景）
═══════════════════════════════════════════════════════════ */
.det-hero-slider-wrap {
  position: relative;
  overflow: hidden;
}

/* スライダーのトラック */
.det-slider-track {
  position: absolute;
  inset: 0;
  display: flex;
  transition: transform .6s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.det-slide-img {
  min-width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  flex-shrink: 0;
}

/* 詳細ページの矢印 */
.det-slide-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 1.3rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: all .2s;
}
.det-slide-prev { left: 16px; }
.det-slide-next { right: 16px; }
.det-slide-arrow:hover { background: rgba(232,96,58,.8); border-color: transparent; }

/* ドット */
.det-slide-dots {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 10;
}

/* ═══════════════════════════════════════════════════════════
   GUIDE GRID — 行揃えレイアウト
═══════════════════════════════════════════════════════════ */
.home-guide-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  width: 100%;
  border-top: 1px solid rgba(255,255,255,.08);
}

/* 写真エリア（1行目） */
.home-guide-img {
  height: 280px;
  overflow: hidden;
  border-right: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.home-guide-img:last-of-type { border-right: none; }
.home-guide-img-1 { background: linear-gradient(160deg,#0d1a2e,#1c3555); }
.home-guide-img-2 { background: linear-gradient(160deg,#1a0d2e,#362050); }
.home-guide-img-3 { background: linear-gradient(160deg,#071f1c,#103535); }
.home-guide-img-4 { background: linear-gradient(160deg,#1a1000,#352200); }

.guide-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform .4s ease;
}
.home-guide-img:hover .guide-photo { transform: scale(1.04); }

/* 各行のセル共通 */
.hgg-cell {
  padding: 10px 18px;
  border-right: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.06);
  display: flex;
  align-items: flex-start;
}
/* 4列目は右ボーダーなし */
.hgg-cell:nth-child(4n) { border-right: none; }

/* 名前行 */
.hgg-name {
  font-family: 'Outfit', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--fg);
  padding-top: 14px;
  padding-bottom: 8px;
  align-items: center;
}

/* 言語タグ行 */
.hgg-langs {
  flex-wrap: wrap;
  gap: 4px;
  padding-top: 6px;
  padding-bottom: 8px;
  align-items: center;
}

/* 役職行 */
.hgg-role {
  font-size: .8rem;
  font-weight: 600;
  color: var(--teal);
  padding-top: 6px;
  padding-bottom: 8px;
  align-items: center;
}

/* bio行 */
.hgg-bio {
  font-size: .82rem;
  color: var(--muted);
  line-height: 1.65;
  padding-top: 8px;
  padding-bottom: 12px;
  align-items: flex-start;
}

/* 予約ボタン行 */
.hgg-btn {
  padding: 12px 18px 20px;
  align-items: center;
  border-bottom: none;
}
.hgg-btn .guide-book-btn { width: 100%; }

/* レスポンシブ */
@media (max-width: 900px) {
  .home-guide-grid { grid-template-columns: 1fr 1fr; }
  .hgg-cell:nth-child(4n)   { border-right: 1px solid rgba(255,255,255,.08); }
  .hgg-cell:nth-child(2n)   { border-right: none; }
  .home-guide-img:last-of-type { border-right: 1px solid rgba(255,255,255,.08); }
}
@media (max-width: 520px) {
  .home-guide-grid { grid-template-columns: 1fr; }
  .hgg-cell, .home-guide-img { border-right: none; }
}

/* ═══════════════════════════════════════════════════════════
   TOUR GRID — 行揃えレイアウト
═══════════════════════════════════════════════════════════ */

/* グリッドを行揃えに */
.home-tour-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  width: 100%;
  border-top: 1px solid var(--bdr);
}

/* 写真エリアラッパー */
.htt-img-wrap {
  border-right: 1px solid var(--bdr);
  border-bottom: 1px solid var(--bdr);
  overflow: hidden;
}
.htt-img-wrap:last-of-type,
.htt-img-wrap:nth-child(4) { border-right: none; }

/* スライダーは写真エリア全体 */
.htt-img {
  height: 240px;
  position: relative;
  overflow: hidden;
  display: block;
  cursor: pointer;
}
.htt-img .slider-track {
  position: absolute;
  inset: 0;
  display: flex;
  transition: transform .45s cubic-bezier(.4,0,.2,1);
}
.htt-img .slider-img {
  min-width: 100%;
  width: 100%;
  height: 100%;
  flex-shrink: 0;
  object-fit: contain;
  object-position: center;
  background: #0a0a0c;
  transform: scale(0.8);
  transform-origin: center;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.htt-img:hover .slider-img {
  transform: scale(1.05);
  object-fit: cover;
}

/* テキストセル共通 */
.htt-cell {
  padding: 10px 18px;
  border-right: 1px solid var(--bdr);
  border-bottom: 1px solid rgba(255,255,255,.04);
  display: flex;
  align-items: flex-start;
}
.htt-cell:nth-child(4n) { border-right: none; }

/* タグ行 */
.htt-tags {
  flex-wrap: wrap;
  gap: 4px;
  padding-top: 12px;
  padding-bottom: 8px;
  align-items: center;
}

/* タイトル行 */
.htt-title {
  font-family: 'Outfit', sans-serif;
  font-size: .92rem;
  font-weight: 700;
  color: var(--fg);
  line-height: 1.4;
  cursor: pointer;
  padding-top: 8px;
  align-items: flex-start;
  transition: color .18s;
}
.htt-title:hover { color: var(--acc); }

/* 場所行 */
.htt-loc {
  font-size: .75rem;
  color: var(--muted);
  padding-top: 6px;
  padding-bottom: 6px;
  align-items: center;
}

/* 説明行 */
.htt-desc {
  font-size: .8rem;
  color: var(--muted);
  line-height: 1.65;
  padding-top: 6px;
  padding-bottom: 10px;
  align-items: flex-start;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* 評価・価格行 */
.htt-foot {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  padding-top: 10px;
  padding-bottom: 16px;
}

/* レスポンシブ */
@media (max-width: 900px) {
  .home-tour-grid { grid-template-columns: 1fr 1fr; }
  .htt-img-wrap:nth-child(2) { border-right: none; }
  .htt-img-wrap:nth-child(4) { border-right: none; }
  .htt-cell:nth-child(4n)    { border-right: 1px solid var(--bdr); }
  .htt-cell:nth-child(2n)    { border-right: none; }
}
@media (max-width: 520px) {
  .home-tour-grid { grid-template-columns: 1fr; }
  .htt-img-wrap, .htt-cell { border-right: none; }
}

/* ── フッター 運営会社コラム ── */
.footer-company {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.footer-company-title {
  font-size: .82rem;
  font-weight: 700;
  color: var(--fg);
  margin-bottom: 2px;
}
.footer-company p {
  color: var(--muted);
  font-size: .8rem;
  line-height: 1.6;
}

/* sticky-cta 非表示（削除済みだが念のため） */
.sticky-cta { display: none !important; }
