/*
Theme Name: yado-navi
Theme URI: https://yado-navi.jp
Description: yado-navi WordPress Theme — 一棟貸し・古民家・サウナ。日本全国の特別な「空間」と「体験」をナビゲートする宿メディア。
Author: Antigravity IDE
Version: 1.0.0
Text Domain: yado-navi
*/

/* =========================================================================
   yado-navi.jp — 共通デザインシステム
   生成り(warm off-white) × 明朝×ゴシック × 写真主役の編集メディア
   ========================================================================= */

:root{
  /* ---- color : warm neutral base ---- */
  --paper:    #F4F1E9;
  --paper-2:  #ECE7DB;
  --surface:  #FBFAF6;
  --ink:      #221F1C;
  --ink-2:    #5A544C;
  --ink-3:    #918A7E;
  --line:     rgba(34,31,28,.13);
  --line-2:   rgba(34,31,28,.08);
  --dark:     #1E1B18;
  --dark-2:   #2A2622;

  /* ---- accent : 朱 Vermilion（確定）---- */
  --accent:      oklch(0.55 0.15 35);
  --accent-deep: oklch(0.46 0.14 35);
  --accent-soft: oklch(0.55 0.15 35 / .10);
  --accent-fg:   #FBFAF6;

  /* ---- type ---- */
  --mincho: "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --gothic: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  --latin:  "Jost", var(--gothic);

  /* ---- layout ---- */
  --wrap: 1200px;
  --gut: 32px;
  --radius: 3px;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--gothic);
  font-weight:400;
  line-height:1.8;
  letter-spacing:.01em;
  font-feature-settings:"palt" 1;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* ---- shared headings ---- */
.mincho{ font-family:var(--mincho); font-weight:700; }
.eyebrow{
  font-family:var(--latin);
  font-weight:500;
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--ink-3);
  white-space:nowrap;
}
.eyebrow.on-dark{ color:rgba(255,255,255,.7); }

.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:36px; }
.sec-head .lead{ max-width:62ch; }
.sec-title{
  font-family:var(--mincho); font-weight:700;
  font-size:clamp(26px, 3vw, 38px);
  line-height:1.3; letter-spacing:.02em; margin:10px 0 0;
}
.sec-sub{ color:var(--ink-2); font-size:15px; margin:10px 0 0; }
.sec-more{
  flex:0 0 auto; font-family:var(--latin); font-size:13px; letter-spacing:.06em;
  color:var(--ink); display:inline-flex; align-items:center; gap:8px;
  border-bottom:1px solid var(--ink); padding-bottom:3px; transition:gap .2s, opacity .2s;
}
.sec-more:hover{ gap:14px; opacity:.6; }

/* ---- containers ---- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gut); }
.wrap-wide{ width:100%; max-width:1440px; margin-inline:auto; padding-inline:var(--gut); }

/* =========================================================================
   image placeholder
   ========================================================================= */
.ph{
  position:relative; overflow:hidden; background:var(--paper-2);
  background-image:repeating-linear-gradient(135deg,
     rgba(34,31,28,.045) 0 2px, transparent 2px 11px);
  display:flex; align-items:center; justify-content:center;
}
.ph::after{
  content:attr(data-label);
  font-family:"SFMono-Regular",ui-monospace,Menlo,Consolas,monospace;
  font-size:11px; letter-spacing:.04em; color:var(--ink-3);
  background:rgba(251,250,246,.78); padding:5px 10px; border-radius:2px;
  border:1px solid var(--line-2); max-width:80%; text-align:center; line-height:1.5;
}
.ph.dark{ background:#2b2824;
  background-image:repeating-linear-gradient(135deg,
     rgba(255,255,255,.05) 0 2px, transparent 2px 11px); }
.ph.dark::after{ background:rgba(20,18,16,.55); color:rgba(255,255,255,.75); border-color:rgba(255,255,255,.12); }

/* =========================================================================
   tag / badge
   ========================================================================= */
.tag{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; line-height:1; color:var(--ink-2);
  padding:8px 14px; border:1px solid var(--line);
  border-radius:999px; background:var(--surface);
  transition:border-color .18s, color .18s, background .18s, transform .18s;
  white-space:nowrap;
}
.tag:hover{ border-color:var(--ink); color:var(--ink); transform:translateY(-1px); }
.tag .hash{ color:var(--accent); font-family:var(--latin); }
.tag-sm{ font-size:12px; padding:5px 11px; }
.tag-solid{ background:var(--ink); color:var(--surface); border-color:var(--ink); }
.tag-area{
  display:inline-flex; align-items:center; gap:6px; font-size:12px; letter-spacing:.04em;
  color:var(--ink-2); font-family:var(--latin); text-transform:uppercase;
}
.tag-area::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--accent); }

/* =========================================================================
   button
   ========================================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--gothic); font-weight:500; font-size:15px; letter-spacing:.04em;
  padding:15px 28px; border-radius:var(--radius); border:1px solid transparent;
  transition:transform .18s, background .18s, color .18s, border-color .18s, box-shadow .18s;
}
.btn-fill{ background:var(--ink); color:var(--surface); }
.btn-fill:hover{ background:var(--accent); transform:translateY(-2px); }
.btn-line{ border-color:currentColor; background:transparent; }
.btn-line:hover{ background:var(--ink); color:var(--surface); border-color:var(--ink); }
.btn-line.on-dark{ color:#fff; }
.btn-line.on-dark:hover{ background:#fff; color:var(--ink); }
.btn-accent{ background:var(--accent); color:var(--accent-fg); }
.btn-accent:hover{ background:var(--accent-deep); transform:translateY(-2px); }
.btn-block{ width:100%; }
.btn .arr{ transition:transform .2s; }
.btn:hover .arr{ transform:translateX(4px); }

/* =========================================================================
   site header
   ========================================================================= */
