/* 让右侧圆点绝对定位生效 */
.railway-td {
  position: relative;
}
/* 右侧铁道线和圆点 for 指定区域 */
.railway-right {
  border-right: 2px solid #8fd16a !important;
  border-top-right-radius: 6px !important;
  position: relative;
}
.railway-dots-right {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	height: 48px;
	/* 或你需要的高度 */
	justify-content: space-between;
}
/* Consolidated dark theme for te/* 	----------------------------- 
	Header / Topbar
	----------------------------- */
/* index-specific fixed topbar */
.index{background:#0b0b0b;color:#f3f3f3;--topbar-height:78px}
.index .header{position:fixed;top:0;left:20px;right:20px;z-index:1100;height:var(--topbar-height);gap:12px;align-items:center}
.index .header .logo{height:var(--topbar-height);display:flex;align-items:center}
.index .header .logo img{height:40px;width:auto;display:block}
.index .nav a{color:#e6e6e6;height:calc(var(--topbar-height)-16px);display:inline-flex;align-items:center}
.index .site-wrapper{padding-top:calc(var(--topbar-height)+24px)}
html,body{height:100%;}
body{font-family: "Noto Sans JP", "メイリオ", Meiryo, Arial, sans-serif;margin:0;background:#000;color:#e9eef3;font-size:inherit}

/*
  Cleaned and ordered stylesheet for index.php
  - Removed duplicates and fixed syntax
  - Organized by page region: variables, base, header/topbar, hero, layout, filters, list/cards, tokyo-area, sidebar, utilities, footer, responsive
  - Added a standard `line-clamp` alongside `-webkit-line-clamp` for broader compatibility
*/

:root{
  --max-w:1200px;
  --accent:#d94b6a;
  --muted:#9aa0a6;
}

/* -----------------------------
	Base / Typography
	----------------------------- */
html{font-size:14px;height:100%}
body{height:100%;margin:0;background:#000;color:#e9eef3;font-family:"Noto Sans JP","メイリオ",Meiryo,Arial,sans-serif}
.container{max-width:var(--max-w);margin:0 auto}

/* Base text sizing */
body, p, a, li, span, input, label, .card .info p{font-size:14px}
h1{font-size:20px;margin:0 0 8px}
h2{font-size:18px;margin:0 0 10px}
h3{font-size:16px;margin:0 0 6px}
h4{font-size:14px;margin:0 0 6px}

/* -----------------------------
	Header / Topbar
	----------------------------- */
.header{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.header .logo{display:flex;align-items:center;gap:12px}
.header .logo img{height:70px;width:auto;display:block}
/* index-specific fixed topbar */
.index{background:#0b0b0b;color:#f3f3f3;--topbar-height:78px}
.index .header{position:fixed;top:0;left:20px;right:20px;z-index:1100;height:var(--topbar-height);gap:12px;align-items:center}
.index .header .logo{height:var(--topbar-height);display:flex;align-items:center}
.index .nav a{color:#e6e6e6;height:calc(var(--topbar-height)-16px);display:inline-flex;align-items:center}
.index .site-wrapper{padding-top:calc(var(--topbar-height)+24px)}

/* -----------------------------
	Search Section (Homepage)
	----------------------------- */
.search-section {
    background: rgba(255, 255, 255, 0.05);
    border-radius: 15px;
    padding: 25px 20px;
    margin-bottom: 25px;
    text-align: center;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.search-section h2 {
    color: #fff;
    font-size: 1.8em;
    margin-bottom: 20px;
    font-weight: 300;
}

/* Collapsible search section styles */
.search-section h2{display:flex;align-items:center;justify-content:center;gap:10px}
.search-toggle{background:transparent;border:0;color:#fff;font-size:18px;line-height:1;cursor:pointer;padding:4px 6px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center}
.search-toggle:focus{outline:2px solid rgba(74,144,226,0.9)}
.search-content{max-height:1000px;overflow:hidden;transition:max-height 260ms ease}
.search-content[aria-hidden="true"]{max-height:0}
.search-section.compact{padding:12px 10px;margin-bottom:12px;border-radius:10px}
.search-section.compact h2{font-size:1.1em;margin-bottom:8px}
.search-section.compact .search-form{max-width:100%;margin:0}
.search-section.compact .search-input-wrapper{padding:8px}
.search-section.compact .search-input{padding:10px 12px;font-size:14px}

.home-ranking-jump{
  margin:0 0 12px;
}

.sidebar .home-ranking-jump{
  margin:0 0 10px;
}

.home-ranking-jump-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:42px;
  padding:0.55rem 0.8rem;
  border:1px solid #8c309f;
  border-radius:10px;
  color:#fff;
  text-decoration:none;
  font-size:0.95rem;
  font-weight:600;
  background:linear-gradient(180deg, #2f3947 0%, #4800cc 100%);
}

.home-ranking-jump-link:hover{
  background:linear-gradient(180deg, #364456 0%, #49627c 100%);
}

.search-form {
    max-width: 500px;
    margin: 0 auto 20px;
}

.search-input-wrapper {
    position: relative;
    display: flex; 
    border-radius: 30px;
    overflow: hidden;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
    transition: box-shadow 0.3s ease;
}

.search-input-wrapper:focus-within {
    box-shadow: 0 12px 35px rgba(0, 123, 255, 0.4);
}

.search-input {
  flex: 1;
  padding: 16px 20px;
  padding-right: 3rem; /* room for absolute circular button */
  border: none;
  outline: none;
  font-size: 1em;
  background: transparent;
  color: #333;
}

.search-input::placeholder {
    color: #999;
}

.search-button { 
  right: 0.5rem;
  background: #007bff;
  color: white;
  border: none;
  border-radius: 50%;
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.search-button:hover {
  background: #0056b3;
}

.search-button .search-icon {
    font-size: 1.1em;
}

.search-examples {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.search-examples-label {
    color: #aaa;
    font-size: 0.9em;
    margin-right: 5px;
}

.example-tag {
    padding: 6px 12px;
    background: rgba(0, 123, 255, 0.2);
    color: #fff;
    text-decoration: none;
    border-radius: 15px;
    border: 1px solid rgba(0, 123, 255, 0.4);
    transition: all 0.3s ease;
    font-size: 0.85em;
}

.example-tag:hover {
    background: #007bff;
    border-color: #007bff;
    transform: translateY(-1px);
}

/* Hero section with dynamic grid based on ad count */
.hero{
  display: flex;
  gap: 2px;
  align-items: stretch;
 margin: 1px 2px 13px 5px;
}

.hero .title{font-size:22px;margin:0;color:#fff}
.hero .subtitle{color:var(--muted);margin-top:6px}
.hero-text h1{margin:0 0 8px 0;font-size:15px}
.hero-text p{margin:0;color:#555}

/* Advertisement slots */
.ad-slot{
  flex: 1;
  display:block;
  overflow:hidden;
  margin:0;
  padding:0;
  min-width: 0;
}
.ad-slot a{display:block;width:100%;height:100%}
.ad-slot img{
  display:block;
  width:100%; 
  object-fit:contain;
  object-position:center;
  background:#1a1a1a;
  border-radius:6px;
  margin:0;
  padding:0;
}

/* -----------------------------
	Layout: main + sidebar
	----------------------------- */
.layout{display:grid;grid-template-columns:1fr 360px;gap:10px}
.main-left{grid-column:1/2}
.sidebar{grid-column:2/3}

/* When single-column on small screens we let DOM flow determine order */

/* -----------------------------
	Filters / area panel
	----------------------------- */
.filters{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.filter{background:#6a6a6d;padding:8px 10px;border-radius:10px;border:1px solid #1b1b1b;color:#e9eef3}

/* Muted text utility class */
.muted{color:var(--muted)}
.filter-area-panel{background:#171717;padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,0.03);margin-bottom:12px}
.filter-area-panel h3{margin:0 0 6px;font-size:16px;color:#fff}
.filter-area-panel .fa-description{color:var(--muted);font-size:13px;margin-bottom:8px}
.filter-area-panel .tags{display:flex;flex-wrap:wrap;gap:8px}
.filter-area-panel .tags .tag{background:#1c1c1c;padding:6px 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.02);color:#dfdede;text-decoration:none}

/* -----------------------------
	Cards / List
	----------------------------- */
.list{display:grid;row-gap:6px;column-gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:start}
.card{display:grid;grid-template-columns:96px 1fr;grid-template-rows:auto 1fr;gap:6px 8px;background:#2b2b2b;padding:6px;border-radius:8px;border:1px solid #191919;box-sizing:border-box;min-height:76px}
.card img{width:96px;height:96px;object-fit:cover;border-radius:8px;grid-column:1/2;grid-row:1/3}
.card .info{display:grid;grid-template-rows:auto auto auto;gap:4px;min-width:0;overflow:hidden;padding:0;grid-column:2/3;grid-row:1/3}
.card .info .rank-badge{display:flex;align-items:center;justify-content:space-between;min-height:18px;font-size:13px;line-height:1;gap:8px;width:100%}
.card .info .rank-medal{display:inline-flex;align-items:center;justify-content:center;font-size:14px}
.card .info .rank-number{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 20px;
  padding: 0 1px;
  letter-spacing: 0.2px;
  line-height: 1;
}
.card .info .rank-number-gold{color:#ffd56a;background:#2b2412;border-color:#6d571f;font-size:1.06rem}
.card .info .rank-number-silver{color:#d9e1e8;background:#23282d;border-color:#5f6872;font-size:1.06rem}
.card .info .rank-number-bronze{color:#d9a673;background:#2a2118;border-color:#6b4f36;font-size:1.06rem}
.card .info .rank-number-default{color:#cddc39;background:#242a30;border-color:#5e6770;font-size:1rem;font-weight:700}
.card .info .rank-badge .score-value{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-size:0.9rem;font-weight:700;color:#ffd56a;white-space:nowrap;padding:3px 1px;border-radius:999px;background:#1a1a1a;border:1px solid #4a4a4a;box-shadow:inset 0 1px 0 rgba(255,255,255,0.05)}
.card .info .rank-badge .score-value .score-label{font-size:0.68rem;letter-spacing:0.8px;color:#cfd6db;font-weight:700}
.card .info h3{margin:4px 0 2px;line-height:1.2;font-size:14px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#fff}
.card .info h3 a,.card .info h3 a:visited{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#fff;text-decoration:none}
.card .info h3 a:hover,.card .info h3 a:focus{text-decoration:underline}
.card .info p{margin:0;color:#cfd6db;font-size:13px;line-height:1.2;max-height:2.4em;overflow:hidden;text-overflow:ellipsis}
.card .meta{display:flex;align-items:center;gap:8px;padding-top:4px;border-top:1px solid rgba(255,255,255,0.015);justify-content:flex-start}
.card .meta .price{font-weight:700;color:#cac4c6bf}
.card .meta a{display:inline-block;margin-top:8px;background:var(--accent);color:#fff;padding:8px 10px;border-radius:8px;text-decoration:none}

/* -----------------------------
	Tokyo area grid / panels
	----------------------------- */
.tokyo-area{background:linear-gradient(180deg,rgba(255,255,255,0.01),rgba(0,0,0,0.06));padding:10px;border-radius:12px;border:1px solid rgba(255,255,255,0.43);box-shadow:inset 0 1px 0 rgba(255,255,255,0.02);margin-bottom:12px;margin-top:10px;box-sizing:border-box;width:100%;min-width:0;position:relative}
.tokyo-area .grid{display:block;padding:6px;overflow-x: scroll;}
.tokyo-area .map-table{border-collapse:collapse;margin:0;width:1100px;table-layout:fixed}
.tokyo-area .map-table td{height:71px;border:1px solid #fd8f8f52;text-align:center;vertical-align:middle;padding:6px;box-sizing:border-box;word-break:break-word;min-width:48px}
.tokyo-area .map-table a{display:flex;align-items:center;justify-content:center;width:100%;height:100%;text-decoration:none;color:#dfdede;border-radius:10px;padding:6px;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(0,0,0,0.12));border:1px solid rgba(255,255,255,0.03);box-shadow:inset 0 1px 0 rgba(255,255,255,0.03),inset 0 -6px 12px rgba(0,0,0,0.6),0 2px 6px rgba(0,0,0,0.6);transition:transform .12s ease,box-shadow .18s ease,background .18s ease;overflow:hidden}
.tokyo-area .map-table a:hover{transform:translateY(-3px);background:linear-gradient(180deg,rgba(255,255,255,0.04),rgba(0,0,0,0.08));box-shadow:0 6px 18px rgba(0,0,0,0.45);color:#fff}
.tokyo-area .area-name{line-height:1.15;padding:2px 1px}
.tokyo-area .panels{display:none;gap:10px}
.tokyo-area .panel{flex:0 0 100%;padding:8px;box-sizing:border-box}
.tokyo-area .panels-scroll{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.tokyo-area .panel .panel-grid{display:grid;grid-template-columns:1fr;gap:8px}
.tokyo-area .panel .tile{background:transparent;min-height:56px;display:flex;align-items:center;justify-content:flex-start;border-radius:12px/6px;transition:background .18s ease;padding:8px;box-sizing:border-box}
.tokyo-area .panel .tile a{display:block;width:100%;height:100%;text-align:left;padding:6px;text-decoration:none;color:#dfdede}
.tokyo-area .panel .tile a:hover{background:#8f8b8b}
.tokyo-area .hint{color:#666;font-size:13px;margin-bottom:10px}
.tokyo-area-simple{background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(0,0,0,0.28));border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:14px;box-shadow:0 10px 22px rgba(0,0,0,0.22)}
.prefecture-title{margin:0 0 12px 0;color:#e8f3ff;font-size:16px;display:flex;align-items:center;gap:8px;font-weight:700;border-bottom:2px solid rgba(142,197,255,0.58);}
.prefecture-title .icon{color:#8ec5ff;font-size:18px;line-height:1}
.tokyo-area-list{list-style:none;margin:0;padding:2px;display:flex;flex-wrap:wrap;gap:8px 10px}
.tokyo-area-list li{display:flex}
.tokyo-area-list li a{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:8px;background:#1c1c1c;border:1px solid #433f3f;color:#f5f5f5;font-weight:600;letter-spacing:0.1px;text-decoration:none;line-height:1.1;transition:all .15s ease}
.tokyo-area-list li a:hover{color:#ffb347;border-color:#ff9a2f;background:rgba(255,154,47,0.08);box-shadow:0 4px 12px rgba(0,0,0,0.25)}
.tokyo-area-list .arrow{display:none}
.tokyo-area-empty{margin:0;color:#ddd;font-size:14px}

/* Scroll hint overlay (simplified - no edge indicators) */
.tokyo-scroll-hint{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .28s ease}
.tokyo-area.has-overflow .tokyo-scroll-hint{opacity:1}

/* -----------------------------
  About section (esthe intro)
  ----------------------------- */
.about-esthe{background:#0f1117;color:#f5f5f5;padding:16px;border-radius:8px;margin:24px 0 12px;line-height:1.6}
.about-esthe h2{margin:0 0 12px;font-size:18px;color:#ffd166}
.about-esthe p{margin:0 0 12px;font-size:14px}
.about-esthe ul{margin:0;padding-left:18px;display:grid;gap:6px;font-size:14px}
.about-esthe a{color:#8ec5ff;text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1.5px}
.about-esthe a:hover,.about-esthe a:focus{color:#b7d9ff;text-decoration:underline}
.about-esthe__links{margin-top:12px}
.pc_disp{display:block}
.sp_disp{display:none}
@media (max-width: 768px){
  .pc_disp{display:none}
  .sp_disp{display:block}
  .about-esthe{margin:16px 0}
}
 
/* -----------------------------
	Sidebar / boxes
	----------------------------- */
.sidebar .box{background:#0e0e10;padding:12px;border-radius:10px;margin-bottom:12px;border:1px solid #191919}
.map{height:300px;background:linear-gradient(135deg,#071015,#0d1113);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#c5ced6;padding:8px;box-sizing:border-box;width: 334px;}
.map img{max-width:100%;height:auto;border-radius:8px;display:block;object-fit:cover}
.toplist{display:flex;flex-direction:column;gap:8px}
.toplist .item{background:#0e0e10;padding:10px;border-radius:8px;display:flex;gap:10px;align-items:center;border:1px solid #191919}
.toplist .item img{width:64px;height:44px;object-fit:cover;border-radius:6px}
.toplist .station-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-top:8px}
.toplist .station-item{background:#0e0e10;border-radius:8px;border:1px solid #191919;transition:all 0.2s ease;overflow:hidden}
.toplist .station-item a{color:#dfe6e9;text-decoration:none;display:flex;flex-direction:column;align-items:center;padding:8px;gap:6px}
.toplist .station-item img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:6px}
.toplist .station-item .station-name{font-size:13px;font-weight:500;text-align:center}
.toplist .station-item:hover{background:#1a1a1c;border-color:#ff8a00;transform:translateY(-3px);box-shadow:0 4px 12px rgba(255,138,0,0.2)}
.toplist .station-item:hover a{color:#ff8a00}

/* 热门车站TOP6按钮样式 */
.hot-stations{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}
.hot-station-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 8px;background:linear-gradient(135deg,#ff8a00 0%,#ff6b00 100%);border-radius:8px;text-decoration:none;transition:all 0.3s ease;border:1px solid rgba(255,138,0,0.3);min-height:60px}
.hot-station-btn .station-name{color:#fff;font-size:13px;font-weight:600;margin-bottom:3px}
.hot-station-btn .shop-count{color:rgba(255,255,255,0.9);font-size:11px;font-weight:400}
.hot-station-btn:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 20px rgba(255,138,0,0.4);background:linear-gradient(135deg,#ff9500 0%,#ff7700 100%)}
.hot-station-btn:active{transform:translateY(-2px) scale(1.02)}

.box.regions{background:linear-gradient(180deg,rgba(255,255,255,0.01),rgba(0,0,0,0.06));padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,0.03)}
.box.regions .regions-title{
  margin: 0 0 10px 0;
  padding-bottom: 8px;
}

.sidebar .sidebar-section-title{
  margin: 0 0 10px 0;
  padding-bottom: 8px;
  color: #e8f3ff;
  font-size: 16px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 2px solid rgba(142,197,255,0.58);
}

.sidebar .sidebar-section-title .icon{
  color: #8ec5ff;
  font-size: 18px;
  line-height: 1;
}

.regions-grid{ grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:6px;align-items:center}
.regions-grid .tag{display:inline-block;background:#1c1c1c;border-radius:2px;padding:4px 9px;border:1px solid rgb(67 63 63);color:#dfe6e9;text-decoration:none}

/* 新着店舗 & 高評価店舗 */
.box .shop-item{background:#0e0e10;border-radius:8px;border:1px solid #191919;margin-bottom:8px;transition:all 0.2s ease;overflow:hidden}
.box .shop-item:last-child{margin-bottom:0}
.box .shop-item a{display:flex;gap:10px;padding:8px;color:#dfe6e9;text-decoration:none;align-items:center}
.box .shop-item img{width:64px;height:64px;object-fit:cover;border-radius:6px;flex-shrink:0}
.box .shop-item .shop-info{flex:1;min-width:0}
.box .shop-item .shop-name{
  font-size:13px;
  font-weight:500;
  margin-bottom:4px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  line-clamp:2;
  line-height:1.3;
}
.box .shop-item .shop-meta{display:flex;gap:8px;font-size:11px;color:#999;flex-wrap:wrap}
.box .shop-item .shop-meta .station{color:#999}
.box .shop-item .shop-meta .date{color:#ff8a00}
.box .shop-item .shop-meta .rating{color:#ffa500}
.box .shop-item:hover{background:#1a1a1c;border-color:#ff8a00;transform:translateX(3px)}
.box .shop-item:hover .shop-name{color:#ff8a00}

/* Sidebar about box styling */
.about_box{
  background: #1d1e21;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(30,40,90,0.08);
  padding: 18px 16px 10px 16px;
  margin-bottom: 18px;
  color: #fff;
  font-size: 1.08em;
  line-height: 1.7;
}
.about_box dl {
  margin: 0 0 8px 0;
  padding: 0; 
  flex-wrap: wrap;
  align-items: flex-start;
}
.about_box dt {
  min-width: 90px; 
  color: #e1c389;
  margin-right: 8px;
  font-size: 1em;
  margin-top: 2px;
}
.about_box dd {
  margin: 0 0 0 0;
  padding: 0;
  flex: 1 1 0%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.about_box a { 
  background: #3f424bc4;
  border-radius: 6px;
  padding: 2px 5px;
  margin: 2px 2px 2px 0;
  text-decoration: none;
  transition: background 0.18s, color 0.18s;
  font-weight: 500; 
  box-shadow: 0 1px 2px rgba(30,40,90,0.04);
}
.about_box a:hover, .about_box a:focus {
  background: #eebf63;
  color: #232946;
}
.about_box .count {
  color: #eebf63;
  font-size: 0.92em;
  margin-left: 2px;
}
.about_box span {
  color: #1d1e21;
}


/* Utilities */
.tag{display:inline-block;background:#111;color:#e9eef3;padding:6px 8px;border-radius:999px;font-size:16px;margin-right:6px;margin-bottom: 4px; text-decoration:none}

/* -----------------------------
	Footer
	----------------------------- */
.footer{padding:28px 0;text-align:center;color:#72777b}
.footer .footer-links{margin-bottom:8px;display:flex;flex-wrap:wrap;justify-content:center;gap:8px 10px}
.footer .footer-links a{color:#aeb6ba;text-decoration:none;font-size:13px;line-height:1.2;min-height:28px;padding:6px 8px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center}
.footer .footer-links a:hover,.footer .footer-links a:focus{color:#fff;background:rgba(255,255,255,0.03);outline:2px solid rgba(217,75,106,0.12);outline-offset:2px}
.footer .footer-links a + a::before{content:none}

/* -----------------------------
	Responsive rules
	----------------------------- */
@media (max-width: 1200px){
  /* Switch to single-column layout; main content stacked above sidebar */
  .layout{grid-template-columns:1fr}
  .main-left{order:1;grid-column:auto;grid-row:auto;max-width:830px;margin:0 auto}
   
  .tokyo-area{grid-column:auto;grid-row:auto}
  /* Sidebar: center and wrap; make ranking jump occupy full row */
  .sidebar{order:2;grid-column:auto;grid-row:auto;margin:0 auto;padding-top:8px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start;justify-content:center}
  .sidebar > *{box-sizing:border-box}
  .sidebar > .home-ranking-jump{flex:1 1 100%;max-width:100%;margin-bottom:0}
  .sidebar > .box{flex:1 1 calc(50% - 12px)}

}
/* On very small screens stack sidebar children vertically */
@media (max-width:800px){
  /* Hero: 2 columns layout */
  .hero {
    flex-wrap: wrap;
    gap: 2px;
  }
  
  .ad-slot {
    flex: 1 1 calc(50% - 1px);
    min-width: calc(50% - 1px);
  }
  
  .sidebar{display:block;width:100%;max-width:100%;margin:0 auto;padding:0}
  .sidebar > .home-ranking-jump{width:100%;max-width:100%;margin:0 0 12px}
  .sidebar > .box{width:100%;max-width:100%;flex:none;margin-bottom:12px}
  .sidebar .box.regions{width:100%;max-width:100%}
  /* make internal map responsive inside stacked sidebar */
  .sidebar .map{max-width:100%;}
  .tokyo-area {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
  }
 
}

/* For very small screens */
@media (max-width:600px){
  /* Additional responsive styles can be added here */
  .search-section {
    padding: 20px 15px;
    margin-bottom: 20px;
  }
  
  .search-section h2 {
    font-size: 1.5em;
  }
  
  .search-input-wrapper {
    border-radius: 25px;
  }
  
  .search-input,
  .search-button {
    padding: 14px 18px;
  }
  
  .search-input {
    font-size: 0.9em;
  }
  
  .search-examples {
    justify-content: center;
  } 
  /* Hero: 2 columns layout for mobile */
  .hero {
    flex-wrap: wrap;
    gap: 2px;
  }
  
  .ad-slot {
    flex: 1 1 calc(50% - 1px);
    min-width: calc(50% - 1px);
    width: calc(50% - 1px);
  }
  
  .ad-slot img {
    width: 100%; 
    object-fit: contain;
  }
  
  .list{grid-template-columns:1fr}
  /* .card{grid-template-columns:96px 1fr;grid-template-rows:auto auto auto;gap:8px 12px} */
  .card img{width:96px;height:96px;grid-row:1/4}
  .card .info{grid-template-rows:auto auto auto}
  .footer .footer-links{gap:8px}
  .footer .footer-links a{font-size:12px;min-height:28px;padding:6px 8px}
  .footer .footer-links a + a::before{display:none}
}

/* Add tokyo-area pane styles (split A/B) */
.tokyo-map-wrapper{width:100%;box-sizing:border-box}
.tokyo-panes{display:flex;gap:12px;align-items:stretch;overflow:hidden}
.tokyo-pane{
  flex:1;
  min-width:0;
  display:block;
  transition: opacity 0.3s ease, transform 0.3s ease;
  min-height: 280px; /* 固定最小高度避免切换时闪烁 */
}
.tokyo-pane .map-table{
  width:100%;
  table-layout:fixed;
  border-collapse:collapse;
  height: 100%; /* 让表格填满容器高度 */
}

/* Controls (hidden on wide screens) */
.tokyo-pane-controls{display:none;gap:8px;justify-content:center;margin-top:8px}
.tokyo-arrow{
  background:#858484;
  border:1px solid rgba(255,255,255,0.04);
  color:#fff;
  padding:8px 12px;
  border-radius:8px;
  cursor:pointer;
  transition: background-color 0.2s ease, transform 0.2s ease;
}
.tokyo-arrow:hover{
  background:#252525;
  transform: scale(1.05);
}
.tokyo-arrow:focus{outline:2px solid rgba(217,75,106,0.18)}
.tokyo-arrow:active{
  transform: scale(0.95);
}

/* Wide: show both panes side-by-side (>=800px) */
@media (min-width:800px){
  .tokyo-area{overflow:visible}
  .tokyo-panes{overflow:visible}
  .tokyo-pane{display:block}
  .tokyo-pane-controls{display:none}
}

/* Narrow: single-pane mode; JS will add .pane-single to .tokyo-area
   When .pane-single is present, hide non-active panes and show controls */
@media (max-width:799px){
  .tokyo-panes{
    display:block;
    min-height: 280px; /* 让容器有固定高度避免切换闪烁 */
  }
  .tokyo-area.pane-single .tokyo-pane{
    display:none;
    min-height: 280px; /* 保持与宽屏模式相同的最小高度 */
  }
  .tokyo-area.pane-single .tokyo-pane.active{
    display:block;
  }
  .tokyo-area.pane-single .tokyo-pane .map-table td{height:auto}
  .tokyo-area.pane-single .tokyo-pane .map-table a{justify-content:center}
  .tokyo-pane-controls{display:flex}
}

/* Override previous wide fixed width for map-table used earlier */
.tokyo-area .map-table{border-collapse:collapse;margin:0;table-layout:fixed;width:100%;max-width:100%}

/* Ensure tokyo-area doesn't force page horizontal scroll */
.tokyo-area, .tokyo-panes, .tokyo-pane{min-width:0}

/* 铁道风格上边框 for index.php 池袋・目白エリア */
.railway-td {
  border-top: 2px solid #8fd16a !important;
  position: relative;
  background: transparent;
  border-radius: 0 !important;
  padding-top: 12px !important;
}
.railway-td .railway-dots {
  display: flex;
  justify-content: space-between;
  position: absolute;
  left: 12%;
  right: 12%;
  top: -6px;
  z-index: 2;
  pointer-events: none;
}
/* 合并所有圆点样式为统一的 .railway-dot，可通过 .small/.large 控制大小 */
.railway-dot {
  width: 10px;
  height: 10px;
  background: #fff;
  border-radius: 50%;
  border: 1px solid #8fd16a;
  box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.railway-dot.small {
	width: 6px;
	height: 6px;
	background: #fff;
	border-radius: 50%;
	border: 1px solid #aaa;
	display: block;
}
.railway-left {
  border-left: 2px solid #8fd16a !important;
  border-top-left-radius: 6px !important;
  position: relative;
}
.railway-left-vertical {
  border-left: 2px solid #8fd16a !important;
  border-top: none !important;
  border-radius: 0 0 0 8px !important;
  position: relative;
  padding-left: 8px !important;
}
.railway-dots-vertical {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  left: -8px;
  top: 18%;
  bottom: 18%;
  height: 64%;
  z-index: 2;
  pointer-events: none;
}


