/* =========================================================================
 *  ラン活ナビ — スタイル v1「脱AI感」
 *  方針（食べログ / HOME'S / サウナイキタイ調査より）:
 *  ・色は「面」でなく「線と点」。見出し・区切りはグレースケール＋1px罫線。
 *  ・絵文字全廃→単色ラインアイコン。左アクセントバー/英語キッカー撤去。
 *  ・角丸控えめ・影は使わず1px罫線・hoverは色と下線のみ。
 *  色: 白ベース × 藍(線と点) × 差し色ランドセルレッド × ゴールド(本革・最高級)
 * ========================================================================= */
:root{
  --bg:#fbfbfc; --surface:#fff; --surface-2:#f4f6f9;
  --ink:#23272e; --ink-2:#555c66; --ink-3:#8a909a;
  --line:#e5e7ec; --line-2:#eef0f3;
  --green:#3f5aa6; --green-d:#2c4080; --green-bg:#eef1f9; --green-l:#8fa3d4;
  --wine:#b23a48; --wine-d:#8f2c38; --wine-bg:#f8edee;
  --gold:#a9802f; --gold-bg:#f6efdf; --warn:#c9772a;
  --r:8px; --r-s:6px;
  --sh:0 1px 2px rgba(31,42,54,.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:26px;height:26px;flex:none}
.brand b{font-size:16px;letter-spacing:.02em;font-weight:800;color:var(--green-d)}
.brand b span{color:var(--wine)}
.brand small{display:block;font-size:8.5px;letter-spacing:.22em;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:230px;max-width:38vw}
.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(--green)}
.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);display:flex;align-items:center;gap:8px}
.h-sec .en{display:none}
.h-sec .more{margin-left:auto;font-size:12.5px;color:var(--ink-3);font-weight:700}
.h-sec .more:hover{color:var(--green)}
.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:20px 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:660px;padding:34px 18px 30px}
.hero h1{font-size:25px;line-height:1.5;margin:0 0 10px;font-weight:800;letter-spacing:.01em;color:var(--green-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(--green);color:#fff;font-weight:800;padding:0 22px;font-size:14px;letter-spacing:.04em}
.bigsearch button:hover{background:var(--green-d)}

/* ---------- カテゴリタイル（主軸） ---------- */
.ctiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ctile{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 16px}
.ctile:hover{border-color:var(--green);background:#fcfdff}
.ctile .ci{flex:none;width:42px;height:42px;border-radius:10px;display:grid;place-items:center;background:var(--green-bg);color:var(--green-d)}
.ctile .ci .ico{width:23px;height:23px}
.ctile .ct{flex:1;min-width:0}
.ctile .ct b{font-size:15.5px;font-weight:800;color:var(--ink);display:flex;align-items:baseline;gap:6px}
.ctile .ct b i{font-style:normal;font-size:12px;font-weight:700;color:var(--green);background:var(--green-bg);border-radius:999px;padding:1px 8px}
.ctile .ct small{display:block;font-size:11.5px;color:var(--ink-3);margin-top:3px;line-height:1.6}
.ctile .carr{flex:none;color:var(--ink-3);font-size:20px}
.ctile:hover .carr{color:var(--green)}

/* ---------- 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(--green);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)}
.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}
.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(--green);width:16px;height:16px;flex:none;margin:0}
.opt .cnt{margin-left:auto;font-size:11px;color:var(--ink-3)}
.opt:hover{color:var(--green)}
.opt.dim{opacity:.45}
.facet .clear{width:100%;border:0;border-top:1px solid var(--line-2);background:#fff;color:var(--green-d);font-weight:800;padding:12px;font-size:12.5px}
.facet .clear:hover{background:var(--green-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(--wine);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(--green-bg);border:1px solid #d2dcf0;color:var(--green-d);border-radius:4px;padding:4px 9px;font-size:12px;font-weight:700;cursor:pointer}
.achip:hover{background:#e2e8f6}

/* ---------- チップ ---------- */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip{display:inline-flex;align-items:center;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(--green);color:var(--green)}
.chip .n{font-size:11px;color:var(--ink-3);font-weight:700}
.chip-color .cdot{width:12px;height:12px}

/* カラードット */
.cdot{display:inline-block;width:13px;height:13px;border-radius:50%;border:1px solid rgba(0,0,0,.14);flex:none;vertical-align:-1px}
.cdot.lg{width:18px;height:18px;margin-right:6px}
.colorrow{display:flex;align-items:center;gap:5px;margin-bottom:9px;flex-wrap:wrap}
.cmore{font-size:10.5px;color:var(--ink-3);font-weight:700}

/* ---------- 結果カード ---------- */
.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:#fcfdff}
.wrow .thumb{width:128px;height:128px;border-radius:var(--r-s);flex:none;overflow:hidden;position:relative;background:var(--green-bg);display:grid;place-items:center;color:var(--green-l)}
.wrow .thumb .ph .ico{width:40px;height:40px}
.wrow .thumb .rec{position:absolute;left:6px;top:6px;font-size:9.5px;font-weight:800;color:var(--wine-d);background:#fff;border:1px solid #e6c6cc;border-radius:4px;padding:1px 6px}
.wrow .thumb .rec.leather{color:var(--gold);border-color:#e6d3a8}
.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(--green);text-decoration:underline;text-underline-offset:2px}
.wrow .loc{font-size:12px;color:var(--ink-3);margin-bottom:6px;display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.wrow .loc .catlink{color:var(--green);font-weight:700}
.wrow .loc .catlink:hover{text-decoration:underline;text-underline-offset:2px}
.wrow .price{display:flex;align-items:center;gap:5px;font-size:13.5px;color:var(--ink);margin-bottom:7px}
.wrow .price .ico{width:15px;height:15px;color:var(--wine)}
.wrow .price b{font-weight:800}
.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}
.tag{font-size:11px;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:4px;padding:2px 8px}
.tag.tg-leather{color:var(--gold);border-color:#e6d3a8}
.tag.tg-pop{color:var(--wine-d);border-color:#e6c6cc}
.tag.tg-light{color:var(--green-d);border-color:#d2dcf0}
.tag.tag-color{display:inline-flex;align-items:center;gap:5px}
a.tag:hover{border-color:var(--green);color:var(--green)}
.amen{display:flex;flex-wrap:wrap;gap:6px}
.amen .a{font-size:11px;font-weight:700;border-radius:4px;padding:2px 8px;border:1px solid var(--line);color:var(--ink-3)}
.amen .a.on{color:var(--green-d);border-color:#d2dcf0}
.empty{padding:50px 20px;text-align:center;color:var(--ink-3)}

/* ---------- 個別ページ ---------- */
.dhero{position:relative;background:linear-gradient(120deg,#2c4080,#3f5aa6);min-height:190px;display:flex;align-items:flex-end;overflow:hidden}
.dhero-mk{position:absolute;right:-10px;bottom:-20px;color:rgba(255,255,255,.13)}
.dhero-mk .ico{width:200px;height:200px}
.dhero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,30,60,.05) 30%,rgba(20,30,60,.55))}
.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:#d6deef;font-weight:700;letter-spacing:.04em;margin-bottom:5px}
.dhero .area a{color:#d6deef}.dhero .area a:hover{text-decoration:underline}
.dhero h1{margin:0;font-size:23px;font-weight:800;letter-spacing:.01em}
.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(--green-d);border-bottom-color:var(--green)}

/* 設備（罫線グリッド・ラインアイコン） */
.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(--green)}
.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)}

/* ブランドの物語 */
.story{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 2px;margin:10px 0}
.story-h{font-size:12px;font-weight:800;color:var(--wine-d);letter-spacing:.06em;margin-bottom:8px}
.story p{margin:0;font-size:14px;line-height:1.95;color:var(--ink)}
.story.empty p{color:var(--ink-3);font-size:13px}

.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:120px;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(--green);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}
.cta{display:flex;gap:10px;margin:18px 0 6px;flex-wrap:wrap}
.cta a{flex:1;min-width:200px;text-align:center;padding:13px;border-radius:var(--r-s);font-weight:800;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:7px}
.cta .pri{background:var(--wine);color:#fff}.cta .pri:hover{background:var(--wine-d)}
.cta .pri .ico{width:17px;height:17px}
.cta .sec{background:#fff;border:1px solid var(--green);color:var(--green-d)}
.cta .sec:hover{background:var(--green-bg)}
.foot-note{font-size:11.5px;color:var(--ink-3);margin:10px 2px}

.lineup .it{display:flex;align-items:center;gap:13px;border:1px solid var(--line);border-radius:var(--r-s);padding:12px 14px;margin-bottom:10px;background:#fff}
.lineup .it .bdg{min-width:64px;padding:0 8px;height:38px;border-radius:var(--r-s);flex:none;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:800;text-align:center;line-height:1.2}
.b-cordovan{background:var(--gold)}.b-cow{background:var(--wine)}.b-synthetic{background:var(--green)}
.lineup .it .m{flex:1;min-width:0}.lineup .it .m b{font-size:14px;display:block}.lineup .it .m small{font-size:11.5px;color:var(--ink-3)}
.lineup .it .gr{font-size:11.5px;font-weight:700;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:999px;padding:3px 11px;white-space:nowrap}

/* 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;display:flex;align-items:center;gap:7px}
.seobox summary .ico{width:15px;height:15px;color:var(--ink-3)}
.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(--green-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(--green);background:#fff;color:var(--green-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(--wine);color:#fff;border-radius:999px;font-size:11px;padding:1px 7px;font-weight:800}
  .amen-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .ctiles{grid-template-columns:1fr}
  .wrow .thumb{width:96px;height:96px}.wrow h3{font-size:15px}
  .cta a{min-width:100%}
}
.fade{animation:fade .2s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ---------- 独立フロント: ヘッダーナビ / フッター（SSR版で追加） ---------- */
.rn-nav{display:flex;gap:16px;align-items:center}
.rn-nav a{font-size:13px;font-weight:700;color:var(--ink-2)}
.rn-nav a:hover{color:var(--green)}
@media (max-width:560px){ .rn-nav{gap:11px} .rn-nav a{font-size:12px} }

.rn-footer{border-top:1px solid var(--line);background:var(--surface);margin-top:40px}
.rn-footer .inner{max-width:var(--maxw);margin:0 auto;padding:26px 16px 16px;display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:flex-start}
.rn-footer .fb b{font-size:16px;font-weight:800;color:var(--green-d)}
.rn-footer .fb b span{color:var(--wine)}
.rn-footer .fb small{display:block;color:var(--ink-3);font-size:12px;margin-top:6px}
.rn-footer .links{display:flex;flex-wrap:wrap;gap:8px 18px}
.rn-footer .links a{font-size:12.5px;font-weight:700;color:var(--ink-2)}
.rn-footer .links a:hover{color:var(--green)}
.rn-foot-note{max-width:var(--maxw);margin:0 auto;padding:0 16px 14px;font-size:11.5px;color:var(--ink-3);line-height:1.7}

/* ページネーション（WP標準） */
.pagination,.nav-links{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin:22px 0}
.pagination .page-numbers,.nav-links .page-numbers{display:inline-flex;min-width:36px;height:36px;align-items:center;justify-content:center;padding:0 10px;border:1px solid var(--line);border-radius:var(--r-s);background:#fff;font-size:13px;font-weight:700;color:var(--ink-2)}
.pagination .page-numbers.current{background:var(--green);border-color:var(--green);color:#fff}
.pagination a.page-numbers:hover{border-color:var(--green);color:var(--green)}