.site-head{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:saturate(1.2) blur(12px);
  border-bottom:1px solid var(--line-2);
}
.site-head .bar{ display:flex; align-items:center; gap:32px; height:74px; }
.brand{ display:inline-flex; align-items:center; gap:11px; flex:0 0 auto; }
.brand .mark{ width:30px; height:30px; flex:0 0 auto; color:var(--ink); }
.brand .wm{ font-family:var(--mincho); font-weight:700; font-size:23px; letter-spacing:.06em; line-height:1; }
.brand .wm small{ font-family:var(--latin); font-weight:500; font-size:10px; letter-spacing:.34em;
  text-transform:uppercase; color:var(--ink-3); display:block; margin-top:4px; }
.nav{ display:flex; align-items:center; gap:30px; margin-left:auto; }
.nav a{ font-size:14.5px; color:var(--ink-2); position:relative; padding:6px 0; transition:color .18s; }
.nav a:hover{ color:var(--ink); }
.nav a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:1px;
  background:var(--ink); transition:width .22s; }
.nav a:hover::after{ width:100%; }
.head-actions{ display:flex; align-items:center; gap:14px; }
.icon-btn{ width:40px; height:40px; border-radius:50%; border:1px solid var(--line);
  background:var(--surface); display:flex; align-items:center; justify-content:center;
  color:var(--ink); transition:border-color .18s, transform .18s; cursor:pointer; }
.icon-btn:hover{ border-color:var(--ink); transform:translateY(-1px); }
.burger{ display:none; }

/* mobile menu */
.m-menu{ position:fixed; inset:0; z-index:60; background:var(--paper); transform:translateY(-100%);
  transition:transform .4s cubic-bezier(.4,0,.1,1); display:flex; flex-direction:column; padding:30px var(--gut); }
.m-menu.open{ transform:translateY(0); }
.m-menu .m-top{ display:flex; justify-content:space-between; align-items:center; height:44px; }
.m-menu nav{ display:flex; flex-direction:column; gap:6px; margin-top:50px; }
.m-menu nav a{ font-family:var(--mincho); font-weight:700; font-size:30px; padding:14px 0; border-bottom:1px solid var(--line-2); }
.m-menu nav a span{ font-family:var(--latin); font-size:12px; letter-spacing:.1em; color:var(--ink-3); text-transform:uppercase; margin-left:14px; }

/* =========================================================================
   footer
   ========================================================================= */
