/* Tateishi Topshot Villa — 共有ページCSS（コンテンツ系ページ: legal/access/faq/rooms/contact）
   ホーム(index.html / en/index.html)はヒーロー含む専用CSSを内蔵。本CSSは下層ページ共通。 */
:root{--bg:#FAF8F3;--ink:#211f1b;--soft:#6f6a61;--line:#e7e1d6;--coral:#cf5b3b;--coral-d:#b54a2d;--card:#fff;--navy:#1c2330}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Zen Kaku Gothic New",sans-serif;color:var(--ink);background:var(--bg);line-height:1.85;-webkit-font-smoothing:antialiased}
img{display:block}
.en{font-family:"Archivo",sans-serif}
.wrap{max-width:1080px;margin:0 auto;padding:0 30px}
a{color:inherit}
/* header (solid) */
header{background:var(--navy)}
.bar{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo b{font-family:"Archivo";font-weight:800;font-size:16px;letter-spacing:.02em;color:#fff}
.logo span{display:block;font-size:10px;color:rgba(255,255,255,.7);letter-spacing:.18em}
nav.main{display:flex;align-items:center;gap:22px}
nav.main a{font-size:14px;color:rgba(255,255,255,.92);text-decoration:none}
.links{display:flex;gap:22px}
.lang{font-size:12px;color:rgba(255,255,255,.7)}.lang a{text-decoration:none}.lang .cur{color:#fff;font-weight:700}
.book-sm{background:var(--coral);color:#fff!important;padding:9px 18px;border-radius:999px;font-size:13px;font-weight:700;text-decoration:none}
.menu-btn{display:none;background:none;border:0;color:#fff;cursor:pointer}
#mnav{display:none}
/* page head */
main{padding:52px 0 80px}
.lab{font-family:"Archivo";font-size:12px;letter-spacing:.22em;color:var(--coral);text-transform:uppercase;margin-bottom:10px}
h1{font-family:"Archivo";font-weight:800;font-size:32px;margin-bottom:8px}
.intro{color:var(--soft);font-size:15px;margin-bottom:34px;max-width:46em}
.back{display:inline-block;margin-top:36px;color:var(--coral);font-weight:700;text-decoration:none}
/* legal dl + body */
dl.sct{border-top:1px solid var(--line)}
dl.sct>div{display:grid;grid-template-columns:240px 1fr;border-bottom:1px solid var(--line)}
dl.sct dt{padding:16px 16px 16px 0;font-weight:700;font-size:14.5px}
dl.sct dd{padding:16px 0;font-size:14.5px}
dl.sct dd small{color:var(--soft);font-size:12.5px}
.legal-body h2{font-size:17px;margin:28px 0 8px;font-weight:700}
.legal-body p{font-size:14.5px;margin-bottom:8px}
.legal-body ul{margin:6px 0 8px 1.2em}.legal-body li{font-size:14.5px;margin-bottom:4px}
.legal-body .contact{margin-top:8px;font-size:14.5px;line-height:1.8}
.upd{color:var(--soft);font-size:13px;margin-bottom:30px}
/* access grid */
.acc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px 28px;margin:6px 0 30px}
.acc-grid .it{border:1px solid var(--line);border-radius:14px;padding:16px 18px;background:var(--card)}
.acc-grid .it .k{font-size:12px;color:var(--soft)}
.acc-grid .it .v{font-family:"Archivo";font-weight:700;font-size:18px;color:var(--coral-d);margin:2px 0}
.acc-grid .it .n{font-size:12px;color:var(--soft)}
.addr{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:22px;font-size:14.5px}
.map{aspect-ratio:16/8;border-radius:16px;overflow:hidden;margin:8px 0 24px;border:1px solid var(--line)}
.map iframe{width:100%;height:100%;border:0}
.h2{font-size:19px;font-weight:700;margin:30px 0 12px}
.near{list-style:none}.near li{font-size:14.5px;padding:8px 0;border-bottom:1px solid var(--line);color:var(--soft)}
/* faq */
.faq-list details{border-bottom:1px solid var(--line);padding:16px 0}
.faq-list summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;font-weight:700;font-size:15.5px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary .x{color:var(--coral);transition:.2s}
.faq-list details[open] summary .x{transform:rotate(45deg)}
.faq-list details p{margin-top:12px;font-size:14px;color:var(--soft);line-height:1.95}
.faq-cat{font-family:"Archivo";font-size:12px;letter-spacing:.18em;color:var(--coral);text-transform:uppercase;margin:30px 0 6px}
/* rooms gallery */
.rgal{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rgal .c{border-radius:18px;overflow:hidden;background:var(--card);box-shadow:0 8px 24px rgba(90,80,60,.07)}
.rgal .c figure{aspect-ratio:4/3;overflow:hidden}
.rgal .c img{width:100%;height:100%;object-fit:cover;transition:.6s}
.rgal .c:hover img{transform:scale(1.05)}
.rgal .c .b{padding:14px 16px}.rgal .c b{font-size:14.5px}.rgal .c p{font-size:12.5px;color:var(--soft)}
.spec{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 28px}
.spec .s{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:10px 16px;font-size:13.5px}
.spec .s b{font-family:"Archivo";color:var(--coral-d);margin-right:6px}
/* cta band */
.ctaband{margin-top:40px;background:var(--navy);color:#fff;border-radius:18px;padding:34px;text-align:center}
.ctaband h2{font-size:20px;margin-bottom:8px}.ctaband p{opacity:.78;font-size:13.5px;margin-bottom:18px}
.btn{display:inline-flex;align-items:center;gap:9px;border-radius:999px;font-weight:700;font-size:15px;text-decoration:none;padding:15px 30px;background:var(--coral);color:#fff;transition:.2s}.btn:hover{background:var(--coral-d)}
/* contact */
.cbox{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px 26px;margin-bottom:18px}
.cbox h2{font-size:17px;margin-bottom:8px}.cbox p{font-size:14.5px;color:var(--soft);margin-bottom:6px}
.cbox a.mail{color:var(--coral);font-weight:700;text-decoration:none}
/* footer */
footer{background:#13161f;color:#fff;padding:48px 0 30px}
.fbar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px}
.fbar .en{font-weight:800;font-size:16px}.fbar .jp{font-size:12px;color:rgba(255,255,255,.6)}
.flinks a{color:rgba(255,255,255,.85);text-decoration:none;font-size:13px;margin-left:18px}
.fbot{border-top:1px solid rgba(255,255,255,.1);margin-top:26px;padding-top:18px;font-size:12px;color:rgba(255,255,255,.5);display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
@media(max-width:820px){
 nav.main .links,nav.main .lang{display:none}.menu-btn{display:block}
 dl.sct>div{grid-template-columns:1fr}dl.sct dt{padding-bottom:0}dl.sct dd{padding-top:6px}
 .acc-grid{grid-template-columns:repeat(2,1fr)}.rgal{grid-template-columns:1fr}
 #mnav.open{display:block}#mnav{display:none;background:#fff;padding:14px 30px}#mnav a{display:block;padding:9px 0;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}
}
