/* =========================================================================
 *  つづきハグ — スタイル（脱AI感）
 *  方針: 色は「面」でなく「線と点」。絵文字全廃→単色ラインアイコン。
 *  影は控えめ・1px罫線で区切る・hoverは色と下線。
 *  色: クリーム白ベース × 安心のティールグリーン(線と点) × 温かいオレンジ(差し色)
 *  カテゴリ識別色: グルメ=オレンジ / 医療=ブルー / 公園=グリーン（点と線のみ）
 * ========================================================================= */
:root{
  --bg:#fbfaf6; --surface:#fff; --surface-2:#f4f4ee;
  --ink:#23302c; --ink-2:#5b655f; --ink-3:#8d958e;
  --line:#e6e6dd; --line-2:#f0f0e8;
  --brand:#2f8f83; --brand-d:#1f6a60; --brand-bg:#e8f3f1; --brand-l:#74b7ad;
  --accent:#e08a3c; --accent-d:#c06e22; --accent-bg:#fbf0e2;
  --gold:#a9802f;
  --cat-gourmet:#e08a3c; --cat-medical:#3b78b0; --cat-park:#3f9d63;
  --warn:#c9772a;
  --r:8px; --r-s:6px;
  --sh:0 1px 2px rgba(31,42,36,.05);
  --maxw:1100px; --side:286px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Noto Sans JP","Hiragino Kaku Gothic ProN","Hiragino Sans",system-ui,sans-serif;
  color:var(--ink);background:var(--bg);font-size:14.5px;line-height:1.8;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;color:inherit}
input,select{font-family:inherit;font-size:14px}
.app{max-width:var(--maxw);margin:0 auto;background:var(--bg);min-height:100vh;padding-bottom:80px}
.ico{width:1em;height:1em;display:inline-block;vertical-align:-.13em;flex:none}