.site-foot{ background:var(--dark); color:rgba(255,255,255,.72); margin-top:120px; }
.site-foot .inner{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding:80px 0 56px; }
.foot-h{ font-family:var(--latin); font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:rgba(255,255,255,.5); margin:0 0 20px; }
.foot-links{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; }
.foot-links a{ font-size:14px; color:rgba(255,255,255,.72); transition:color .18s; }
.foot-links a:hover{ color:#fff; }
.foot-brand .wm{ font-family:var(--mincho); font-weight:700; font-size:24px; letter-spacing:.08em; color:#fff; }
.foot-brand p{ font-size:13.5px; line-height:1.9; max-width:34ch; margin:18px 0 0; color:rgba(255,255,255,.6); }
.foot-bot{ border-top:1px solid rgba(255,255,255,.1); padding:22px 0; display:flex;
  justify-content:space-between; align-items:center; font-size:12px; color:rgba(255,255,255,.45);
  font-family:var(--latin); letter-spacing:.04em; }

/* =========================================================================
   front-page (top-B)
   ========================================================================= */
.hero2{ padding:64px 0 0; }
.hero2-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.hero2 .eyebrow{ margin-bottom:24px; }
.hero2 h1{ font-family:var(--mincho); font-weight:800; line-height:1.2; letter-spacing:.03em;
  font-size:clamp(38px,5vw,68px); margin:0; }
.hero2 .sub{ font-size:clamp(15px,1.5vw,17px); color:var(--ink-2); line-height:2; max-width:42ch; margin:24px 0 0; }
.hero2 .photo{ position:relative; border-radius:var(--radius); overflow:hidden; }
.hero2 .photo .ph{ width:100%; aspect-ratio:4/5; }
.hero2 .photo .stamp{ position:absolute; right:18px; bottom:18px; z-index:2; color:#fff;
  font-family:var(--mincho); font-weight:700; font-size:15px; background:rgba(20,18,16,.5);
  backdrop-filter:blur(4px); padding:9px 15px; border-radius:2px; }
.hero2 .photo img{ width:100%; height:100%; object-fit:cover; }

.search{ margin-top:36px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:10px; display:grid; grid-template-columns:1fr 1fr 1fr auto; gap:8px;
  box-shadow:0 10px 40px rgba(34,31,28,.07); }
.field{ position:relative; }
.field label{ position:absolute; top:10px; left:15px; font-family:var(--latin); font-size:10px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); pointer-events:none; }
.field select{ -webkit-appearance:none; appearance:none; width:100%; border:0; background:transparent;
  font-family:var(--gothic); font-size:15px; color:var(--ink); padding:28px 38px 13px 14px; cursor:pointer;
  border-radius:2px; }
.field::after{ content:""; position:absolute; right:16px; top:50%; width:8px; height:8px;
  border-right:1.5px solid var(--ink-2); border-bottom:1.5px solid var(--ink-2);
  transform:translateY(-65%) rotate(45deg); pointer-events:none; }
.field + .field{ border-left:1px solid var(--line-2); }
.search .go{ background:var(--ink); color:#fff; border:0; border-radius:2px; padding:0 30px;
  font-size:15px; font-weight:500; display:inline-flex; align-items:center; gap:10px; transition:background .2s; cursor:pointer; }
.search .go:hover{ background:var(--accent); }
.hint{ margin-top:14px; font-size:12.5px; color:var(--ink-3); display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.hint a{ color:var(--ink-2); border-bottom:1px solid var(--line); }
.hint a:hover{ color:var(--ink); border-color:var(--ink); }

.rail-sec{ padding:100px 0 0; }
.rail{ display:flex; gap:22px; overflow-x:auto; padding:4px 0 24px; scroll-snap-type:x mandatory;
  margin-inline:calc(var(--gut) * -1); padding-inline:var(--gut); }
.rail::-webkit-scrollbar{ height:0; }
.rcard{ flex:0 0 clamp(300px,30vw,388px); scroll-snap-align:start; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:transform .22s, box-shadow .22s; }
.rcard:hover{ transform:translateY(-4px); box-shadow:0 16px 44px rgba(34,31,28,.12); }
.rcard .ph{ aspect-ratio:16/10; }
.rcard .rc-body{ padding:24px 24px 26px; }
.rcard .rc-cat{ display:inline-flex; align-items:center; gap:9px; font-family:var(--latin); font-size:11px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
.rcard .rc-cat::before{ content:""; width:20px; height:1px; background:var(--accent); }
.rcard h3{ font-family:var(--mincho); font-weight:700; font-size:21px; line-height:1.5; margin:13px 0 0; }
.rcard .rc-foot{ display:flex; align-items:center; margin-top:18px; font-size:12px; color:var(--ink-3); font-family:var(--latin); }
.rcard .rc-foot .yc{ margin-left:auto; color:var(--ink-2); }
.rcard .rc-foot .yc b{ color:var(--accent); font-family:var(--mincho); font-size:15px; }
.rail-cue{ display:flex; align-items:center; gap:8px; }
.rail-cue button{ width:42px; height:42px; border-radius:50%; border:1px solid var(--line);
  background:var(--surface); color:var(--ink); display:flex; align-items:center; justify-content:center;
  transition:border-color .18s, transform .18s; cursor:pointer; }
.rail-cue button:hover{ border-color:var(--ink); transform:translateY(-1px); }

.banners{ padding:100px 0 0; }
.banner{ position:relative; display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:34px;
  padding:40px 40px; border-radius:var(--radius); overflow:hidden; color:#fff; isolation:isolate; }
.banner + .banner{ margin-top:18px; }
.banner .bg-img{ position:absolute; inset:0; z-index:-2; transition:transform .7s cubic-bezier(.2,.7,.2,1);
  width:100%; height:100%; object-fit:cover; }
.banner::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(90deg, rgba(20,18,16,.78) 0%, rgba(20,18,16,.55) 45%, rgba(20,18,16,.25) 100%); }
.banner:hover .bg-img{ transform:scale(1.05); }
.banner .b-no{ font-family:var(--mincho); font-weight:700; font-size:46px; opacity:.9; line-height:1; }
.banner .b-mid .b-en{ font-family:var(--latin); font-size:12px; letter-spacing:.16em; text-transform:uppercase; opacity:.85; }
.banner .b-mid h3{ font-family:var(--mincho); font-weight:700; font-size:clamp(24px,2.6vw,32px); margin:6px 0 6px; line-height:1.3; }
.banner .b-mid p{ font-size:13.5px; color:rgba(255,255,255,.82); margin:0; }
.banner .b-go{ flex:0 0 auto; width:54px; height:54px; border-radius:50%; border:1px solid rgba(255,255,255,.5);
  display:flex; align-items:center; justify-content:center; transition:background .2s, color .2s; }
.banner:hover .b-go{ background:#fff; color:var(--ink); }

.area{ padding:100px 0 0; }
.area-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.acell{ position:relative; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:26px 24px; display:flex; flex-direction:column; gap:6px; transition:border-color .2s, transform .2s, background .2s; overflow:hidden; }
.acell:hover{ border-color:var(--ink); transform:translateY(-3px); }
.acell .a-jp{ font-family:var(--mincho); font-weight:700; font-size:21px; }
.acell .a-en{ font-family:var(--latin); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.acell .a-n{ margin-top:14px; font-size:13px; color:var(--ink-2); }
.acell .a-n b{ font-family:var(--mincho); font-weight:700; color:var(--accent); font-size:18px; }
.acell.wide{ grid-column:span 2; background:var(--accent-soft); border-color:transparent;
  display:flex; flex-direction:row; align-items:center; justify-content:space-between; }
.acell.wide .a-jp{ font-size:22px; }

.tags2{ padding:100px 0 0; }
.tags2 .tg-row{ display:flex; flex-wrap:wrap; gap:11px; margin-top:8px; }

.latest2{ padding:100px 0 0; }
.yado-grid2{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.ycard2{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; transition:transform .22s, box-shadow .22s; }
.ycard2:hover{ transform:translateY(-5px); box-shadow:0 18px 48px rgba(34,31,28,.13); }
.ycard2 .y-img{ position:relative; aspect-ratio:1/1; overflow:hidden; }
.ycard2 .y-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.ycard2:hover .y-img img{ transform:scale(1.06); }
.ycard2 .y-genre{ position:absolute; top:12px; left:12px; z-index:2; font-family:var(--latin);
  font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:#fff; white-space:nowrap;
  background:rgba(20,18,16,.55); backdrop-filter:blur(4px); padding:4px 10px; border-radius:2px; }
.ycard2 .y-body{ padding:18px 18px 20px; }
.ycard2 .tag-area{ margin-bottom:8px; }
.ycard2 h4{ font-family:var(--mincho); font-weight:700; font-size:17px; line-height:1.5; margin:0 0 12px; }
.ycard2 .y-tags{ display:flex; flex-wrap:wrap; gap:6px; }

/* =========================================================================
   guide article (single.php)
   ========================================================================= */
.progress{ position:fixed; top:0; left:0; height:3px; width:0; background:var(--accent); z-index:60; transition:width .1s linear; }

.a-hero{ position:relative; min-height:min(78vh,680px); display:flex; align-items:flex-end; overflow:hidden; background:var(--dark); }
.a-hero .bg-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.a-hero .scrim{ position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,18,16,.25) 0%, rgba(20,18,16,.05) 35%, rgba(20,18,16,.72) 100%); }
.a-hero .inner{ position:relative; z-index:2; color:#fff; padding-bottom:54px; width:100%; }
.a-kicker{ display:inline-flex; align-items:center; gap:11px; font-family:var(--latin); font-size:12.5px;
  letter-spacing:.16em; text-transform:uppercase; color:#fff; margin-bottom:22px; }
.a-kicker::before{ content:""; width:30px; height:1px; background:var(--accent); }
.a-kicker .cat{ background:var(--accent); color:#fff; padding:5px 12px; border-radius:2px; letter-spacing:.1em; }
.a-hero h1{ font-family:var(--mincho); font-weight:800; line-height:1.32; letter-spacing:.02em;
  font-size:clamp(28px,4.4vw,56px); margin:0; max-width:20ch; text-shadow:0 2px 40px rgba(0,0,0,.3); }
.a-meta{ display:flex; flex-wrap:wrap; align-items:center; gap:10px 20px; margin-top:28px;
  font-size:13px; color:rgba(255,255,255,.85); font-family:var(--latin); letter-spacing:.03em; }
.a-meta .who{ display:inline-flex; align-items:center; gap:10px; }
.a-meta .av{ width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.2);
  border:1px solid rgba(255,255,255,.35); display:flex; align-items:center; justify-content:center;
  font-family:var(--mincho); font-size:13px; }
.a-meta .div{ width:1px; height:13px; background:rgba(255,255,255,.35); }

.a-wrap{ display:grid; grid-template-columns:1fr minmax(0,680px) 1fr; padding:60px 0 0; }
.a-wrap > *{ grid-column:2; }
.toc{ grid-column:3; position:sticky; top:98px; align-self:start; justify-self:start;
  margin-left:48px; padding-left:24px; border-left:1px solid var(--line); max-width:220px; }
.toc h5{ font-family:var(--latin); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-3); margin:0 0 16px; }
.toc a{ display:block; font-size:13px; color:var(--ink-2); line-height:1.6; padding:7px 0;
  border-bottom:1px solid var(--line-2); transition:color .18s, padding .18s; }
.toc a:last-child{ border-bottom:0; }
.toc a:hover{ color:var(--ink); padding-left:6px; }
.toc a .n{ font-family:var(--latin); color:var(--accent); margin-right:8px; }

.lead-p{ font-family:var(--mincho); font-weight:600; font-size:clamp(18px,2vw,21px); line-height:2.0;
  letter-spacing:.02em; color:var(--ink); margin:0 0 8px; }
.body p{ font-size:16px; line-height:2.1; color:var(--ink); margin:0 0 24px; }
.body h2{ font-family:var(--mincho); font-weight:700; font-size:clamp(22px,2.4vw,28px); letter-spacing:.02em;
  line-height:1.5; margin:64px 0 22px; scroll-margin-top:96px; }
.body h2 .h-no{ display:block; font-family:var(--latin); font-size:12px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--accent); margin-bottom:10px; font-weight:500; }
.body figure{ margin:34px 0; }
.body figure img,
.body figure .ph{ width:100%; aspect-ratio:16/10; border-radius:var(--radius); object-fit:cover; }
.body figcaption{ font-size:12.5px; color:var(--ink-3); margin-top:11px; line-height:1.6;
  padding-left:14px; border-left:2px solid var(--line); }

.spot{ display:grid; grid-template-columns:120px 1fr; gap:22px; align-items:center; margin:30px 0;
  padding:20px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); }
.spot img{ width:120px; height:120px; border-radius:2px; object-fit:cover; }
.spot .s-k{ font-family:var(--latin); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.spot h4{ font-family:var(--mincho); font-weight:700; font-size:18px; margin:7px 0 7px; }
.spot p{ font-size:13.5px; color:var(--ink-2); line-height:1.85; margin:0; }

.yado-embed{ margin:44px 0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  background:var(--surface); box-shadow:0 14px 50px rgba(34,31,28,.10); position:relative; }
.yado-embed .pin{ position:absolute; top:0; left:30px; z-index:3; display:inline-flex; align-items:center; gap:8px;
  background:var(--accent); color:#fff; font-family:var(--latin); font-size:11px; letter-spacing:.12em;
  text-transform:uppercase; padding:7px 14px 8px; border-radius:0 0 3px 3px; }
.ye-img{ position:relative; aspect-ratio:16/9; overflow:hidden; }
.ye-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.2,.7,.2,1); }
.yado-embed:hover .ye-img img{ transform:scale(1.04); }
.ye-img .ye-genre{ position:absolute; left:14px; bottom:14px; z-index:2; font-family:var(--latin); white-space:nowrap;
  font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:#fff; background:rgba(20,18,16,.55);
  backdrop-filter:blur(4px); padding:5px 11px; border-radius:2px; }
.ye-body{ padding:26px 30px 28px; }
.ye-area{ display:inline-flex; align-items:center; gap:7px; font-family:var(--latin); font-size:12px;
  letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2); }
.ye-area::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--accent); }
.ye-body h3{ font-family:var(--mincho); font-weight:800; font-size:25px; line-height:1.45; margin:11px 0 0; }
.ye-body h3 a{ background:linear-gradient(transparent 88%, var(--accent-soft) 0); }
.ye-desc{ font-size:14.5px; line-height:1.95; color:var(--ink-2); margin:14px 0 0; }
.ye-tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
.ye-foot{ display:flex; align-items:center; gap:20px; margin-top:24px; padding-top:22px; border-top:1px solid var(--line-2); flex-wrap:wrap; }
.ye-price{ display:flex; align-items:baseline; gap:7px; }
.ye-price .from{ font-size:12px; color:var(--ink-3); }
.ye-price .num{ font-family:var(--mincho); font-weight:800; font-size:27px; color:var(--ink); }
.ye-price .unit{ font-size:12.5px; color:var(--ink-2); }
.ye-cta{ margin-left:auto; display:flex; gap:10px; flex-wrap:wrap; }
.ye-cta .detail{ display:inline-flex; align-items:center; gap:8px; padding:13px 20px; border:1px solid var(--line);
  border-radius:var(--radius); font-size:14px; color:var(--ink); transition:border-color .18s, transform .18s; }
