/* ============================================================
   日本の世界遺産ガイド / Japan World Heritage Guide
   共通スタイル（日英共通）。色はここを変えれば全ページに反映。
   ============================================================ */
:root{
  --c-bg:#faf8f4;
  --c-surface:#ffffff;
  --c-text:#211f1b;
  --c-muted:#6c655a;
  --c-line:#e7e1d6;
  --c-brand:#9c2b2b;        /* 朱・神社の鳥居をイメージ */
  --c-brand-dark:#7d2020;
  --c-gold:#b08a3e;
  --radius:14px;
  --shadow:0 2px 12px rgba(0,0,0,.07);
  --maxw:1080px;
  --font: -apple-system,BlinkMacSystemFont,"Hiragino Sans","Noto Sans JP","Yu Gothic",sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--c-text);background:var(--c-bg);line-height:1.78;font-size:16px}
a{color:var(--c-brand);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,248,244,.93);backdrop-filter:blur(8px);border-bottom:1px solid var(--c-line)}
.site-header .container{display:flex;align-items:center;gap:16px;height:62px}
.logo{font-weight:800;font-size:1.18rem;color:var(--c-text);letter-spacing:.02em;white-space:nowrap}
.logo span{color:var(--c-brand)}
.nav{margin-left:auto;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.nav a{color:var(--c-muted);font-weight:600;font-size:.93rem}
.nav a:hover{color:var(--c-brand);text-decoration:none}
.lang-switch{display:inline-flex;border:1px solid var(--c-line);border-radius:999px;overflow:hidden;font-size:.82rem}
.lang-switch a{padding:5px 12px;color:var(--c-muted);font-weight:700}
.lang-switch a.active{background:var(--c-brand);color:#fff}
.lang-switch a:hover{text-decoration:none}

/* hero */
.hero{background:linear-gradient(135deg,#f7ece6 0%,#f3ecdd 100%);border-bottom:1px solid var(--c-line);padding:60px 0 50px;text-align:center}
.hero .badge{display:inline-block;background:var(--c-brand);color:#fff;font-size:.74rem;font-weight:700;padding:4px 12px;border-radius:999px;letter-spacing:.05em;margin-bottom:14px}
.hero-media{max-width:760px;margin:0 auto 22px}
.hero-media img{width:100%;height:auto;border-radius:16px;box-shadow:var(--shadow);display:block}
.hero h1{font-size:2rem;margin:0 0 12px;line-height:1.42}
.hero p{font-size:1.04rem;color:var(--c-muted);max-width:660px;margin:0 auto}

/* quick jump chips */
.jump{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:24px 0 0}
.jump a{display:inline-block;padding:7px 14px;border-radius:999px;background:#fff;border:1px solid var(--c-line);font-weight:700;font-size:.86rem;color:var(--c-text)}
.jump a:hover{text-decoration:none;box-shadow:var(--shadow);border-color:var(--c-brand);color:var(--c-brand)}

section{padding:46px 0}
.section-title{font-size:1.5rem;margin:0 0 6px;display:flex;align-items:center;gap:10px}
.section-sub{color:var(--c-muted);margin:0 0 24px}

/* heritage grid (hub) */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.h-card{display:block;background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);color:var(--c-text);transition:transform .12s,box-shadow .12s}
.h-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.1);text-decoration:none}
.h-card .thumb{height:120px;background:#ece5d8;display:flex;align-items:center;justify-content:center;font-size:2.4rem;color:var(--c-muted);overflow:hidden}
.h-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.h-card .b{padding:14px 16px}
.h-card h3{margin:0 0 4px;font-size:1.05rem}
.h-card p{margin:0;color:var(--c-muted);font-size:.84rem}
.h-card.soon{opacity:.55;pointer-events:none}

/* spot cards */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.card{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card .thumb{height:140px;background:#ece5d8;display:flex;align-items:center;justify-content:center;color:var(--c-muted);font-size:2.2rem}
.card .body{padding:15px 17px 17px;display:flex;flex-direction:column;flex:1}
.card h3{margin:0 0 8px;font-size:1.08rem}
.card p{margin:0;color:var(--c-muted);font-size:.9rem;flex:1}
.tag{display:inline-block;font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:999px;background:#f1e9da;color:var(--c-gold);margin:0 6px 8px 0}

/* info table */
.info-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden}
.info-table th,.info-table td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--c-line);font-size:.92rem}
.info-table th{background:#f6efe2;width:150px;color:var(--c-muted);white-space:nowrap;vertical-align:top}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:0}

/* list rows (souvenir/food/parking) */
.rows{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden}
.row{display:flex;gap:14px;padding:14px 18px;border-bottom:1px solid var(--c-line)}
.row:last-child{border-bottom:0}
.row .ic{font-size:1.5rem;flex:none;width:34px;text-align:center}
.row .rb h4{margin:0 0 3px;font-size:1rem}
.row .rb p{margin:0;color:var(--c-muted);font-size:.88rem}

/* affiliate */
.affil{background:#fff;border:1px dashed var(--c-brand);border-radius:var(--radius);padding:18px 20px;margin:18px 0}
.affil h4{margin:0 0 6px;font-size:1rem;color:var(--c-brand-dark)}
.affil p{margin:0 0 12px;color:var(--c-muted);font-size:.9rem}
.btn{display:inline-block;background:var(--c-brand);color:#fff;font-weight:700;padding:11px 22px;border-radius:999px;font-size:.94rem}
.btn:hover{background:var(--c-brand-dark);text-decoration:none;color:#fff}
.btn.ghost{background:#fff;color:var(--c-brand);border:1.5px solid var(--c-brand)}
.btn.ghost:hover{background:#fdf2f2}

.ad-slot{margin:26px auto;max-width:728px;min-height:90px;border:1px dashed var(--c-line);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#bcb2a0;font-size:.82rem;background:#fdfbf7}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--c-line);border-radius:10px;margin:0 0 10px;padding:0 16px}
.faq summary{cursor:pointer;font-weight:700;padding:14px 0;font-size:.97rem}
.faq details[open] summary{border-bottom:1px solid var(--c-line)}
.faq details p{color:var(--c-muted);font-size:.92rem;padding:12px 0 14px;margin:0}

.longread h3{font-size:1.12rem;margin:22px 0 8px}
.longread p{margin:0 0 14px;color:#3c372f;font-size:.97rem}

/* 検索＋地方フィルター */
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:0 0 22px}
.search-input{flex:1;min-width:200px;padding:11px 16px;border:1px solid var(--c-line);border-radius:999px;font-size:.95rem;background:#fff}
.search-input:focus{outline:none;border-color:var(--c-brand)}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:7px 14px;border-radius:999px;border:1px solid var(--c-line);background:#fff;font-weight:700;font-size:.85rem;cursor:pointer;color:var(--c-text)}
.chip:hover{border-color:var(--c-brand)}
.chip.active{background:var(--c-brand);color:#fff;border-color:var(--c-brand)}
.h-card.hide{display:none}
.empty{color:var(--c-muted);padding:18px 0;display:none}

/* ランキング記事 */
.rank-list{display:flex;flex-direction:column;gap:14px}
.rank-item{display:flex;gap:16px;background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);color:var(--c-text)}
.rank-item:hover{box-shadow:0 6px 18px rgba(0,0,0,.1);text-decoration:none}
.rank-item .thumb{width:170px;flex:none;background:#ece5d8}
.rank-item .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.rank-item .b{padding:14px 18px}
.rank-item .num{display:inline-block;background:var(--c-brand);color:#fff;font-weight:800;border-radius:8px;padding:1px 10px;margin-right:8px;font-size:.85rem}
.rank-item h3{margin:0 0 6px;font-size:1.12rem;display:inline-block}
.rank-item p{margin:0;color:var(--c-muted);font-size:.92rem}
.rank-item .reg{font-size:.78rem;color:var(--c-gold);font-weight:700}
@media(max-width:560px){.rank-item .thumb{width:104px}.rank-item{gap:10px}}

.breadcrumb{font-size:.82rem;color:var(--c-muted);padding:14px 0 0}
.breadcrumb a{color:var(--c-muted)}
.note{font-size:.8rem;color:var(--c-muted);background:#f6efe2;border-radius:10px;padding:12px 16px;margin:18px 0}

.site-footer{background:#211f1b;color:#cbc4b8;padding:40px 0 30px;margin-top:30px}
.site-footer a{color:#e3c79e}
.site-footer .cols{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}
.site-footer h5{color:#fff;margin:0 0 10px;font-size:.95rem}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:0 0 6px;font-size:.87rem}
.site-footer .copy{margin-top:26px;font-size:.78rem;color:#8a8273;border-top:1px solid #38342d;padding-top:16px}

@media(max-width:640px){
  .hero h1{font-size:1.55rem}
  .site-header .container{height:auto;padding:10px 16px;flex-wrap:wrap}
  .nav{gap:12px}
  .info-table th{width:110px}
}
