/* ワインターミナル — WP独立フロント（SWELL非依存）。プロトv5「脱AI感」準拠 */
:root{
  --bg:#fbfbf7; --surface:#fff; --surface-2:#f4f6f0;
  --ink:#1f2a24; --ink-2:#586259; --ink-3:#8b958a;
  --line:#e3e8df; --line-2:#eef1ea;
  --green:#2e7d52; --green-d:#1e5c3b; --green-bg:#eaf2ec;
  --wine:#8e2c3b; --wine-d:#6b1f2c; --wine-bg:#f5ebec;
  --gold:#a9802f; --gold-bg:#f6efdf; --warn:#c9772a;
  --r:8px; --r-s:6px; --maxw:1100px;
}
*{box-sizing:border-box}
.wt body, body.wt-portal{margin:0}
body.wt-portal{
  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;margin:0;
}
.wt-portal a{color:inherit;text-decoration:none}
.wt-portal img{display:block;max-width:100%}
.wt-wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}
.wt-ico{width:1em;height:1em;display:inline-block;vertical-align:-.13em;flex:none}

/* ヘッダー */
.wt-appbar{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.wt-appbar .row{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:12px;padding:11px 16px}
.wt-brand{display:flex;align-items:center;gap:9px}
.wt-brand .mk{width:26px;height:26px;flex:none}
.wt-brand b{font-size:16px;letter-spacing:.02em;font-weight:800;color:var(--green-d);line-height:1.1}
.wt-brand b span{color:var(--wine)}
.wt-brand small{display:block;font-size:8.5px;letter-spacing:.24em;color:var(--ink-3);font-weight:700;margin-top:1px}
.wt-appbar .sp{flex:1}
.wt-nav a{font-size:13px;color:var(--ink-2);font-weight:700;margin-left:16px}
.wt-nav a:hover{color:var(--green)}

/* フッター */
.wt-footer{border-top:1px solid var(--line);margin-top:48px;background:var(--surface)}
.wt-footer .inner{max-width:var(--maxw);margin:0 auto;padding:26px 16px;display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between}
.wt-footer .fb b{font-weight:800;color:var(--green-d)}
.wt-footer .fb b span{color:var(--wine)}
.wt-footer small{color:var(--ink-3);font-size:12px}
.wt-footer .links a{color:var(--ink-2);font-size:12.5px;font-weight:700;margin-left:14px}
.wt-footer .links a:hover{color:var(--green)}

/* パンくず / 見出し */
.wt-bc{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12px;color:var(--ink-3);margin:16px 0 12px}
.wt-bc a:hover{color:var(--green)}
.wt-bc .sep{opacity:.5}.wt-bc b{color:var(--ink-2);font-weight:700}
.wt-head{margin:6px 0 16px}
.wt-head h1{font-size:24px;font-weight:800;margin:0 0 6px;letter-spacing:.01em}
.wt-head .cnt{color:var(--ink-3);font-size:13px;font-weight:700}
.wt-lead{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;line-height:1.9;color:var(--ink-2);margin:0 0 16px}
.wt-lead .pts{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.wt-lead .pts span{font-size:12px;font-weight:700;color:var(--green-d);background:var(--green-bg);border-radius:999px;padding:4px 11px}
.wt-h2{display:flex;align-items:center;gap:9px;margin:30px 2px 14px;padding-bottom:9px;border-bottom:1px solid var(--line)}
.wt-h2 h2{font-size:17px;margin:0;font-weight:800;color:var(--ink)}

/* ワイナリーカード（一覧行） */
.wt-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface)}
.wt-row{display:flex;gap:14px;padding:14px;border-bottom:1px solid var(--line-2);align-items:flex-start}
.wt-row:last-child{border-bottom:0}
.wt-row:hover{background:var(--surface-2)}
.wt-row .thumb{width:120px;height:90px;flex:none;border-radius:var(--r-s);background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-3);overflow:hidden}
.wt-row .thumb img{width:100%;height:100%;object-fit:cover}
.wt-row .meta{flex:1;min-width:0}
.wt-row .nm{font-size:15.5px;font-weight:800;color:var(--ink);margin:0 0 3px}
.wt-row:hover .nm{color:var(--green-d)}
.wt-row .loc{font-size:12px;color:var(--ink-3);font-weight:700;margin-bottom:5px}
.wt-row .sm{font-size:13px;color:var(--ink-2);margin:0 0 7px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.wt-chips{display:flex;flex-wrap:wrap;gap:6px}
.wt-chip{font-size:11.5px;font-weight:700;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:2px 9px}
.wt-chip.g{color:var(--green-d);border-color:#cfe3d5}

/* 個別ページ */
.wt-single .hero{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin:6px 0 18px}
.wt-single .hero.no-img{background:linear-gradient(135deg,var(--green-bg) 0%,#f4f6f0 60%,#fff 100%);padding:24px 20px}
.wt-single .hero.no-img .hero-motif{position:absolute;right:-14px;bottom:-26px;color:#bcd9c5;opacity:.8;pointer-events:none}
.wt-single .hero.no-img .hero-motif svg{width:170px;height:170px}
.wt-single .hero.has-img{min-height:300px;background-size:cover;background-position:center;display:flex;align-items:flex-end}
.wt-single .hero.has-img::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,30,24,.74),rgba(20,30,24,.08) 55%,rgba(20,30,24,0) 80%)}
.wt-single .hero-in{position:relative;z-index:1}
.wt-single .hero.has-img .hero-in{padding:22px 20px;width:100%}
.wt-single h1{font-size:25px;font-weight:800;margin:0 0 8px}
.wt-single .hero.has-img h1{color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.35)}
.wt-single .sub{color:var(--ink-3);font-size:13px;font-weight:700;margin-bottom:12px}
.wt-single .hero.has-img .sub{color:rgba(255,255,255,.92)}
.wt-single .hero-credit{position:absolute;right:9px;bottom:8px;z-index:2;font-size:10.5px;color:rgba(255,255,255,.85);background:rgba(0,0,0,.32);padding:2px 8px;border-radius:4px}
@media(min-width:760px){.wt-single .hero.has-img{min-height:360px}}
.wt-badges{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}
.wt-badge{font-size:12px;font-weight:700;color:var(--green-d);background:var(--green-bg);border-radius:999px;padding:4px 12px}
.wt-badge.w{color:var(--wine-d);background:var(--wine-bg)}
.wt-grid{display:grid;grid-template-columns:1fr;gap:18px}
.wt-card{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden}
.wt-card .ct{font-size:14px;font-weight:800;padding:12px 16px;border-bottom:1px solid var(--line)}
.wt-table{width:100%;border-collapse:collapse;font-size:13.5px}
.wt-table th{text-align:left;width:128px;color:var(--ink-3);font-weight:700;vertical-align:top;padding:11px 0 11px 16px;white-space:nowrap}
.wt-table td{padding:11px 16px 11px 8px;border-bottom:1px solid var(--line-2);color:var(--ink);line-height:1.8}
.wt-table tr:last-child th,.wt-table tr:last-child td{border-bottom:0}
.wt-table a{color:var(--green-d);font-weight:700}
.wt-table a:hover{text-decoration:underline}
.wt-body{padding:16px;line-height:1.95;color:var(--ink-2)}
.wt-body p{margin:0 0 1em}
.wt-lineup{padding:6px 0}
.wt-lineup .li{display:flex;gap:10px;align-items:baseline;padding:10px 16px;border-bottom:1px solid var(--line-2)}
.wt-lineup .li:last-child{border-bottom:0}
.wt-lineup .ty{font-size:11px;font-weight:800;color:#fff;background:var(--wine);border-radius:4px;padding:1px 7px;flex:none}
.wt-lineup .ty.white{background:var(--gold)}
.wt-lineup .ty.sp{background:var(--green)}
.wt-lineup .lname{font-weight:700}
.wt-lineup .lg{color:var(--ink-3);font-size:12px;margin-left:auto}
.gmap{width:100%;height:300px;border:0;display:block}
.wt-notice{font-size:12px;color:var(--ink-2);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-s);padding:11px 13px;margin:16px 0 0;display:flex;gap:9px;align-items:flex-start;line-height:1.7}
.wt-notice .nl{flex:none;font-size:10.5px;font-weight:800;color:var(--warn);border:1px solid #e6cdac;border-radius:4px;padding:1px 6px}
.wt-cta{display:inline-block;margin-top:4px;font-size:13px;font-weight:800;color:#fff;background:var(--green);border-radius:var(--r-s);padding:9px 18px}
.wt-cta:hover{background:var(--green-d)}
.wt-cta.line{background:transparent;color:var(--green-d);border:1px solid var(--green)}

/* FAQ / 内部リンク */
.wt-faq{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden}
.wt-faq details{border-bottom:1px solid var(--line-2)}
.wt-faq details:last-child{border-bottom:0}
.wt-faq summary{padding:14px 16px;font-weight:700;cursor:pointer;list-style:none;font-size:14px}
.wt-faq summary::-webkit-details-marker{display:none}
.wt-faq .a{padding:0 16px 14px;color:var(--ink-2);font-size:13.5px;line-height:1.85}
.wt-links{display:flex;flex-wrap:wrap;gap:8px}
.wt-links a{font-size:13px;font-weight:700;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:6px 14px;background:var(--surface)}
.wt-links a:hover{color:var(--green-d);border-color:#cfe3d5}
.wt-empty{padding:40px 16px;text-align:center;color:var(--ink-3)}

@media(min-width:760px){
  .wt-row .thumb{width:180px;height:130px}
  .wt-single h1{font-size:28px}
}

/* ===== 地図トップ＆こだわり検索（portal-app.js用） ===== */
.muted{color:var(--ink-3)}
.wt-h2 .more{margin-left:auto;font-size:12.5px;color:var(--ink-3);font-weight:700}
.wt-h2 .more:hover{color:var(--green)}

/* ヒーロー */
.wt-hero{position:relative;overflow:hidden;background:var(--surface);border-bottom:1px solid var(--line)}
.wt-hero .in{max-width:640px;margin:0 auto;padding:34px 18px 30px}
.wt-hero h1{font-size:25px;line-height:1.5;margin:0 0 10px;font-weight:800;letter-spacing:.01em;color:var(--green-d)}
.wt-hero p{margin:0 0 14px;font-size:13.5px;color:var(--ink-2)}
.wt-bigsearch{display:flex;gap:8px;max-width:520px}
.wt-bigsearch input{flex:1;border:1px solid var(--line);border-radius:8px;padding:11px 14px;font-size:14px;outline:0}
.wt-bigsearch input:focus{border-color:var(--green)}
.wt-bigsearch button{border:0;background:var(--green);color:#fff;font-weight:800;border-radius:8px;padding:0 20px;font-size:14px;cursor:pointer}
.wt-bigsearch button:hover{background:var(--green-d)}

/* 日本地図 */
.geo{position:relative;width:100%;margin:0 auto;aspect-ratio:3/2}
.geo-map{position:absolute;inset:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.geolonia-svg-map{position:absolute;inset:0;width:100%;height:100%;max-height:none;transform:scale(.9);transform-origin:center top}
.geolonia-svg-map .prefecture{fill:#dde6d6;stroke:#fbfbf7;stroke-width:.8;transition:fill .15s}
.geolonia-svg-map .prefecture.has{fill:var(--green-l,#6aab81);cursor:pointer}
.geolonia-svg-map .prefecture.has:hover,.geolonia-svg-map .prefecture.hi{fill:var(--green-d)}
.geolonia-svg-map .boundary-line{stroke:#fbfbf7;stroke-width:.6;fill:none}
.rpanel{position:absolute;width:clamp(132px,21%,176px);pointer-events:none;z-index:2;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:8px;padding:8px 11px 9px;box-shadow:0 1px 3px rgba(31,42,36,.1)}
.rpanel .rhead{display:inline-block;background:var(--green);color:#fff;border-radius:6px;padding:2px 9px;font-size:11.5px;font-weight:800;margin-bottom:5px;pointer-events:auto}
.rpanel .pns{display:grid;gap:1px 9px;grid-template-columns:repeat(3,auto)}
.rpanel .pn{font-size:11px;color:var(--ink-3);line-height:1.75;white-space:nowrap;text-shadow:0 0 3px #fbfbf7,0 1px 2px #fbfbf7}
.rpanel .pn.on{color:var(--ink-2);font-weight:700;pointer-events:auto;display:inline-flex;align-items:baseline;gap:2px}
.rpanel .pn.on:hover{color:var(--wine);text-decoration:underline;text-underline-offset:2px}
.rpanel .pn.on i{font-style:normal;font-size:9.5px;font-weight:700;color:var(--ink-3)}
.map-legend{display:flex;justify-content:center;gap:16px;padding:11px 14px 0;font-size:11.5px;color:var(--ink-3);flex-wrap:wrap}
.map-legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.map-legend .i-has{background:var(--green-l,#6aab81)}.map-legend .i-idle{background:#dde6d6}

/* チップ */
.wt-chips2{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.wt-chip2{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)}
.wt-chip2:hover{border-color:var(--green);color:var(--green)}
.wt-chip2 .n{font-size:11px;color:var(--ink-3);font-weight:700}

/* 結果リスト（地図トップ／検索 共通） */
.wt-list2{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:6px}
.wrow2{display:flex;gap:14px;padding:14px;border-top:1px solid var(--line-2)}
.wrow2:first-child{border-top:0}
.wrow2:hover{background:var(--surface-2)}
.wrow2 .thumb{width:96px;height:72px;flex:none;border-radius:var(--r-s);background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-3)}
.wrow2 .thumb .wt-ico{width:26px;height:26px;opacity:.6}
.wrow2 .body{flex:1;min-width:0}
.wrow2 .nm{display:block;font-size:15px;font-weight:800;color:var(--ink);margin-bottom:3px}
.wrow2:hover .nm{color:var(--green-d)}
.wrow2 .loc{display:block;font-size:12px;color:var(--ink-3);font-weight:700;margin-bottom:5px}
.wrow2 .loc .wt-ico{width:13px;height:13px;margin-right:2px}
.wrow2 .sum{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:13px;color:var(--ink-2);margin-bottom:7px}
.wrow2 .amen{display:flex;flex-wrap:wrap;gap:6px}
.wa{font-size:11px;font-weight:700;border:1px solid var(--line);border-radius:4px;padding:1px 7px}
.wa.on{color:var(--green-d);border-color:#cfe3d5}
.wa.off{color:var(--ink-3);opacity:.6}

/* 検索レイアウト */
.layout{display:flex;gap:20px;align-items:flex-start}
.side{width:286px;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;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);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;width:100%}
.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}
.fgroup>summary::-webkit-details-marker{display:none}
.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;cursor:pointer}
.facet .clear:hover{background:var(--green-bg)}
.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{border:1px solid var(--line);border-radius:999px;padding:3px 10px;cursor:pointer;color:var(--ink-2);font-weight:700;background:#fff}
.achip:hover{border-color:var(--wine);color:var(--wine)}

@media(max-width:760px){
  .layout{flex-direction:column}
  .side{width:100%}
  .facet{position:static}
  /* スマホ: 日本地図は消し、エリア枠だけを2列で並べる */
  .geo{position:static;aspect-ratio:auto;display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .geo-map{display:none}
  .map-legend{display:none}
  .rpanel{position:static;width:auto;pointer-events:auto;box-shadow:none;z-index:auto}
  .rpanel .pn{text-shadow:none}
  .rpanel .rhead{box-shadow:none}
}
@media(max-width:430px){
  .geo{grid-template-columns:1fr}
}

/* ===== プロト完全再現: 産地ページ・個別ページ ===== */
.ico{width:1em;height:1em;display:inline-block;vertical-align:-.13em;flex:none}
.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(--green)}

/* リード文・ポイント */
.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}

/* 県内エリア地図 */
.pref-map-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;max-width:60%;margin:0 auto}
.pref-map{position:relative;width:100%;aspect-ratio:7/5;background:linear-gradient(180deg,#eef4ea,#fbfbf7)}
.pref-map svg{position:absolute;inset:0;width:100%;height:100%}
.pref-map svg polygon,.pref-map svg path{fill:#cfe0c8;stroke:#fff;stroke-width:1.1}
.zone{position:absolute;transform:translate(-50%,-50%);display:inline-flex;align-items:baseline;gap:5px;background:rgba(255,255,255,.97);border:1px solid var(--line);border-radius:999px;padding:4px 11px;box-shadow:var(--sh);white-space:nowrap;color:var(--ink)}
.zone:hover{border-color:var(--green);color:var(--green)}
.zone b{font-size:12px;font-weight:800}
.zone .c{font-size:10.5px;font-weight:700;color:var(--ink-3)}
.zone.z0{opacity:.55}
.area-links{gap:10px;margin-top:6px}
.area-links .chip{font-size:15px;font-weight:700;padding:11px 18px}
.area-links .chip .n{font-size:12px;padding:1px 8px}

/* チップ */
.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(--green);color:var(--green)}
.chip .n{font-size:11px;color:var(--ink-3);font-weight:700}

/* FAQ */
.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::-webkit-details-marker{display:none}
.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}

/* ワイナリーカード（wrow） */
.wlist{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.wlist .empty{padding:40px 16px;text-align:center;color:var(--ink-3)}
.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:200px;height:150px;border-radius:var(--r-s);flex:none;overflow:hidden;position:relative;background:#eef2ea;display:grid;place-items:center;color:#9fb0a2}
.wrow .thumb img{width:100%;height:100%;object-fit:cover}
.wrow .thumb .ph .ico{width:32px;height:32px}
.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:8px;display:flex;align-items:center;gap:3px}
.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-green{color:var(--green-d);border-color:#cfe0d3}
.tag.tg-gold{color:var(--gold);border-color:#e6d3a8}
.tag.tg-wine{color:var(--wine-d);border-color:#e6c6cc}
.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:#cfe0d3}

/* 個別ページ */
.wt-single{max-width:var(--maxw);margin:0 auto}
.dhero{position:relative;background:#1e3326;min-height:200px;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,20,.1) 30%,rgba(15,28,20,.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:#cfe0d3;font-weight:700;letter-spacing:.04em;margin-bottom:5px}
.dhero h1{margin:0;font-size:23px;font-weight:800;letter-spacing:.01em;color:#fff}
.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;cursor:pointer}
.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}
.story .wt-body{font-size:14px;line-height:1.95;color:var(--ink)}
.story .wt-body p{margin:0 0 1em}
.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(--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}
.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(--green);color:#fff}.cta .pri:hover{background:var(--green-d)}
.cta .sec{background:#fff;border:1px solid var(--wine);color:var(--wine)}
.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{width:38px;height:38px;border-radius:var(--r-s);flex:none;display:grid;place-items:center;color:#fff;font-size:13px;font-weight:800}
.b-赤{background:var(--wine)}.b-白{background:var(--gold)}.b-泡{background:var(--green)}.b-ロゼ{background:#b9577a}.b-甘口{background:#6b4a86}
.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:11px;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:999px;padding:2px 9px;white-space:nowrap}
.wt-single .wt-notice{margin:18px 0 0}

@media(max-width:760px){
  .pref-map-card{max-width:100%}
  .amen-grid{grid-template-columns:1fr 1fr}
  .wrow{gap:11px;padding:13px}
  .wrow .thumb{width:120px;height:90px}
  .wrow h3{font-size:15px}
  .cta{flex-direction:column}
}

/* トップ ヒーロー写真バリアント */
.wt-hero.photo{background-size:cover;background-position:center;border-bottom:0}
.wt-hero.photo .in{max-width:var(--maxw);padding:64px 18px 58px}
.wt-hero.photo h1{color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.45)}
.wt-hero.photo p{color:rgba(255,255,255,.94);text-shadow:0 1px 6px rgba(0,0,0,.4)}
.wt-hero-cr{position:absolute;right:10px;bottom:8px;font-size:10px;color:rgba(255,255,255,.82);background:rgba(0,0,0,.32);padding:2px 8px;border-radius:4px}

/* 準備中（詳細未収集） */
.prep-banner{background:var(--gold-bg);border:1px solid #e6d3a8;border-radius:var(--r);padding:16px 18px;margin:0 0 4px;line-height:1.85}
.prep-banner b{display:block;color:var(--gold);font-size:14px;margin-bottom:4px}
.prep-banner span{font-size:13px;color:var(--ink-2)}
.wrow .thumb .rec.prep{color:var(--ink-3);border-color:var(--line);background:#fff}

/* みんなの写真ギャラリー */
.wt-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:6px}
.wt-gallery figure{margin:0;position:relative;border-radius:var(--r-s);overflow:hidden;border:1px solid var(--line);background:var(--surface-2)}
.wt-gallery img{width:100%;height:120px;object-fit:cover;display:block}
.wt-gallery figcaption{position:absolute;left:0;right:0;bottom:0;font-size:10px;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.55));padding:10px 6px 4px}

/* 写真投稿フォーム */
.wt-photoform-wrap{margin-top:22px}
.wt-photoform{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden}
.wt-photoform>summary{padding:13px 16px;font-weight:800;font-size:13.5px;cursor:pointer;color:var(--green-d);list-style:none}
.wt-photoform>summary::-webkit-details-marker{display:none}
.wt-photoform>summary::before{content:"＋ ";color:var(--ink-3)}
.wt-photoform[open]>summary::before{content:"− "}
.wt-photoform .pf-in{padding:2px 16px 16px;border-top:1px solid var(--line-2)}
.pf-note{font-size:12.5px;color:var(--ink-2);line-height:1.8;margin:12px 0}
.pf-form{display:flex;flex-direction:column;gap:12px;position:relative}
.pf-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.pf-row{display:flex;flex-direction:column;gap:5px;font-size:12.5px;font-weight:700;color:var(--ink-2)}
.pf-row input[type=file],.pf-row input[type=text]{border:1px solid var(--line);border-radius:var(--r-s);padding:9px 11px;font-size:14px;font-weight:400}
.pf-consent{display:flex;gap:9px;align-items:flex-start;font-size:12px;color:var(--ink-2);line-height:1.7;background:var(--surface-2);border-radius:var(--r-s);padding:11px 12px}
.pf-consent input{margin-top:3px;flex:none;accent-color:var(--green)}
.pf-submit{align-self:flex-start;background:var(--green);color:#fff;border:0;border-radius:var(--r-s);padding:10px 24px;font-weight:800;font-size:14px;cursor:pointer}
.pf-submit:hover{background:var(--green-d)}
.pf-submit:disabled{opacity:.6}
.pf-msg{font-size:13px;font-weight:700;margin:2px 0 0}
.pf-msg.ok{color:var(--green-d)}
.pf-msg.err{color:var(--wine)}

/* UI修正: スマホ ヘッダーの折返し対策 */
.wt-brand b{white-space:nowrap}
@media(max-width:520px){
  .wt-appbar .row{gap:8px;padding:10px 12px;flex-wrap:nowrap}
  .wt-brand .mk{width:22px;height:22px}
  .wt-brand b{font-size:14px}
  .wt-brand small{display:none}
  .wt-nav{flex:none;white-space:nowrap}
  .wt-nav a{margin-left:11px;font-size:12px;white-space:nowrap}
  .wt-nav a:first-child{display:none} /* 「産地マップ」はロゴと重複するため非表示 */
  .wt-nav a:nth-child(4){display:none} /* こだわり検索はSPで省略(ホーム/フッターから) */
}
/* UI修正: スマホ 県ゾーン地図のピルを小さくして見切れ防止 */
@media(max-width:760px){
  .zone{padding:3px 9px}
  .zone b{font-size:11px}
  .zone .c{font-size:10px}
}

/* =======================================================================
 *  ポータルトップ（/ ・templates/top.php）専用スタイル  ※すべて .wt-top にスコープ
 * ===================================================================== */
.wt-top section{padding:26px 0}
.wt-top h2.sec{font-size:17px;font-weight:800;margin:0 0 12px;display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.wt-top h2.sec .ico{color:var(--wine);width:18px;height:18px}
.wt-top h2.sec .more{margin-left:auto;font-size:12px;color:var(--ink-3);font-weight:700}
.wt-top .ico{width:1em;height:1em;display:inline-block;vertical-align:-.13em;flex:none}
.wt-top .note{font-size:11.5px;color:var(--ink-3);margin:10px 2px 0}
.wt-top .pt0{padding-top:0}

/* first view 2-col */
.wt-top .fv{padding:20px 0 8px}
.wt-top .fv .grid{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:20px;align-items:start}
.wt-top .tagline{font-size:14px;font-weight:700;color:var(--green-d);margin:0 0 10px}
.wt-top .tagline b{color:var(--wine)}

/* 検索条件カード */
.wt-top .searchcard{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden;margin-bottom:16px}
.wt-top .searchcard .kw{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;padding:14px 14px 0}
.wt-top .searchcard .kw input{flex:1;min-width:0;border:1px solid var(--line);border-radius:var(--r-s);padding:11px 13px;font-size:14px;outline:0}
.wt-top .searchcard .kw input:focus{border-color:var(--green)}
.wt-top .searchcard .kw .kwbtn{border:0;background:var(--green);color:#fff;font-weight:800;border-radius:var(--r-s);padding:0 22px;font-size:14px;cursor:pointer;flex:none;white-space:nowrap}
.wt-top .cond{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:12px 14px}
.wt-top .cond .f{min-width:0}
.wt-top .cond .f label{font-size:11px;font-weight:700;color:var(--ink-3);display:block;margin-bottom:3px}
.wt-top .cond .f select{width:100%;min-width:0;border:1px solid var(--line);border-radius:var(--r-s);padding:9px 10px;background:#fff;font-size:13px}
.wt-top .cond .go{grid-column:1/-1;border:0;background:var(--wine);color:#fff;font-weight:800;font-size:14px;border-radius:var(--r-s);padding:12px;cursor:pointer}
.wt-top .cond .go b{font-size:15px;margin:0 3px}

/* 産地から探す：地図＋リスト */
.wt-top .areawrap{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden}
.wt-top .areawrap .hd{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--line-2);font-size:14px;font-weight:800}
.wt-top .areawrap .hd .ico{color:var(--wine);width:16px;height:16px}
.wt-top .areabody{display:grid;grid-template-columns:230px 1fr}
.wt-top .mapcol{border-right:1px solid var(--line-2);background:var(--surface-2);padding:12px}
.wt-top .regions{display:grid;grid-template-columns:repeat(3,1fr)}
.wt-top .rg{padding:11px 13px;border-bottom:1px solid var(--line-2);border-right:1px solid var(--line-2)}
.wt-top .rg .rh{font-size:11.5px;font-weight:800;color:var(--green-d);border-left:3px solid var(--green);padding-left:6px;margin-bottom:6px}
.wt-top .rg .pl{display:flex;flex-wrap:wrap;gap:2px 10px}
.wt-top .rg .pl a{font-size:12px;color:var(--ink-2);white-space:nowrap;display:inline-flex;align-items:baseline;gap:2px;font-weight:700}
.wt-top .rg .pl a:hover{color:var(--wine);text-decoration:underline}
.wt-top .rg .pl a i{font-style:normal;font-size:10px;color:var(--ink-3);font-weight:400}
.wt-top .rg .pl span{font-size:12px;color:var(--ink-3);opacity:.5}

/* サイド */
.wt-top .side .bn{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:14px;margin-bottom:12px}
.wt-top .side .bn.accent{background:var(--green-bg);border-color:#cfe3d5}
.wt-top .side .bn h3{margin:0 0 5px;font-size:14px;font-weight:800;color:var(--green-d)}
.wt-top .side .bn p{margin:0;font-size:12px;color:var(--ink-2)}
.wt-top .side .bn p a{color:var(--green);font-weight:700}
.wt-top .side .stat{display:flex;gap:10px;text-align:center}
.wt-top .side .stat div{flex:1}
.wt-top .side .stat b{display:block;font-size:20px;font-weight:800;color:var(--wine)}
.wt-top .side .stat small{font-size:10.5px;color:var(--ink-3)}

/* クイックナビ → 追従ヘッダー */
.wt-top .qbar{position:sticky;top:var(--wt-appbar-h,52px);z-index:55;background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line);transition:box-shadow .15s}
.wt-top .qbar.stuck{box-shadow:0 3px 10px rgba(31,42,36,.10);border-top-color:transparent}
.wt-top .qnav{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:14px 0;transition:padding .15s}
.wt-top .qnav a{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--ink-2)}
.wt-top .qnav a .ic{width:42px;height:42px;border-radius:50%;background:var(--green-bg);display:grid;place-items:center;color:var(--green-d);transition:width .15s,height .15s}
.wt-top .qnav a .ic .ico{width:20px;height:20px}
.wt-top .qnav a:hover{color:var(--green-d)}
.wt-top .qbar.stuck .qnav{padding:6px 0}
.wt-top .qbar.stuck .qnav a{gap:3px;font-size:11.5px}
.wt-top .qbar.stuck .qnav a .ic{width:28px;height:28px}
.wt-top .qbar.stuck .qnav a .ic .ico{width:15px;height:15px}

/* 注目ランキング */
.wt-top .rank{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.wt-top .rcard{display:flex;gap:12px;border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:12px;position:relative;color:inherit}
.wt-top .rcard:hover{border-color:var(--green)}
.wt-top .rcard .no{position:absolute;left:-1px;top:-1px;background:var(--wine);color:#fff;font-weight:800;font-size:12px;padding:2px 9px;border-radius:var(--r) 0 var(--r-s) 0}
.wt-top .rcard .th{width:96px;height:72px;flex:none;border-radius:var(--r-s);background:var(--surface-2);display:grid;place-items:center;color:#a7c6b1;border:1px solid var(--line);overflow:hidden}
.wt-top .rcard .th img{width:100%;height:100%;object-fit:cover}
.wt-top .rcard .th .ico{width:30px;height:30px}
.wt-top .rcard .bd{min-width:0}
.wt-top .rcard .nm{font-size:14px;font-weight:800;margin:2px 0 1px;line-height:1.4;display:block}
.wt-top .rcard .mt{font-size:11.5px;color:var(--ink-3);font-weight:700;display:block}
.wt-top .rcard .tg{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.wt-top .rcard .tg span{font-size:10.5px;font-weight:700;color:var(--green-d);background:var(--green-bg);border-radius:4px;padding:1px 7px}

/* 特集 */
.wt-top .feat{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.wt-top .fcard{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;color:inherit}
.wt-top .fcard:hover{border-color:var(--green)}
.wt-top .fcard .img{display:block;height:96px;background:var(--surface-2)}
.wt-top .fcard .img.a{background:linear-gradient(135deg,#dfe7da,#eef4ea)}
.wt-top .fcard .img.b{background:linear-gradient(135deg,#efe2c9,#f7f0e0)}
.wt-top .fcard .img.c{background:linear-gradient(135deg,#ecd9dc,#f6ecee)}
.wt-top .fcard .img.d{background:linear-gradient(135deg,#dbe6ea,#eef3f5)}
.wt-top .fcard .cap{display:block;padding:9px 11px;font-size:12.5px;font-weight:700}
.wt-top .fcard .cap small{display:block;color:var(--ink-3);font-size:10.5px;font-weight:500;margin-top:1px}

/* UGC */
.wt-top .ugc{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.wt-top .ugc figure,.wt-top .ugc .ph{margin:0;border:1px solid var(--line);border-radius:var(--r-s);overflow:hidden;background:var(--surface-2);aspect-ratio:1/1;display:grid;place-items:center;color:#a7c6b1}
.wt-top .ugc .ph img{width:100%;height:100%;object-fit:cover}
.wt-top .ugc figure .ico{width:26px;height:26px}

/* チップ（スコープ内で上書き） */
.wt-top .chips{display:flex;flex-wrap:wrap;gap:8px}
.wt-top .chip{display:inline-flex;align-items:baseline;gap:6px;border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 14px;font-size:12.5px;font-weight:700;color:var(--ink-2)}
.wt-top .chip:hover{border-color:var(--green);color:var(--green)}
.wt-top .chip .n{font-size:10.5px;color:var(--ink-3)}
.wt-top .chip.t{border-color:#e6c6cc;color:var(--wine-d)}

/* 網羅リンク */
.wt-top .sitelinks{border-top:1px solid var(--line);background:var(--surface)}
.wt-top .sitelinks .cols{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.wt-top .sitelinks h4{font-size:12px;font-weight:800;color:var(--green-d);margin:0 0 8px}
.wt-top .sitelinks a{display:inline-block;font-size:11.5px;color:var(--ink-2);margin:0 10px 5px 0}
.wt-top .sitelinks a:hover{color:var(--green)}

/* SP専用ヒーロー写真（PCでは非表示） */
.wt-top .mhero{display:none}

/* ===== モバイル ===== */
@media(max-width:880px){
  /* §11-1 トップのヘッダーバーをなくす */
  .wt-front .wt-appbar{display:none}
  .wt-top .fv{padding-top:0}
  .wt-top .fv .grid{grid-template-columns:minmax(0,1fr)}
  .wt-top .side{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}
  .wt-top .side .bn{margin:0}
  /* §11-1 地図＋地域リストはSP非表示（産地選択はカードのselectで） */
  .wt-top .areawrap{display:none}
  /* §11-2 SPヒーロー写真 */
  .wt-top .tagline{display:none}
  .wt-top .mhero{display:block;position:relative;margin:0;background:#EAE3D9}
  .wt-top .mhero .bg{width:100%;height:min(62vw,360px);object-fit:cover;object-position:center 32%;display:block;background:#EAE3D9}
  .wt-top .mhero::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(to bottom,rgba(15,30,20,.28) 0%,rgba(15,30,20,0) 34%,rgba(251,251,247,0) 56%,var(--bg) 100%)}
  .wt-top .mhero .ov{position:absolute;left:0;right:0;top:16px;z-index:2;text-align:center;padding:0 16px}
  .wt-top .mhero .ov .mk{display:inline-block;width:30px;height:30px;filter:drop-shadow(0 1px 3px rgba(0,0,0,.45))}
  .wt-top .mhero .ov b{display:block;margin-top:3px;font-size:19px;font-weight:800;color:#fff;letter-spacing:.02em;text-shadow:0 1px 8px rgba(0,0,0,.5)}
  .wt-top .mhero .ov small{display:block;font-size:8px;letter-spacing:.24em;color:rgba(255,255,255,.92);font-weight:700;margin-top:1px;text-shadow:0 1px 6px rgba(0,0,0,.5)}
  .wt-top .mhero .ov p{margin:9px auto 0;white-space:nowrap;font-size:12px;letter-spacing:-.01em;font-weight:700;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.55)}
  .wt-top .searchcard{position:relative;z-index:3;margin-top:-36px;box-shadow:0 3px 14px rgba(31,42,36,.12)}
  .wt-top .cond{grid-template-columns:repeat(2,minmax(0,1fr))}
  .wt-top .rank{grid-template-columns:1fr}
  .wt-top .feat{grid-template-columns:1fr 1fr}
  .wt-top .ugc{grid-template-columns:repeat(3,1fr)}
  .wt-top .sitelinks .cols{grid-template-columns:1fr 1fr}
}

/* インライン産地マップ（japan-map.svg）をコンテナにフィットさせる（崩れ防止） */
.wt-top .region-map{width:100%;margin:0 auto}
.wt-top .region-map svg{display:block;position:static;inset:auto;transform:none;width:100%;height:auto;max-height:240px}

/* === 横スクロール（横揺れ）を固定：clipはスクロールコンテナを作らずsticky維持 === */
html{overflow-x:clip}
.wt-top{overflow-x:clip}

/* === 条件カードのプルダウンをデザイン強化（ネイティブ簡素→ブランド調） === */
.wt-top .cond .f label{font-size:11px;font-weight:800;color:var(--ink-3);letter-spacing:.04em;margin-bottom:5px}
.wt-top .cond .f select{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  width:100%;min-width:0;
  border:1px solid var(--line);border-radius:9px;
  padding:11px 36px 11px 13px;
  background-color:#fff;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238e2c3b' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;background-size:13px;
  font-size:13.5px;font-weight:700;color:var(--ink);line-height:1.25;
  cursor:pointer;transition:border-color .15s,box-shadow .15s;
}
.wt-top .cond .f select:hover{border-color:var(--green-l)}
.wt-top .cond .f select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(46,125,82,.14)}
/* キーワード入力・ボタンも角丸と focus を揃える */
.wt-top .searchcard .kw input{border-radius:9px}
.wt-top .searchcard .kw input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(46,125,82,.14)}
.wt-top .searchcard .kw .kwbtn{border-radius:9px}

/* グリッド項目が中身でトラックを押し広げないように（iOSの横はみ出し対策） */
.wt-top .main,.wt-top .side,.wt-top .searchcard,.wt-top .searchcard .kw input{min-width:0}
.wt-top .searchcard{max-width:100%}

/* ===== ワインショップ個別 ===== */
.wt-shop-single{max-width:760px}
.wt-shop-single .sh-head h1{font-size:22px;font-weight:800;color:var(--ink);margin:6px 0 6px;line-height:1.4}
.wt-shop-single .prep-badge{font-size:11px;font-weight:700;color:#fff;background:var(--ink-3);border-radius:4px;padding:2px 8px;margin-left:8px;vertical-align:middle}
.wt-shop-single .sh-loc{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--ink-2);font-weight:700;margin:0 0 10px}
.wt-shop-single .sh-loc .ico{width:15px;height:15px;color:var(--wine)}
.wt-shop-single .tagrow{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.wt-shop-single .tagrow .tag{font-size:11.5px;font-weight:700;color:var(--green-d);background:var(--green-bg);border-radius:5px;padding:3px 9px}
.wt-shop-single .tagrow .tag.tg-green{color:#2c6e49;background:#e7f1ea}
.wt-shop-single .tagrow .tag.tg-wine{color:var(--wine-d);background:var(--wine-bg)}
.wt-shop-single .sh-info{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);overflow:hidden;margin:14px 0}
.wt-shop-single .sh-info dl{margin:0}
.wt-shop-single .sh-info dl>div{display:grid;grid-template-columns:96px 1fr;gap:0;border-bottom:1px solid var(--line-2)}
.wt-shop-single .sh-info dl>div:last-child{border-bottom:0}
.wt-shop-single .sh-info dt{font-size:12px;font-weight:700;color:var(--ink-3);background:var(--surface-2);padding:11px 14px;margin:0}
.wt-shop-single .sh-info dd{font-size:13.5px;color:var(--ink);padding:11px 14px;margin:0;line-height:1.7}
.wt-shop-single .sh-links{display:flex;flex-wrap:wrap;gap:8px;padding:12px 14px;border-top:1px solid var(--line-2);background:var(--surface-2)}
.wt-shop-single .btn{display:inline-flex;align-items:center;font-size:13px;font-weight:800;color:#fff;background:var(--green);border-radius:var(--r-s);padding:9px 16px}
.wt-shop-single .btn:hover{background:var(--green-d)}
.wt-shop-single .btn.ghost{color:var(--ink-2);background:#fff;border:1px solid var(--line)}
.wt-shop-single .btn.ghost:hover{border-color:var(--green);color:var(--green)}
.wt-shop-single .sh-body{font-size:14.5px;line-height:1.9;margin:16px 0}
.wt-shop-single .sh-meta{font-size:11px;color:var(--ink-3);margin:14px 0 4px}
.wt-shop-single .sh-meta a{color:var(--ink-2);text-decoration:underline;margin-right:4px}
.wt-shop-single .sh-disclaimer{font-size:11px;color:var(--ink-3);margin:8px 0 0}
@media(max-width:600px){ .wt-shop-single .sh-info dl>div{grid-template-columns:84px 1fr} }