.ye-cta .detail:hover{ border-color:var(--ink); transform:translateY(-2px); }
.ye-cta .book{ display:inline-flex; align-items:center; gap:9px; padding:13px 24px; border-radius:var(--radius);
  background:var(--accent); color:#fff; font-size:14px; font-weight:500; transition:background .18s, transform .18s; }
.ye-cta .book:hover{ background:var(--accent-deep); transform:translateY(-2px); }
.ye-cta .book .arr{ transition:transform .2s; } .ye-cta .book:hover .arr{ transform:translateX(3px); }
.ye-pr{ font-size:11px; color:var(--ink-3); margin-top:14px; display:flex; align-items:center; gap:6px; }

.pull{ margin:46px 0; padding:6px 0 6px 30px; border-left:3px solid var(--accent); }
.pull p{ font-family:var(--mincho); font-weight:600; font-size:clamp(20px,2.3vw,26px); line-height:1.75;
  letter-spacing:.02em; color:var(--ink); margin:0; }

.a-summary{ padding:80px 0 0; background:var(--paper-2); margin-top:80px; }
.sum-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:30px; }
.scard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:transform .2s, box-shadow .2s; }
.scard:hover{ transform:translateY(-4px); box-shadow:0 14px 38px rgba(34,31,28,.11); }
.scard img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
.scard .sc-b{ padding:16px 17px 18px; }
.scard .sc-a{ font-family:var(--latin); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.scard h4{ font-family:var(--mincho); font-weight:700; font-size:16px; line-height:1.5; margin:7px 0 10px; }
.scard .sc-p{ font-size:12px; color:var(--ink-2); }
.scard .sc-p b{ font-family:var(--mincho); font-size:15px; color:var(--ink); }

.author{ display:flex; gap:20px; align-items:flex-start; margin:64px 0 0; padding:30px;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); }
.author .av{ width:58px; height:58px; border-radius:50%; flex:0 0 auto; background:var(--paper-2);
  border:1px solid var(--line); display:flex; align-items:center; justify-content:center;
  font-family:var(--mincho); font-weight:700; font-size:22px; color:var(--ink); overflow:hidden; }