/* ---------- ヘッダー ---------- */
.appbar{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.appbar .row{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:12px;padding:11px 16px}
.brand{display:flex;align-items:center;gap:9px;cursor:pointer}
.brand .mk{width:28px;height:28px;flex:none}
.brand b{font-size:17px;letter-spacing:.02em;font-weight:800;color:var(--brand-d)}
.brand b span{color:var(--accent)}
.brand small{display:block;font-size:8.5px;letter-spacing:.24em;color:var(--ink-3);font-weight:700;margin-top:1px}
.appbar .sp{flex:1}
.hsearch{display:flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 8px 6px 13px;width:240px;max-width:40vw}
.hsearch input{border:0;outline:0;flex:1;width:100%;background:transparent}
.hsearch button{border:0;background:transparent;display:flex;color:var(--ink-3)}
.hsearch button svg{width:18px;height:18px}

/* ---------- 汎用 ---------- */
.wrap{padding:18px 16px}
.bc{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12px;color:var(--ink-3);margin:0 0 14px}
.bc a{color:var(--ink-3)}.bc a:hover{color:var(--brand)}
.bc .sep{opacity:.5}.bc b{color:var(--ink-2);font-weight:700}
.h-sec{display:flex;align-items:center;gap:9px;margin:30px 2px 14px;padding-bottom:9px;border-bottom:1px solid var(--line)}
.h-sec h2{font-size:17px;margin:0;font-weight:800;letter-spacing:.01em;color:var(--ink)}
.h-sec .more{margin-left:auto;font-size:12.5px;color:var(--ink-3);font-weight:700}
.h-sec .more:hover{color:var(--brand)}
.muted{color:var(--ink-3)}
.notice{font-size:12px;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:var(--r-s);padding:11px 13px;margin:16px 2px 0;display:flex;gap:9px;align-items:flex-start;line-height:1.7}
.notice .nlabel{flex:none;font-size:10.5px;font-weight:800;color:var(--warn);border:1px solid #e6cdac;border-radius:4px;padding:1px 6px;letter-spacing:.04em}

/* ---------- ヒーロー ---------- */
.hero{position:relative;overflow:hidden;background:var(--surface);border-bottom:1px solid var(--line)}
.hero .in{max-width:680px;padding:34px 18px 28px}
.hero h1{font-size:24px;line-height:1.5;margin:0 0 10px;font-weight:800;letter-spacing:.01em;color:var(--brand-d)}
.hero p{margin:0;font-size:13.5px;color:var(--ink-2)}
.bigsearch{margin-top:18px;display:flex;background:#fff;border-radius:var(--r-s);overflow:hidden;border:1px solid var(--line)}
.bigsearch input{flex:1;border:0;outline:0;padding:14px 16px;font-size:15px;color:var(--ink)}
.bigsearch button{border:0;background:var(--brand);color:#fff;font-weight:800;padding:0 22px;font-size:14px;letter-spacing:.04em}
.bigsearch button:hover{background:var(--brand-d)}

/* ---------- ホームの2モード切替（カテゴリ / エリア） ---------- */
.modeswitch{display:flex;gap:8px;margin:18px 2px 4px}
.modeswitch a{flex:1;text-align:center;border:1px solid var(--line);background:#fff;border-radius:var(--r-s);padding:11px;font-weight:800;font-size:13.5px;color:var(--ink-2);display:flex;align-items:center;justify-content:center;gap:7px}
.modeswitch a .ico{width:17px;height:17px;color:var(--ink-3)}
.modeswitch a.on{border-color:var(--brand);color:var(--brand-d);background:var(--brand-bg)}
.modeswitch a.on .ico{color:var(--brand)}

/* ---------- カテゴリタイル ---------- */
.cat-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:6px}
.ctile{border:1px solid var(--line);background:#fff;border-radius:var(--r);padding:16px 14px;display:flex;flex-direction:column;gap:8px;min-height:118px}
.ctile:hover{border-color:var(--brand)}
.ctile .ic{width:30px;height:30px;color:var(--ink-2)}
.ctile.c-gourmet .ic{color:var(--cat-gourmet)}
.ctile.c-medical .ic{color:var(--cat-medical)}
.ctile.c-park .ic{color:var(--cat-park)}
.ctile b{font-size:15.5px;font-weight:800}
.ctile .n{font-size:11.5px;color:var(--ink-3);font-weight:700}
.ctile .subs{font-size:11px;color:var(--ink-3);line-height:1.7;margin-top:auto}
/* サブカテゴリのチップ列（パン屋を大きく扱う） */
.subchips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.subchip{display:inline-flex;align-items:baseline;gap:6px;border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 14px;font-size:13px;font-weight:700;color:var(--ink-2)}
.subchip:hover{border-color:var(--brand);color:var(--brand)}
.subchip .n{font-size:11px;color:var(--ink-3);font-weight:700}
.subchip.big{font-size:15px;padding:10px 18px;border-color:var(--accent);color:var(--accent-d);background:var(--accent-bg)}
.subchip.big .n{color:var(--accent-d)}

/* ---------- エリア駅マップ（路線図スキーマ） ---------- */
.linemap-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:6px}
.linemap{position:relative;width:100%;aspect-ratio:5/4;background:linear-gradient(180deg,#eef4f2,#fbfaf6)}
.linemap svg{position:absolute;inset:0;width:100%;height:100%}
.linemap .ln-blue{stroke:#2b6cb0;stroke-width:2.2;fill:none;opacity:.85}
.linemap .ln-green{stroke:#3f9d63;stroke-width:2.2;fill:none;opacity:.85}
.st{position:absolute;transform:translate(-50%,-50%);display:inline-flex;flex-direction:column;align-items:center;gap:3px;background:none;border:0;white-space:nowrap}
.st .dot{width:13px;height:13px;border-radius:50%;background:#fff;border:2.4px solid var(--ink-3)}
.st.has .dot{border-color:var(--brand)}
.st .lbl{font-size:11px;font-weight:800;color:var(--ink-2);text-shadow:0 0 3px #fbfaf6,0 1px 2px #fbfaf6}
.st .c{font-size:10px;font-weight:700;color:var(--ink-3)}
.st.has:hover .dot{background:var(--brand);border-color:var(--brand-d)}
.st.has:hover .lbl{color:var(--brand-d);text-decoration:underline;text-underline-offset:2px}
.st.z0{opacity:.5}
.linemap-legend{display:flex;justify-content:center;gap:18px;padding:10px 14px;font-size:11.5px;color:var(--ink-3);flex-wrap:wrap;border-top:1px solid var(--line)}
.linemap-legend i{display:inline-block;width:18px;height:3px;border-radius:2px;margin-right:5px;vertical-align:3px}
.linemap-legend .i-blue{background:#2b6cb0}.linemap-legend .i-green{background:#3f9d63}

/* ---------- SEOアーカイブ ---------- */
.lead{font-size:15px;line-height:2;color:var(--ink-2);margin:0 2px 18px}
.points{list-style:none;margin:0 2px 18px;padding:0;display:flex;flex-wrap:wrap;gap:6px 16px}
.points li{font-size:12.5px;font-weight:700;color:var(--ink-2);display:inline-flex;align-items:center;gap:5px}
.points li .ico{color:var(--brand);width:15px;height:15px}
.faq .qa{border-top:1px solid var(--line);background:#fff}
.faq .qa:last-child{border-bottom:1px solid var(--line)}
.faq .qa summary{padding:13px 4px;font-weight:700;font-size:13.5px;cursor:pointer;list-style:none;position:relative}
.faq .qa summary::after{content:"＋";position:absolute;right:6px;color:var(--ink-3)}
.faq .qa[open] summary::after{content:"－"}
.faq .qa>div{padding:0 4px 14px;font-size:13px;color:var(--ink-2);line-height:1.9}

/* ---------- 検索（ファセット） ---------- */
.layout{display:flex;gap:20px;align-items:flex-start}
.side{width:var(--side);flex:none}
.results{flex:1;min-width:0}
.facet{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;position:sticky;top:64px}
.facet h3{margin:0;font-size:13px;font-weight:800;letter-spacing:.04em;color:var(--ink);background:#fff;padding:13px 14px;border-bottom:1px solid var(--line)}
.facet .fg{border-top:1px solid var(--line-2);padding:13px 14px}
.facet .fg:first-of-type{border-top:0}
.facet .fg .lbl{font-size:11.5px;font-weight:800;color:var(--ink-3);letter-spacing:.04em;margin-bottom:9px}
.facet .kw{display:flex;border:1px solid var(--line);border-radius:var(--r-s);overflow:hidden}
.facet .kw input{flex:1;border:0;outline:0;padding:9px 11px}
.facet select{width:100%;border:1px solid var(--line);border-radius:var(--r-s);padding:9px 10px;background:#fff;color:var(--ink)}
.facet .fg .selrow{display:flex;gap:8px}
.fgroup{border-top:1px solid var(--line-2)}
.fgroup>summary{padding:12px 14px;font-size:13px;font-weight:800;cursor:pointer;list-style:none;position:relative;color:var(--ink)}
.fgroup>summary::after{content:"";position:absolute;right:14px;top:15px;width:8px;height:8px;border-right:1.6px solid var(--ink-3);border-bottom:1.6px solid var(--ink-3);transform:rotate(45deg);transition:transform .15s}
.fgroup[open]>summary::after{transform:rotate(-135deg);top:18px}
.fgroup.kids>summary{color:var(--accent-d)}
.fopts{padding:0 14px 12px}
.opt{display:flex;align-items:center;gap:9px;padding:5px 0;font-size:13.5px;cursor:pointer;user-select:none}
.opt input{accent-color:var(--brand);width:16px;height:16px;flex:none;margin:0}
.opt .cnt{margin-left:auto;font-size:11px;color:var(--ink-3)}
.opt:hover{color:var(--brand)}
.opt.dim{opacity:.45}
.facet .clear{width:100%;border:0;border-top:1px solid var(--line-2);background:#fff;color:var(--brand-d);font-weight:800;padding:12px;font-size:12.5px}
.facet .clear:hover{background:var(--brand-bg)}
.filter-toggle{display:none}
.result-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.result-bar .cnt{font-size:14px}.result-bar .cnt b{color:var(--accent-d);font-size:21px;font-weight:800;margin:0 2px}
.result-bar .sort{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-3)}
.result-bar .sort select{border:1px solid var(--line);border-radius:6px;padding:5px 8px;background:#fff}
.active-chips{display:flex;flex-wrap:wrap;gap:7px;align-items:center;margin-bottom:14px;font-size:11.5px;color:var(--ink-3)}
.achip{display:inline-flex;align-items:center;gap:5px;background:var(--brand-bg);border:1px solid #cfe6e1;color:var(--brand-d);border-radius:4px;padding:4px 9px;font-size:12px;font-weight:700;cursor:pointer}
.achip:hover{background:#dcebe7}

/* ---------- チップ ---------- */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip{display:inline-flex;align-items:baseline;gap:6px;border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 14px;font-size:13px;font-weight:700;color:var(--ink-2)}
.chip:hover{border-color:var(--brand);color:var(--brand)}
.chip .n{font-size:11px;color:var(--ink-3);font-weight:700}
.chip.dim{opacity:.5;border-style:dashed;cursor:default}

/* 周辺エリア（行政区グループ） */
.around{margin-top:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:14px 14px 4px}
.around-h{font-size:12.5px;font-weight:800;color:var(--ink-2);margin-bottom:10px}
.ward-block{display:flex;gap:10px;align-items:flex-start;padding:8px 0;border-top:1px solid var(--line-2)}
.ward-block:first-of-type{border-top:0}
.ward-lbl{flex:none;width:84px;font-size:11.5px;font-weight:800;color:var(--ink-3);padding-top:8px}
.ward-block .chips{margin-top:0}

/* ---------- 結果カード ---------- */
.wlist{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.wrow{display:flex;gap:14px;padding:16px 15px;border-top:1px solid var(--line-2)}
.wrow:first-child{border-top:0}
.wrow:hover{background:#fcfdfb}
.wrow .thumb{width:188px;height:140px;border-radius:var(--r-s);flex:none;overflow:hidden;position:relative;background:#eef2ef;display:grid;place-items:center;color:#9fb0a8}
.wrow .thumb img{width:100%;height:100%;object-fit:cover}
.wrow .thumb .ph .ico{width:32px;height:32px}
.wrow .thumb .rec{position:absolute;left:6px;top:6px;font-size:9.5px;font-weight:800;color:var(--accent-d);background:#fff;border:1px solid #ecd2b0;border-radius:4px;padding:1px 6px}
.wrow .body{flex:1;min-width:0}
.wrow h3{margin:0 0 4px;font-size:15.5px;font-weight:800;line-height:1.4}
.wrow h3 a:hover{color:var(--brand);text-decoration:underline;text-underline-offset:2px}
.wrow .loc{font-size:12px;color:var(--ink-3);margin-bottom:8px;display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.wrow .loc .ico{width:13px;height:13px}
.wrow .sum{font-size:12.5px;color:var(--ink-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:9px}
.tagrow{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:9px}
.tag{font-size:11px;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:4px;padding:2px 8px}
.tag.tg-cat{font-weight:800}
.tag.tg-gourmet{color:var(--cat-gourmet);border-color:#ecd2b0}
.tag.tg-medical{color:var(--cat-medical);border-color:#bcd2e6}
.tag.tg-park{color:var(--cat-park);border-color:#bfe0ca}
.tag.tg-indie{color:var(--brand-d);border-color:#cfe6e1}
a.tag:hover{border-color:var(--brand);color:var(--brand)}
/* 子連れバッジ（カードの目玉） */
.kidsrow{display:flex;flex-wrap:wrap;gap:6px}
.kb{font-size:11px;font-weight:700;border-radius:4px;padding:2px 8px;border:1px solid var(--line);color:var(--ink-3);display:inline-flex;align-items:center;gap:4px}
.kb.on{color:var(--accent-d);border-color:#ecd2b0;background:var(--accent-bg)}
.kb.welcome{color:#fff;background:var(--accent);border-color:var(--accent)}
.kb .ico{width:12px;height:12px}
.empty{padding:50px 20px;text-align:center;color:var(--ink-3)}

/* ---------- 個別ページ ---------- */
.dhero{position:relative;background:#22332e;min-height:188px;display:flex;align-items:flex-end;overflow:hidden}
.dhero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.9}
.dhero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,28,24,.1) 30%,rgba(15,28,24,.8))}
.dhero .in{position:relative;z-index:2;color:#fff;padding:18px 16px;max-width:var(--maxw);margin:0 auto;width:100%}
.dhero .area{font-size:11.5px;color:#d6e8e3;font-weight:700;letter-spacing:.04em;margin-bottom:5px}
.dhero h1{margin:0;font-size:23px;font-weight:800;letter-spacing:.01em}
.dhero .credit{position:absolute;right:10px;bottom:8px;z-index:2;font-size:9.5px;color:rgba(255,255,255,.7)}
.dwrap{padding:16px}
.tabs{display:flex;border-bottom:1px solid var(--line);margin-bottom:18px}
.tab{padding:11px 16px;font-size:14px;font-weight:800;color:var(--ink-3);border:0;background:transparent;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab.on{color:var(--brand-d);border-bottom-color:var(--brand)}

/* 子連れ安心ボックス（個別ページの目玉） */
.kidsbox{background:#fff;border:1px solid var(--line);border-left:2px solid var(--accent);border-radius:var(--r-s);padding:15px 18px;margin-bottom:16px}
.kidsbox .kh{font-size:11px;letter-spacing:.08em;font-weight:800;color:var(--accent-d);display:flex;align-items:center;gap:6px}
.kidsbox .verdict{font-size:18px;font-weight:800;color:var(--ink);margin:3px 0 2px}
.kidsbox p{margin:4px 0 0;font-size:13px;color:var(--ink-2);line-height:1.85}

.amen-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r-s);overflow:hidden;margin-bottom:18px}
.amen-grid .a{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#fff;border-top:1px solid var(--line-2);border-left:1px solid var(--line-2)}
.amen-grid .a:nth-child(-n+2){border-top:0}
.amen-grid .a:nth-child(odd){border-left:0}
.amen-grid .a .ic{display:flex;color:var(--brand)}
.amen-grid .a .ic .ico{width:21px;height:21px}
.amen-grid .a.off{color:var(--ink-3)}
.amen-grid .a.off .ic{color:var(--ink-3)}
.amen-grid .a b{display:block;font-size:13px}
.amen-grid .a small{font-size:11px;color:var(--ink-3)}

.itable{border:1px solid var(--line);border-radius:var(--r-s);overflow:hidden;background:#fff}
.irow{display:flex;border-top:1px solid var(--line-2);font-size:13.5px}
.irow:first-child{border-top:0}
.irow .k{width:104px;flex:none;background:var(--surface-2);color:var(--ink-3);font-weight:700;font-size:12.5px;padding:11px 13px}
.irow .v{flex:1;padding:11px 14px}
.irow .v a{color:var(--brand);font-weight:700}
.irow .v a:hover{text-decoration:underline;text-underline-offset:2px}
.irow .v .tag{margin:0 4px 4px 0;display:inline-block}
.dsum{font-size:14px;line-height:1.95;margin:16px 2px}
.gmap{width:100%;height:300px;border:1px solid var(--line);border-radius:var(--r-s);display:block}
.cta{display:flex;gap:10px;margin:18px 0 6px}
.cta a{flex:1;text-align:center;padding:13px;border-radius:var(--r-s);font-weight:800;font-size:14px}
.cta .pri{background:var(--brand);color:#fff}.cta .pri:hover{background:var(--brand-d)}
.cta .sec{background:#fff;border:1px solid var(--accent);color:var(--accent-d)}
.foot-note{font-size:11.5px;color:var(--ink-3);margin:10px 2px}
.back{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--brand);font-weight:700;margin-top:14px}

/* SEO可視化 */
.seobox{margin:24px 2px 6px;border:1px solid var(--line);border-radius:var(--r-s);background:#fff}
.seobox summary{padding:11px 14px;font-size:12.5px;font-weight:800;color:var(--ink-2);cursor:pointer}
.seobox-in{padding:4px 14px 14px;font-size:12px;color:var(--ink-2);line-height:1.7}
.seobox-in>div{padding:6px 0;border-top:1px solid var(--line-2);display:flex;gap:10px;flex-wrap:wrap}
.seobox-in .k{flex:none;width:118px;color:var(--ink-3);font-weight:700}
.seobox-in code{background:var(--surface-2);border:1px solid var(--line);border-radius:4px;padding:1px 6px;font-size:11px;word-break:break-all}
.seobox .seonote{font-size:11px;color:var(--ink-3);margin:8px 0 0}

/* ---------- 下部ナビ ---------- */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:70;max-width:var(--maxw);margin:0 auto;display:flex;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-top:1px solid var(--line);padding:6px 0 calc(6px + env(safe-area-inset-bottom))}
.tabbar button{flex:1;background:transparent;border:0;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--ink-3);padding:5px}
.tabbar button .i{display:flex}.tabbar button .i svg{width:22px;height:22px}
.tabbar button.on{color:var(--brand-d);font-weight:800}

/* ---------- レスポンシブ ---------- */
@media (max-width:820px){
  .hsearch{display:none}
  .layout{display:block}.side{width:auto}
  .facet{position:static;display:none;margin-bottom:14px}
  .facet.open{display:block}
  .filter-toggle{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;border:1px solid var(--brand);background:#fff;color:var(--brand-d);border-radius:var(--r-s);padding:12px;font-weight:800;font-size:13.5px;margin-bottom:14px}
  .filter-toggle .ico{width:17px;height:17px}
  .filter-toggle .badge{background:var(--accent);color:#fff;border-radius:999px;font-size:11px;padding:1px 7px;font-weight:800}
  .amen-grid{grid-template-columns:1fr 1fr}
  .wrow .thumb{width:116px;height:88px}.wrow h3{font-size:15px}
}
@media (max-width:540px){
  .cat-tiles{grid-template-columns:1fr}
  .ctile{min-height:0;flex-direction:row;align-items:center;flex-wrap:wrap}
  .ctile .subs{width:100%}
}
.fade{animation:fade .2s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* WP独立フロント: 下部タブはアンカー（プロトはbutton）。同じ見た目に */
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--ink-3);padding:5px;text-decoration:none}
.tabbar a .i{display:flex}.tabbar a .i svg{width:22px;height:22px}
.tabbar a.on{color:var(--brand-d);font-weight:800}

/* WP管理バー表示時：固定ヘッダーをバーの下にずらす */
body.admin-bar .appbar{top:32px}
@media screen and (max-width:782px){body.admin-bar .appbar{top:46px}}

/* ===== UGC Phase A：設備チェック投稿 ===== */
.th-rep-msg{border-radius:var(--r-s);padding:11px 13px;font-size:12.5px;margin:0 2px 12px;border:1px solid var(--line)}
.th-rep-msg.ok{background:var(--accent-bg);border-color:#ecd2b0;color:var(--accent-d)}
.th-rep-msg.ng{background:#fbecec;border-color:#e6c6cc;color:#9a3b3b}
.th-rep-sum{border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:14px;margin:0 2px 14px}
.th-rep-sum .hh{font-size:13px;font-weight:800;color:var(--ink);margin-bottom:9px}
.th-rep-rows{display:flex;flex-direction:column;gap:1px}
.th-rep-row{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 0;border-top:1px solid var(--line-2)}
.th-rep-row:first-child{border-top:0}
.th-rep-row .lb{flex:1;min-width:0;color:var(--ink-2)}
.th-rep-row .vd{font-weight:800;font-size:12px;border:1px solid var(--line);border-radius:4px;padding:1px 8px;color:var(--ink-3)}
.th-rep-row .vd.y{color:var(--brand-d);border-color:#cfe6e1;background:var(--brand-bg)}
.th-rep-row .vd.n{color:#9a3b3b;border-color:#e6c6cc}
.th-rep-row .ct{font-size:11px;color:var(--ink-3);white-space:nowrap}
.th-rep-cmts{list-style:none;margin:11px 0 0;padding:11px 0 0;border-top:1px solid var(--line-2);font-size:12.5px;color:var(--ink-2);line-height:1.8}
.th-rep-cmts b{color:var(--ink)}
.th-rep-note{font-size:11px;color:var(--ink-3);margin:9px 0 0}
.th-report{border:1px solid var(--line);border-left:2px solid var(--accent);border-radius:var(--r-s);background:#fff;padding:15px 16px;margin:0 2px}
.th-report .hh{font-size:13px;font-weight:800;color:var(--accent-d);display:flex;align-items:center;gap:6px;margin-bottom:10px}
.th-report .hh .ico{width:16px;height:16px}
.th-fs{display:flex;flex-direction:column;gap:1px;margin-bottom:10px}
.th-f{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:7px 0;border-top:1px solid var(--line-2);font-size:13px}
.th-f:first-child{border-top:0}
.th-f .q{flex:1;min-width:140px;color:var(--ink-2);font-weight:700}
.th-f .rs{display:flex;gap:10px;flex-wrap:wrap}
.th-f .rs label{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;color:var(--ink-2);cursor:pointer}
.th-f .rs input{accent-color:var(--brand);width:15px;height:15px;margin:0}
.th-report textarea{width:100%;border:1px solid var(--line);border-radius:var(--r-s);padding:9px 11px;font-size:13px;min-height:54px;outline:0}
.th-report textarea:focus{border-color:var(--brand)}
.th-sub{display:flex;gap:8px;margin-top:8px}
.th-sub input{flex:1;min-width:0;border:1px solid var(--line);border-radius:var(--r-s);padding:9px 11px;font-size:13px;outline:0}
.th-sub button{flex:none;border:0;background:var(--brand);color:#fff;font-weight:800;border-radius:var(--r-s);padding:0 20px;font-size:13.5px;cursor:pointer}
.th-sub button:hover{background:var(--brand-d)}

/* ===== Phase B：ヘッダーのマイページ／会員・マイページ ===== */
.appbar .myp{display:inline-flex;align-items:center;gap:5px;flex:none;border:1px solid var(--line);border-radius:999px;padding:6px 12px 6px 10px;font-size:12px;font-weight:800;color:var(--ink-2)}
.appbar .myp:hover{border-color:var(--brand);color:var(--brand-d)}
.appbar .myp .ico{width:16px;height:16px;color:var(--ink-3)}
@media (max-width:820px){.appbar .myp span{display:none}.appbar .myp{padding:7px}}
.th-asme{font-size:12px;color:var(--ink-2);font-weight:700;align-self:center}
.th-asme b{color:var(--accent-d)}
/* マイページ */
.th-mp{max-width:720px;margin:0 auto}
.th-mp-head{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:var(--r);background:var(--brand-bg);padding:16px 18px}
.th-mp-head .hello{font-size:16px;font-weight:800;color:var(--ink)}
.th-mp-head .sub{font-size:11px;color:var(--ink-3);font-weight:700;margin-top:2px}
.th-mp-head .bal b{font-size:30px;font-weight:800;color:var(--brand-d)}
.th-mp-head .bal small{font-size:13px;color:var(--ink-3);margin-left:3px}
.th-mp-note{font-size:12.5px;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:var(--r-s);padding:11px 13px;margin-top:12px;line-height:1.8}
.th-mp-log{list-style:none;margin:0;padding:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff}
.th-mp-log li{display:flex;align-items:center;gap:10px;padding:11px 14px;border-top:1px solid var(--line-2);font-size:13px}
.th-mp-log li:first-child{border-top:0}
.th-mp-log .d{color:var(--ink-3);font-size:12px;width:84px;flex:none}
.th-mp-log .r{flex:1;min-width:0;color:var(--ink-2)}
.th-mp-log .p{font-weight:800;color:var(--accent-d)}
.th-mp-acts{display:flex;gap:10px;margin-top:16px}
.th-btn{display:inline-flex;align-items:center;justify-content:center;border:0;background:var(--brand);color:#fff;font-weight:800;border-radius:var(--r-s);padding:11px 20px;font-size:13.5px;cursor:pointer}
.th-btn:hover{background:var(--brand-d)}
.th-btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink-2)}
.th-mp-lead h1{font-size:21px;font-weight:800;color:var(--brand-d);margin:0 0 8px}
.th-mp-lead p{font-size:13.5px;color:var(--ink-2);line-height:1.9;margin:0 0 16px}
.th-auth{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.th-auth-card{border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:16px 16px 18px}
.th-auth-card h2{font-size:15px;font-weight:800;margin:0 0 12px;color:var(--ink)}
.th-auth-card label{display:block;font-size:12px;font-weight:700;color:var(--ink-3);margin-bottom:11px}
.th-auth-card input{display:block;width:100%;margin-top:5px;border:1px solid var(--line);border-radius:var(--r-s);padding:10px 12px;font-size:14px;outline:0}
.th-auth-card input:focus{border-color:var(--brand)}
.th-auth-card .th-btn{width:100%;margin-top:4px}
@media (max-width:600px){.th-auth{grid-template-columns:minmax(0,1fr)}}

/* ===== Phase C：抽選・景品 ===== */
.th-prizes{display:flex;flex-direction:column;gap:12px;margin-top:6px}
.pz{display:flex;gap:14px;border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:14px;align-items:center;flex-wrap:wrap}
.pz-bd{flex:1;min-width:200px}
.pz-tt{font-size:15px;font-weight:800;color:var(--ink)}
.pz-sp{font-size:11px;color:var(--accent2-d);font-weight:700;margin-top:1px}
.pz-ds{font-size:12.5px;color:var(--ink-2);margin:5px 0 8px;line-height:1.7}
.pz-meta{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:12px;color:var(--ink-3)}
.pz-meta b{color:var(--accent2-d)}
.pz-act{flex:none}
.pz-win{display:inline-block;font-weight:800;color:#fff;background:var(--accent);border-radius:999px;padding:6px 14px;font-size:13px}
.pz-done{font-size:12.5px;color:var(--ink-3);font-weight:700}
.pz-short{font-size:12.5px;color:#9a3b3b;font-weight:700}
.th-mp-log .p.minus{color:#9a3b3b}

/* ===== Phase B+：行ってみたい・おでかけ日記・ホームCTA ===== */
/* 行ってみたい */
.th-want-f{margin:0 0 12px}
.th-want{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--accent);background:#fff;color:var(--accent-d);font-weight:800;border-radius:999px;padding:9px 16px;font-size:13.5px;cursor:pointer}
.th-want .ico{width:17px;height:17px}
.th-want:hover{background:var(--accent-bg)}
.th-want.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.th-want i{font-style:normal;font-size:12px;font-weight:800;background:rgba(0,0,0,.06);border-radius:999px;padding:1px 8px}
.th-want.on i{background:rgba(255,255,255,.25)}
/* おでかけ日記 */
.dia-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;margin:0 2px 14px}
.dia{padding:14px;border-top:1px solid var(--line-2)}
.dia:first-child{border-top:0}
.dia-h{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:7px}
.dia-h b{font-size:13.5px;color:var(--ink)}
.dia-m{font-size:11.5px;color:var(--ink-3);font-weight:700}
.dia-ph{display:block;margin:0 0 8px;border-radius:var(--r-s);overflow:hidden;max-width:280px}
.dia-ph img{width:100%;height:auto;display:block}
.dia-b{font-size:13.5px;color:var(--ink-2);line-height:1.85;margin:0}
.th-diary-f{border:1px solid var(--line);border-left:2px solid var(--accent);border-radius:var(--r-s);background:#fff;padding:15px 16px;margin:0 2px}
.dia-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.dia-row label{font-size:12px;font-weight:700;color:var(--ink-3);display:flex;flex-direction:column;gap:4px}
.dia-row input,.dia-row select{border:1px solid var(--line);border-radius:var(--r-s);padding:8px 10px;font-size:13.5px;outline:0}
.th-diary-f textarea{width:100%;border:1px solid var(--line);border-radius:var(--r-s);padding:10px 12px;font-size:13.5px;min-height:80px;outline:0}
.th-diary-f textarea:focus,.dia-row input:focus,.dia-row select:focus{border-color:var(--brand)}
.dia-file{display:block;font-size:12px;font-weight:700;color:var(--ink-3);margin-top:10px}
.dia-file input{display:block;margin-top:5px;font-size:12.5px}
/* ホームCTA（.wt-top内） */
.wt-top .th-cta{display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap;border:1px solid var(--line);border-radius:var(--r);background:var(--accent-bg);padding:18px 20px}
.wt-top .th-cta-bd{flex:1;min-width:240px}
.wt-top .th-cta-bd b{display:flex;align-items:center;gap:7px;font-size:15.5px;font-weight:800;color:var(--accent-d)}
.wt-top .th-cta-bd b .ico{width:18px;height:18px}
.wt-top .th-cta-bd p{margin:6px 0 0;font-size:12.5px;color:var(--ink-2);line-height:1.8}
.wt-top .th-cta-act{display:flex;gap:10px;flex-wrap:wrap}

/* トップページだけヘッダー非表示（写真ヒーロー始まり）。他ページは従来どおり表示 */
body.th-front .appbar{display:none}