.author .av img{ width:100%; height:100%; object-fit:cover; }
.author .au-name{ font-family:var(--mincho); font-weight:700; font-size:16px; }
.author .au-role{ font-family:var(--latin); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin:3px 0 10px; }
.author p{ font-size:13.5px; color:var(--ink-2); line-height:1.85; margin:0; }

.rel-feat{ padding:90px 0 0; }
.rf-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.rfcard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:transform .2s, box-shadow .2s; }
.rfcard:hover{ transform:translateY(-4px); box-shadow:0 14px 38px rgba(34,31,28,.11); }
.rfcard img{ width:100%; aspect-ratio:16/10; object-fit:cover; }
.rfcard .rf-b{ padding:20px 22px 24px; }
.rfcard .rf-c{ font-family:var(--latin); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.rfcard h4{ font-family:var(--mincho); font-weight:700; font-size:17px; line-height:1.55; margin:10px 0 0; }

/* =========================================================================
   single-yado (yado detail)
   ========================================================================= */
.breadcrumb{ padding:22px 0 0; font-size:12.5px; color:var(--ink-3); display:flex; gap:9px; flex-wrap:wrap;
  font-family:var(--latin); letter-spacing:.03em; }
.breadcrumb a{ color:var(--ink-2); } .breadcrumb a:hover{ color:var(--ink); }
.breadcrumb .sep{ opacity:.5; }

.y-head{ padding:26px 0 30px; }
.y-genre-lab{ display:inline-flex; align-items:center; gap:9px; font-family:var(--latin); font-size:12px;
  letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.y-genre-lab::before{ content:""; width:24px; height:1px; background:var(--accent); }
.y-head h1{ font-family:var(--mincho); font-weight:800; font-size:clamp(30px,4vw,50px); line-height:1.3;
  letter-spacing:.02em; margin:16px 0 0; }
.y-sub{ display:flex; flex-wrap:wrap; align-items:center; gap:10px 22px; margin-top:18px; font-size:14px; color:var(--ink-2); }
.y-sub .area{ display:inline-flex; align-items:center; gap:7px; }
.y-sub .area::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--accent); }
.y-sub .div{ width:1px; height:14px; background:var(--line); }

.gallery{ display:grid; grid-template-columns:1fr 168px; gap:12px; }
.gallery .main{ position:relative; border-radius:var(--radius); overflow:hidden; }
.gallery .main img{ width:100%; aspect-ratio:16/10; object-fit:cover; display:block; }
.gallery .thumbs{ display:grid; grid-template-rows:repeat(4,1fr); gap:12px; }
.gallery .thumbs .t{ position:relative; border-radius:var(--radius); overflow:hidden; cursor:pointer;
  border:1px solid var(--line); }
.gallery .thumbs .t img{ width:100%; aspect-ratio:16/11; object-fit:cover; display:block; }
.gallery .thumbs .t.active{ outline:2px solid var(--accent); outline-offset:-2px; }
.gallery .thumbs .more{ position:absolute; inset:0; background:rgba(20,18,16,.55); color:#fff;
  display:flex; align-items:center; justify-content:center; font-family:var(--latin); font-size:14px; letter-spacing:.05em; }

.y-main{ display:grid; grid-template-columns:1fr 360px; gap:56px; padding:72px 0 0; align-items:start; }
.prose h2{ font-family:var(--mincho); font-weight:700; font-size:24px; letter-spacing:.02em; margin:0 0 18px; padding-top:8px; }
.prose section + section{ margin-top:56px; padding-top:56px; border-top:1px solid var(--line-2); }
.prose p{ font-size:15.5px; line-height:2.05; color:var(--ink); margin:0 0 18px; }
.prose p.lead{ font-size:17px; line-height:2.1; }

.facts{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.facts dl{ margin:0; background:var(--surface); padding:18px 22px; display:flex; flex-direction:column; gap:5px; }
.facts dt{ font-family:var(--latin); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.facts dd{ margin:0; font-size:15px; color:var(--ink); font-weight:500; }
.facts dd .mini{ font-size:12.5px; color:var(--ink-2); font-weight:400; }

.y-taglist{ display:flex; flex-wrap:wrap; gap:10px; }

.route{ list-style:none; margin:0; padding:0; }
.route li{ position:relative; padding:0 0 28px 40px; }
.route li::before{ content:""; position:absolute; left:11px; top:6px; width:1px; bottom:-6px; background:var(--line); }
.route li:last-child{ padding-bottom:0; } .route li:last-child::before{ display:none; }
.route li .dot{ position:absolute; left:4px; top:3px; width:16px; height:16px; border-radius:50%;
  border:2px solid var(--accent); background:var(--paper); }
.route .step-k{ font-family:var(--latin); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
.route h4{ font-family:var(--mincho); font-weight:700; font-size:17px; margin:5px 0 4px; }
.route p{ font-size:13.5px; color:var(--ink-2); line-height:1.8; margin:0; }

.feat-link{ display:grid; grid-template-columns:200px 1fr; gap:0; border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden; background:var(--surface); transition:transform .2s, box-shadow .2s; }
.feat-link:hover{ transform:translateY(-3px); box-shadow:0 14px 38px rgba(34,31,28,.11); }
.feat-link img{ height:100%; min-height:130px; width:200px; object-fit:cover; }
.feat-link .fl-body{ padding:24px 26px; }
.feat-link .fl-k{ font-family:var(--latin); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
.feat-link h4{ font-family:var(--mincho); font-weight:700; font-size:19px; line-height:1.5; margin:9px 0 8px; }
.feat-link .fl-go{ font-size:13px; color:var(--ink-2); display:inline-flex; align-items:center; gap:8px; }

.booking{ position:sticky; top:98px; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:28px 26px; box-shadow:0 12px 44px rgba(34,31,28,.08); }
.booking .price{ display:flex; align-items:baseline; gap:8px; }
.booking .price .from{ font-size:12.5px; color:var(--ink-3); }
.booking .price .num{ font-family:var(--mincho); font-weight:800; font-size:34px; color:var(--ink); letter-spacing:.01em; }
.booking .price .unit{ font-size:13px; color:var(--ink-2); }
.booking .micro{ font-size:12px; color:var(--ink-3); margin:6px 0 22px; }
.book-row{ display:flex; flex-direction:column; gap:10px; }
.book-btn{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:15px 18px;
  border-radius:var(--radius); border:1px solid var(--line); background:var(--paper);
  transition:border-color .18s, transform .18s, background .18s; }
.book-btn:hover{ border-color:var(--ink); transform:translateY(-2px); }
.book-btn.primary{ background:var(--ink); border-color:var(--ink); color:#fff; }
.book-btn.primary:hover{ background:var(--accent); border-color:var(--accent); }
.book-btn .b-l{ display:flex; flex-direction:column; gap:2px; }
.book-btn .b-svc{ font-family:var(--latin); font-size:11px; letter-spacing:.08em; text-transform:uppercase; opacity:.7; }
.book-btn .b-act{ font-size:15px; font-weight:500; }
.book-btn .arr{ transition:transform .2s; } .book-btn:hover .arr{ transform:translateX(3px); }
.booking .ext{ display:flex; align-items:center; gap:7px; font-size:11px; color:var(--ink-3); margin-top:16px; justify-content:center; }
.booking .save{ width:100%; margin-top:14px; padding:13px; border:1px dashed var(--line); border-radius:var(--radius);
  background:transparent; color:var(--ink-2); font-size:13px; display:flex; align-items:center; justify-content:center; gap:9px;
  transition:border-color .18s, color .18s; cursor:pointer; }
.booking .save:hover{ border-color:var(--ink); color:var(--ink); }
.booking .qa{ margin-top:22px; padding-top:20px; border-top:1px solid var(--line-2); display:flex; flex-direction:column; gap:11px; }
.booking .qa div{ display:flex; justify-content:space-between; font-size:13px; }
.booking .qa span:first-child{ color:var(--ink-3); } .booking .qa span:last-child{ color:var(--ink); font-weight:500; }

.related{ padding:104px 0 0; }
.rel-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

.book-bar{ display:none; }

/* =========================================================================
   archive-yado
   ========================================================================= */
.arc-head{ padding:30px 0 0; }
.arc-title{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; padding:22px 0 30px; flex-wrap:wrap; }
.arc-title .eyebrow{ margin-bottom:12px; }
.arc-title h1{ font-family:var(--mincho); font-weight:800; font-size:clamp(30px,4vw,48px); letter-spacing:.02em; line-height:1.25; margin:0; }
.arc-title .count{ font-family:var(--latin); font-size:14px; color:var(--ink-2); letter-spacing:.03em; white-space:nowrap; }
.arc-title .count b{ font-family:var(--mincho); font-weight:700; font-size:24px; color:var(--accent); }

.genre-tabs{ display:flex; gap:8px; flex-wrap:wrap; padding:0 0 26px; border-bottom:1px solid var(--line); margin-bottom:30px; }
.gtab{ display:inline-flex; align-items:center; gap:9px; padding:11px 20px; border-radius:999px;
  border:1px solid var(--line); background:var(--surface); font-size:14px; color:var(--ink-2);
  transition:border-color .18s, color .18s, background .18s; }
.gtab:hover{ border-color:var(--ink); color:var(--ink); }
.gtab.active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.gtab .n{ font-family:var(--latin); font-size:11px; opacity:.6; }
.gtab.active .n{ opacity:.7; }

.arc-layout{ display:grid; grid-template-columns:248px 1fr; gap:44px; align-items:start; padding-bottom:40px; }

.filters{ position:sticky; top:98px; }
.fgroup{ padding:0 0 22px; margin-bottom:22px; border-bottom:1px solid var(--line-2); }
.fgroup:last-child{ border-bottom:0; }
.fgroup h4{ font-family:var(--mincho); font-weight:700; font-size:15px; margin:0 0 14px;
  display:flex; align-items:center; justify-content:space-between; }
.fgroup h4 .cnt{ font-family:var(--latin); font-size:11px; color:var(--ink-3); font-weight:400; }
.check{ display:flex; align-items:center; gap:11px; padding:7px 0; cursor:pointer; font-size:13.5px; color:var(--ink-2); }
.check input{ position:absolute; opacity:0; pointer-events:none; }
.check .box{ width:17px; height:17px; border:1.5px solid var(--line); border-radius:3px; flex:0 0 auto;
  display:flex; align-items:center; justify-content:center; transition:border-color .15s, background .15s; }
.check .box svg{ opacity:0; transform:scale(.6); transition:opacity .15s, transform .15s; }
.check input:checked + .box{ background:var(--accent); border-color:var(--accent); }
.check input:checked + .box svg{ opacity:1; transform:scale(1); }
.check:hover{ color:var(--ink); }
.check .ct{ margin-left:auto; font-family:var(--latin); font-size:11px; color:var(--ink-3); }
.fclear{ width:100%; margin-top:6px; padding:11px; background:transparent; border:1px solid var(--line);
  border-radius:var(--radius); font-size:13px; color:var(--ink-2); transition:border-color .18s, color .18s; cursor:pointer; }
.fclear:hover{ border-color:var(--ink); color:var(--ink); }

.sortbar{ display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
.sortbar .showing{ font-size:13px; color:var(--ink-3); }
.sortbar .showing b{ color:var(--ink); font-weight:500; }
.sortsel{ display:inline-flex; align-items:center; gap:9px; font-size:13.5px; color:var(--ink-2); }
.sortsel select{ -webkit-appearance:none; appearance:none; border:1px solid var(--line); background:var(--surface);
  font-family:var(--gothic); font-size:13.5px; color:var(--ink); padding:9px 34px 9px 14px; border-radius:var(--radius); cursor:pointer; }

.arc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px 22px; }
.ycard{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:transform .22s, box-shadow .22s; display:flex; flex-direction:column; }
.ycard:hover{ transform:translateY(-5px); box-shadow:0 18px 48px rgba(34,31,28,.13); }
.ycard .y-img{ position:relative; overflow:hidden; }
.ycard .y-img img{ width:100%; aspect-ratio:16/11; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); display:block; }
.ycard:hover .y-img img{ transform:scale(1.06); }
.ycard .y-genre{ position:absolute; top:13px; left:13px; z-index:2; font-family:var(--latin); white-space:nowrap;
  font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:#fff; background:rgba(20,18,16,.55);
  backdrop-filter:blur(4px); padding:5px 11px; border-radius:2px; }
.ycard .fav{ position:absolute; top:11px; right:11px; z-index:2; width:34px; height:34px; border-radius:50%;
  background:rgba(251,250,246,.9); border:0; display:flex; align-items:center; justify-content:center;
  color:var(--ink-2); transition:color .18s, transform .18s; cursor:pointer; }
.ycard .fav:hover{ color:var(--accent); transform:scale(1.1); }
.ycard .y-body{ padding:20px 22px 22px; flex:1; display:flex; flex-direction:column; }
.ycard .tag-area{ margin-bottom:9px; }
.ycard h3{ font-family:var(--mincho); font-weight:700; font-size:20px; line-height:1.5; margin:0 0 12px; }
.ycard h3 a:hover{ color:var(--accent); }
.ycard .y-tags{ display:flex; flex-wrap:wrap; gap:7px; margin-bottom:18px; }
.ycard .y-foot{ display:flex; align-items:baseline; justify-content:space-between; margin-top:auto;
  padding-top:16px; border-top:1px solid var(--line-2); }
.ycard .y-price .num{ font-family:var(--mincho); font-weight:700; font-size:21px; color:var(--ink); }
.ycard .y-price .unit{ font-size:12px; color:var(--ink-2); }
.ycard .y-cap{ font-size:12px; color:var(--ink-3); }

.pager{ display:flex; align-items:center; justify-content:center; gap:8px; margin-top:54px; }
.pager a,
.pager span{ min-width:42px; height:42px; padding:0 10px; border-radius:var(--radius); border:1px solid var(--line);
  background:var(--surface); display:inline-flex; align-items:center; justify-content:center; font-family:var(--latin);
  font-size:14px; color:var(--ink-2); transition:border-color .18s, color .18s, background .18s; }
.pager a:hover{ border-color:var(--ink); color:var(--ink); }
.pager .current{ background:var(--ink); color:#fff; border-color:var(--ink); }

.mfilter{ display:none; }
.filters .fclose{ display:none; }

/* =========================================================================
   responsive
   ========================================================================= */
@media (max-width:1080px){
  .a-wrap{ grid-template-columns:1fr minmax(0,680px) 1fr; }
  .toc{ display:none; }
}

@media (max-width:980px){
  :root{ --gut:20px; }
  .nav{ display:none; }
  .burger{ display:flex; }
  .site-foot .inner{ grid-template-columns:1fr 1fr; gap:36px 24px; padding:56px 0 40px; }
  .foot-brand{ grid-column:1 / -1; }
  .sec-head{ flex-direction:column; align-items:flex-start; gap:14px; }

  /* front-page */
  .hero2-grid{ grid-template-columns:1fr; gap:36px; }
  .hero2 .photo{ order:-1; }
  .hero2 .photo .ph{ aspect-ratio:16/10; }
  .area-grid{ grid-template-columns:repeat(2,1fr); }
  .yado-grid2{ grid-template-columns:repeat(2,1fr); }
  .acell.wide{ grid-column:span 2; }

  /* single-yado */
  .y-main{ grid-template-columns:1fr; gap:0; }
  .booking{ position:static; margin-top:56px; }
  .rel-grid{ grid-template-columns:repeat(2,1fr); }

  /* archive */
  .arc-layout{ grid-template-columns:1fr; gap:0; }
  .filters{ position:fixed; inset:0; z-index:65; background:var(--paper); padding:24px var(--gut);
    overflow-y:auto; transform:translateX(-100%); transition:transform .3s; }
  .filters.open{ transform:translateX(0); }
  .filters .fclose{ display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
  .mfilter{ display:inline-flex; align-items:center; gap:9px; padding:11px 18px; border:1px solid var(--ink);
    border-radius:var(--radius); background:var(--surface); font-size:13.5px; color:var(--ink); cursor:pointer; }
  .arc-grid{ grid-template-columns:repeat(2,1fr); }

  /* guide */
  .a-wrap{ display:block; }
  .a-wrap > *{ padding-inline:var(--gut); max-width:680px; margin-inline:auto; }
  .rf-grid{ grid-template-columns:1fr; }
}

@media (max-width:760px){
  .ye-foot{ gap:14px; } .ye-cta{ margin-left:0; width:100%; }
  .ye-cta .book, .ye-cta .detail{ flex:1; justify-content:center; }
  .spot{ grid-template-columns:1fr; } .spot img{ width:100%; height:180px; }
  .sum-grid{ grid-template-columns:repeat(2,1fr); }
}

@media (max-width:600px){
  :root{ --gut:16px; }
  /* front-page */
  .search{ grid-template-columns:1fr 1fr; }
  .search .go{ grid-column:1 / -1; padding:15px; }
  .field:nth-child(2){ border-left:0; }
  .banner{ grid-template-columns:auto 1fr; padding:28px 24px; gap:20px; }
  .banner .b-go{ display:none; }
  .area-grid{ grid-template-columns:1fr 1fr; }
  .acell.wide{ grid-column:1 / -1; }
  /* single-yado */
  .gallery{ grid-template-columns:1fr; }
  .gallery .thumbs{ grid-template-rows:none; grid-template-columns:repeat(4,1fr); }
  .facts{ grid-template-columns:1fr; }
  .feat-link{ grid-template-columns:1fr; } .feat-link img{ min-height:160px; width:100%; }
  .rel-grid{ grid-template-columns:1fr; }
  /* book-bar */
  .book-bar{ display:flex; position:fixed; left:0; right:0; bottom:0; z-index:55; align-items:center;
    gap:14px; padding:12px 16px; background:color-mix(in srgb,var(--surface) 94%, transparent);
    backdrop-filter:blur(12px); border-top:1px solid var(--line); }
  .book-bar .bb-p{ flex:1; } .book-bar .bb-p b{ font-family:var(--mincho); font-size:20px; }
  .book-bar .bb-p span{ font-size:11px; color:var(--ink-3); display:block; }
  .book-bar .btn{ padding:13px 22px; }
  body.single-yado{ padding-bottom:74px; }
  /* archive */
  .arc-grid{ grid-template-columns:1fr; }
  /* guide */
  .sum-grid{ grid-template-columns:1fr; }
  .site-foot .inner{ grid-template-columns:1fr; }
}

@media (max-width:520px){
  .site-foot .inner{ grid-template-columns:1fr; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}
