/* =========================================================================
   udatsu theme — 美濃で挑戦する暮らし
   デザイン「藍 × 山吹」を1色固定で実装
   ========================================================================= */

:root{
  --ink:#1C2433; --ink-soft:#4F586B; --ink-mute:#97A0B0; --line:#E8E4DB;
  --bg:#FAF7F1; --mist:#F1EEE7; --tint:#E7E9F2;
  --brand:#2A3C6B; --brand-deep:#1E2C52;
  --hero-bg:#1A2742; --hero-bg2:#27345A;
  --accent:#E8A33A; --accent-deep:#CC8620; --accent-soft:#FAEFD7; --on-accent:#1C2433;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Zen Kaku Gothic New',sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  line-height:1.7;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }

@keyframes udLine{ from{transform:scaleX(0)} to{transform:scaleX(1)} }

/* ---- layout helpers ---- */
.ud-container{ width:100%; max-width:1180px; margin:0 auto; padding:0 32px; }
.ud-container--760{ max-width:760px; }
.ud-container--820{ max-width:820px; }
.ud-section{ padding:88px 0; }
.ud-eyebrow{ font-family:'Poppins',sans-serif; font-weight:600; font-size:12.5px; letter-spacing:.08em; color:var(--accent-deep); }
.ud-h2{ font-size:34px; line-height:1.4; font-weight:700; margin:12px 0 0; }
.ud-tag{ font-size:13px; font-weight:600; color:var(--brand-deep); background:var(--tint); padding:8px 15px; border-radius:999px; }
.ud-tag--accent{ color:var(--accent-deep); background:var(--accent-soft); }
.ud-hide-m{ display:block; }
.ud-show-m{ display:none; }

/* ---- buttons ---- */
.ud-btn{ display:inline-flex; align-items:center; gap:9px; text-decoration:none; border-radius:999px; font-weight:700; white-space:nowrap; cursor:pointer; border:none; transition:transform .2s cubic-bezier(.22,1,.36,1),border-color .2s,box-shadow .2s; }
.ud-btn--brand{ background:var(--brand); color:#fff; font-size:13.5px; padding:11px 20px; box-shadow:0 6px 16px rgba(42,60,107,.24); }
.ud-btn--brand:hover{ transform:translateY(-1px); }
.ud-btn--accent{ background:var(--accent); color:var(--on-accent); font-size:16px; padding:16px 30px; box-shadow:0 12px 26px rgba(0,0,0,.28); }
.ud-btn--accent:hover{ transform:translateY(-2px); }
.ud-btn--ghost{ background:transparent; color:#fff; font-size:16px; padding:16px 28px; border:1.5px solid rgba(255,255,255,.4); }
.ud-btn--ghost:hover{ border-color:#fff; }

/* =========================================================================
   Header
   ========================================================================= */
.ud-header{ position:sticky; top:0; z-index:50; background:rgba(250,247,241,0.82); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); }
.ud-header__inner{ height:74px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.ud-logo{ text-decoration:none; display:flex; flex-direction:column; line-height:1; }
.ud-logo__name{ font-family:'Poppins',sans-serif; font-weight:700; font-size:25px; letter-spacing:-0.01em; color:var(--ink); }
.ud-logo__name .dot{ color:var(--accent); }
.ud-logo__underline{ display:block; width:100%; height:3px; margin-top:3px; border-radius:2px; background:var(--accent); transform-origin:left; animation:udLine .6s cubic-bezier(.22,1,.36,1) both; }
.ud-logo__sub{ font-size:10.5px; color:var(--ink-mute); margin-top:5px; letter-spacing:.14em; }
.ud-logo__img{ max-height:48px; width:auto; }
.ud-nav{ display:flex; align-items:center; gap:30px; }
.ud-nav__link{ text-decoration:none; color:var(--ink-soft); font-size:14px; font-weight:500; white-space:nowrap; transition:color .2s; }
.ud-nav__link:hover{ color:var(--brand-deep); }
.ud-burger{ display:none; background:none; border:none; cursor:pointer; padding:8px; flex-direction:column; gap:5px; }
.ud-burger span{ display:block; width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.25s; }

/* =========================================================================
   Hero
   ========================================================================= */
.ud-hero{ background:var(--hero-bg); color:#fff; position:relative; overflow:hidden; }
.ud-hero__photo-m{ display:none; position:absolute; inset:0; z-index:0; }
.ud-hero__photo-m img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ud-hero__photo-m::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(13,19,32,.72) 0%,rgba(13,19,32,.4) 44%,rgba(13,19,32,.84) 100%); }
.ud-hero__glow1{ position:absolute; right:-120px; top:-90px; width:430px; height:430px; border-radius:50%; background:rgba(232,163,58,.13); filter:blur(6px); }
.ud-hero__glow2{ position:absolute; left:-90px; bottom:-130px; width:340px; height:340px; border-radius:50%; background:rgba(255,255,255,.05); }
.ud-hero__wrap{ position:relative; padding-top:74px; }
.ud-hero__grid{ display:grid; grid-template-columns:1.08fr 0.92fr; gap:52px; align-items:center; min-height:520px; }
.ud-hero__badge{ display:inline-flex; align-items:center; gap:9px; font-family:'Poppins',sans-serif; font-weight:600; font-size:12.5px; letter-spacing:.05em; color:var(--on-accent); background:var(--accent); padding:7px 15px; border-radius:999px; white-space:nowrap; }
.ud-hero__title{ font-size:clamp(40px,8.2vw,66px); line-height:1.16; letter-spacing:.01em; font-weight:700; margin:24px 0 0; color:#fff; }
.ud-hero__mark{ position:relative; white-space:nowrap; }
.ud-hero__mark::after{ content:""; position:absolute; left:2px; right:2px; bottom:4px; height:12px; background:var(--accent); opacity:.55; z-index:0; border-radius:3px; }
.ud-hero__mark span{ position:relative; z-index:1; }
.ud-hero__sub{ font-size:16.5px; line-height:1.95; color:rgba(255,255,255,.8); margin:26px 0 0; max-width:480px; }
.ud-hero__actions{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.ud-hero__visual{ position:relative; height:450px; }
.ud-hero__card{ position:absolute; border-radius:20px; overflow:hidden; }
.ud-hero__card img{ width:100%; height:100%; object-fit:cover; }
.ud-hero__card--a{ right:18px; top:14px; width:236px; height:312px; transform:rotate(4.5deg); box-shadow:0 26px 54px rgba(0,0,0,.4); }
.ud-hero__card--b{ left:0; top:78px; width:248px; height:322px; transform:rotate(-4deg); box-shadow:0 26px 54px rgba(0,0,0,.38); }
.ud-hero__chip{ position:absolute; left:-14px; bottom:6px; background:#fff; border-radius:14px; padding:13px 16px; box-shadow:0 14px 30px rgba(0,0,0,.22); display:flex; align-items:center; gap:11px; }
.ud-hero__chip-ico{ width:38px; height:38px; border-radius:11px; background:var(--accent-soft); display:flex; align-items:center; justify-content:center; color:var(--accent-deep); font-family:'Poppins'; font-weight:700; }
.ud-hero__chip-t1{ font-size:12.5px; font-weight:700; color:var(--ink); }
.ud-hero__chip-t2{ font-size:11px; color:var(--ink-mute); margin-top:1px; }
.ud-hero__show-m{ display:none; position:relative; margin-top:30px; }

/* stats band */
.ud-stats{ margin:30px 0 40px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.13); border-radius:20px; display:grid; grid-template-columns:repeat(4,1fr); position:relative; }
.ud-stats__item{ text-align:center; padding:24px 12px; border-right:1px solid rgba(255,255,255,.1); }
.ud-stats__item:last-child{ border-right:none; }
.ud-stats__num{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:34px; color:var(--accent); }
.ud-stats__unit{ font-size:17px; color:#fff; margin-left:3px; }
.ud-stats__label{ font-size:12.5px; color:rgba(255,255,255,.62); margin-top:4px; }

/* =========================================================================
   美濃のこと
   ========================================================================= */
.ud-mino__grid{ display:grid; grid-template-columns:0.95fr 1.05fr; gap:56px; align-items:center; }
.ud-mino__body{ font-size:15px; line-height:2.1; color:var(--ink-soft); margin:22px 0 0; }
.ud-mino__tags{ display:flex; gap:10px; flex-wrap:wrap; margin-top:24px; }
.ud-mino__media{ position:relative; }
.ud-mino__media-img{ aspect-ratio:5/4; border-radius:22px; overflow:hidden; box-shadow:0 18px 40px rgba(28,36,51,.12); }
.ud-mino__media-img img{ width:100%; height:100%; object-fit:cover; }
.ud-mino__badge{ position:absolute; left:-18px; bottom:-18px; background:#fff; border-radius:16px; padding:16px 20px; box-shadow:0 14px 30px rgba(28,36,51,.14); }
.ud-mino__badge-t1{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:15px; color:var(--ink); }
.ud-mino__badge-t2{ font-size:12px; color:var(--ink-mute); margin-top:3px; }
.ud-mino__cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:56px; }
.ud-feature-card{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:22px; }
.ud-feature-card__title{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:16px; color:var(--brand-deep); }
.ud-feature-card__body{ font-size:12.5px; line-height:1.9; color:var(--ink-soft); margin:8px 0 0; }

/* =========================================================================
   募集中の物件
   ========================================================================= */
.ud-bukken{ background:var(--mist); }
.ud-bukken__head{ display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.ud-bukken__lead{ font-size:14.5px; color:var(--ink-soft); margin:10px 0 0; }
.ud-filter{ display:flex; gap:8px; flex-wrap:wrap; }
.ud-filter__btn{ font-size:13px; font-weight:500; color:var(--ink-soft); background:#fff; border:1px solid var(--line); padding:8px 16px; border-radius:999px; cursor:pointer; transition:.2s; }
.ud-filter__btn.is-active{ font-weight:700; color:#fff; background:var(--brand); border-color:var(--brand); }

.ud-pickup-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:32px; }
.ud-prop-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:18px; }

/* card shared */
.ud-card{ position:relative; display:flex; flex-direction:column; justify-content:flex-end; border-radius:22px; overflow:hidden; text-decoration:none; box-shadow:0 6px 20px rgba(28,36,51,.1); transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s; }
.ud-card:hover{ transform:translateY(-5px); box-shadow:0 24px 46px rgba(28,36,51,.2); }
.ud-card__bg{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .6s cubic-bezier(.22,1,.36,1); }
.ud-card:hover .ud-card__bg{ transform:scale(1.06); }
.ud-card__overlay{ position:absolute; inset:0; }
.ud-card__body{ position:relative; }

/* big PICK UP card */
.ud-pick-card{ aspect-ratio:16/10; }
.ud-pick-card .ud-card__overlay{ background:linear-gradient(to top,rgba(13,19,32,.92),rgba(13,19,32,.4) 48%,rgba(13,19,32,.04)); }
.ud-pick-card__badges{ position:absolute; top:16px; left:16px; display:flex; align-items:center; gap:8px; }
.ud-pick-card__pick{ font-family:'Poppins',sans-serif; font-weight:700; font-size:11px; letter-spacing:.06em; color:var(--on-accent); background:var(--accent); padding:5px 11px; border-radius:999px; }
.ud-pick-card__no{ font-family:'Poppins',sans-serif; font-weight:700; font-size:12px; color:#fff; background:rgba(255,255,255,.18); padding:5px 10px; border-radius:999px; }
.ud-pick-card__body{ padding:26px; }
.ud-pick-card__use{ display:inline-block; font-size:11.5px; font-weight:700; color:var(--on-accent); background:var(--accent); padding:5px 12px; border-radius:999px; }
.ud-pick-card__name{ font-size:25px; font-weight:700; color:#fff; margin:12px 0 0; }
.ud-pick-card__meta{ font-size:13px; color:rgba(255,255,255,.78); margin-top:6px; }
.ud-pick-card__feats{ display:flex; gap:7px; flex-wrap:wrap; margin-top:14px; }
.ud-pick-card__feat{ font-size:11.5px; font-weight:600; color:#fff; background:rgba(255,255,255,.16); padding:5px 11px; border-radius:999px; }
.ud-pick-card__foot{ display:flex; align-items:center; justify-content:space-between; margin-top:18px; }
.ud-pick-card__rent{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:24px; color:#fff; }
.ud-pick-card__permo{ font-size:12.5px; color:rgba(255,255,255,.7); }
.ud-pick-card__cta{ display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:700; color:var(--on-accent); background:var(--accent); padding:9px 16px; border-radius:999px; }

/* small property card */
.ud-prop-card{ aspect-ratio:3/4; border-radius:18px; box-shadow:0 4px 14px rgba(28,36,51,.08); }
.ud-prop-card:hover{ transform:translateY(-4px); box-shadow:0 18px 36px rgba(28,36,51,.16); }
.ud-prop-card .ud-card__overlay{ background:linear-gradient(to top,rgba(13,19,32,.9),rgba(13,19,32,.22) 55%,transparent); }
.ud-prop-card__tag{ position:absolute; top:12px; left:12px; font-size:11px; font-weight:700; color:var(--brand-deep); background:rgba(255,255,255,.94); padding:5px 10px; border-radius:999px; white-space:nowrap; }
.ud-prop-card__no{ position:absolute; top:14px; right:14px; font-family:'Poppins',sans-serif; font-weight:700; font-size:11px; color:#fff; opacity:.85; }
.ud-prop-card__body{ padding:18px; }
.ud-prop-card__use{ font-size:10.5px; font-weight:600; color:rgba(255,255,255,.85); }
.ud-prop-card__name{ font-size:16px; font-weight:700; color:#fff; margin:5px 0 0; line-height:1.4; }
.ud-prop-card__foot{ display:flex; align-items:baseline; justify-content:space-between; margin-top:12px; }
.ud-prop-card__rent{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:17px; color:#fff; }
.ud-prop-card__permo{ font-size:11px; color:rgba(255,255,255,.7); }
.ud-prop-card__arrow{ font-size:13px; font-weight:700; color:#fff; }

/* =========================================================================
   入居者ストーリー
   ========================================================================= */
.ud-stories__head{ display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.ud-stories__lead{ font-size:14.5px; color:var(--ink-soft); margin:14px 0 0; max-width:540px; line-height:1.9; }
.ud-link-accent{ text-decoration:none; color:var(--accent-deep); font-size:14px; font-weight:700; white-space:nowrap; transition:color .2s; }
.ud-link-accent:hover{ color:var(--brand-deep); }
.ud-stories__list{ display:flex; flex-direction:column; margin-top:24px; }
.ud-story-row{ display:grid; grid-template-columns:1.02fr 0.98fr; gap:56px; align-items:center; padding:48px 0; border-top:1px solid var(--line); text-decoration:none; }
.ud-story__img{ position:relative; aspect-ratio:5/4; border-radius:24px; overflow:hidden; box-shadow:0 18px 40px rgba(28,36,51,.13); }
.ud-story__img-bg{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .6s cubic-bezier(.22,1,.36,1); }
.ud-story-row:hover .ud-story__img-bg{ transform:scale(1.05); }
.ud-story__no{ position:absolute; top:18px; left:18px; font-family:'Poppins',sans-serif; font-weight:700; font-size:13px; color:#fff; letter-spacing:.06em; background:rgba(28,36,51,.42); backdrop-filter:blur(4px); padding:6px 13px; border-radius:999px; }
.ud-story__theme{ position:absolute; left:18px; bottom:18px; display:inline-flex; align-items:center; gap:7px; white-space:nowrap; font-size:12px; font-weight:700; color:var(--ink); background:rgba(255,255,255,.94); padding:7px 14px; border-radius:999px; }
.ud-story__role{ font-size:12.5px; font-weight:700; color:var(--accent-deep); letter-spacing:.02em; }
.ud-story__quote-wrap{ position:relative; margin-top:14px; }
.ud-story__quote-mark{ position:absolute; left:-6px; top:-26px; font-family:'Zen Maru Gothic',serif; font-size:64px; line-height:1; color:var(--accent); opacity:.4; }
.ud-story__quote{ position:relative; margin:0; font-family:'Zen Maru Gothic',sans-serif; font-weight:700; font-size:27px; line-height:1.6; letter-spacing:.01em; color:var(--ink); white-space:pre-line; }
.ud-story__body{ font-size:14.5px; line-height:2; color:var(--ink-soft); margin:20px 0 0; max-width:440px; }
.ud-story__meta{ display:flex; align-items:center; justify-content:space-between; margin-top:26px; max-width:440px; }
.ud-story__person{ display:flex; align-items:center; gap:11px; }
.ud-story__avatar{ width:38px; height:38px; border-radius:50%; flex:none; box-shadow:0 2px 6px rgba(28,36,51,.18); background-size:cover; background-position:center; }
.ud-story__name{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:15px; color:var(--ink); }
.ud-story__name-sub{ font-size:11.5px; color:var(--ink-mute); }
.ud-story__cta{ display:inline-flex; align-items:center; gap:7px; font-size:13.5px; font-weight:700; color:var(--on-accent); background:var(--accent); padding:10px 18px; border-radius:999px; box-shadow:0 6px 14px rgba(232,163,58,.26); }

/* =========================================================================
   運営者の想い
   ========================================================================= */
.ud-owner{ background:var(--mist); padding:64px 0; }
.ud-owner__card{ background:#fff; border-radius:28px; box-shadow:0 14px 34px rgba(28,36,51,.10); display:grid; grid-template-columns:0.92fr 1.08fr; overflow:hidden; align-items:stretch; }
.ud-owner__img{ position:relative; min-height:360px; }
.ud-owner__img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ud-owner__pill{ position:absolute; left:22px; bottom:22px; display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:700; color:var(--ink); background:rgba(255,255,255,.94); padding:8px 15px; border-radius:999px; }
.ud-owner__body{ padding:46px 48px; }
.ud-owner__title{ font-size:28px; line-height:1.55; font-weight:700; margin:12px 0 0; letter-spacing:.01em; text-wrap:balance; }
.ud-owner__text{ font-size:15px; line-height:2.05; color:var(--ink-soft); margin:20px 0 0; }
.ud-owner__sign{ display:flex; align-items:center; gap:12px; margin-top:24px; padding-top:20px; border-top:1px solid var(--line); flex-wrap:wrap; }
.ud-owner__sign-name{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:16px; color:var(--ink); }
.ud-owner__sign-note{ font-size:12px; color:var(--ink-mute); }

/* =========================================================================
   3STEP
   ========================================================================= */
.ud-steps__head{ text-align:center; }
.ud-steps__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:40px; }
.ud-step-card{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:30px 26px; position:relative; overflow:hidden; }
.ud-step-card__bignum{ position:absolute; right:16px; top:8px; font-family:'Zen Maru Gothic'; font-weight:700; font-size:70px; color:var(--accent-soft); line-height:1; }
.ud-step-card__label{ font-family:'Poppins',sans-serif; font-weight:700; font-size:14px; color:var(--accent-deep); position:relative; }
.ud-step-card__title{ font-size:19px; font-weight:700; margin:16px 0 0; position:relative; }
.ud-step-card__body{ font-size:13.5px; line-height:1.95; color:var(--ink-soft); margin:10px 0 0; position:relative; }

/* =========================================================================
   お問い合わせ
   ========================================================================= */
.ud-contact{ padding:20px 0 96px; }
.ud-contact__card{ background:var(--brand); border-radius:28px; padding:56px; display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; box-shadow:0 24px 50px rgba(42,60,107,.22); overflow:hidden; position:relative; }
.ud-contact__glow{ position:absolute; right:-60px; top:-60px; width:240px; height:240px; border-radius:50%; background:rgba(232,163,58,.16); }
.ud-contact__inner{ position:relative; }
.ud-contact__title{ font-size:34px; line-height:1.45; font-weight:700; color:#fff; margin:0; }
.ud-contact__text{ font-size:15px; line-height:2; color:rgba(255,255,255,.82); margin:20px 0 0; }
.ud-contact__note{ display:flex; align-items:center; gap:10px; margin-top:24px; color:rgba(255,255,255,.85); font-size:13.5px; }
.ud-contact__dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); }

/* form */
.ud-form{ position:relative; background:#fff; border-radius:20px; padding:28px; box-shadow:0 14px 30px rgba(0,0,0,.16); }
.ud-form__rows{ display:flex; flex-direction:column; gap:13px; }
.ud-form__rows > div{ min-width:0; }
.ud-form__two{ display:grid; grid-template-columns:1fr 1fr; gap:13px; }
.ud-form__two > div{ min-width:0; }
.ud-form label{ font-size:12px; font-weight:700; color:var(--ink-soft); display:block; }
.ud-input, .ud-textarea, .ud-select{ width:100%; min-width:0; -webkit-appearance:none; appearance:none; margin-top:6px; border:1px solid var(--line); border-radius:12px; background:var(--bg); font-family:inherit; font-size:14px; color:var(--ink); padding:0 14px; height:42px; transition:border-color .2s,box-shadow .2s; }
.ud-textarea{ height:84px; padding:12px 14px; resize:vertical; }
.ud-input:focus, .ud-textarea:focus, .ud-select:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(232,163,58,.18); }
.ud-hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.ud-submit{ margin-top:4px; border:none; cursor:pointer; background:var(--accent); color:var(--on-accent); font-family:'Zen Kaku Gothic New'; font-size:15px; font-weight:700; padding:15px; border-radius:999px; box-shadow:0 8px 18px rgba(232,163,58,.3); transition:transform .2s cubic-bezier(.22,1,.36,1); }
.ud-submit:hover{ transform:translateY(-2px); }
.ud-submit:disabled{ opacity:.6; cursor:wait; transform:none; }
.ud-form__msg{ font-size:13.5px; margin-top:4px; padding:10px 14px; border-radius:10px; display:none; }
.ud-form__msg.is-ok{ display:block; background:var(--accent-soft); color:var(--accent-deep); }
.ud-form__msg.is-err{ display:block; background:#fdecec; color:#b3261e; }

/* =========================================================================
   Footer
   ========================================================================= */
.ud-footer{ border-top:1px solid var(--line); padding:48px 0 40px; }
.ud-footer__top{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:28px; }
.ud-footer__brand{ font-family:'Poppins',sans-serif; font-weight:700; font-size:21px; }
.ud-footer__brand .dot{ color:var(--accent); }
.ud-footer__desc{ font-size:12.5px; color:var(--ink-mute); margin:12px 0 0; line-height:1.9; max-width:300px; }
.ud-footer__cols{ display:flex; gap:48px; flex-wrap:wrap; }
.ud-footer__col{ display:flex; flex-direction:column; gap:11px; }
.ud-footer__col-h{ font-size:11px; color:var(--ink-mute); letter-spacing:.08em; font-family:'Poppins'; font-weight:600; }
.ud-footer__col a{ font-size:13px; color:var(--ink-soft); text-decoration:none; transition:color .2s; }
.ud-footer__col a:hover{ color:var(--brand-deep); }
.ud-footer__bottom{ margin:32px auto 0; padding:18px 32px 0; border-top:1px solid var(--line); font-size:11.5px; color:var(--ink-mute); max-width:1180px; }

/* =========================================================================
   物件詳細
   ========================================================================= */
.ud-breadcrumb{ padding-top:22px; display:flex; align-items:center; gap:8px; font-size:12.5px; color:var(--ink-mute); flex-wrap:wrap; }
.ud-breadcrumb a{ color:var(--ink-mute); text-decoration:none; transition:color .2s; }
.ud-breadcrumb a:hover{ color:var(--brand-deep); }
.ud-breadcrumb .current{ color:var(--ink-soft); font-weight:600; }

.ud-detail__head{ padding-top:20px; }
.ud-detail__tags{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.ud-badge-accent{ font-size:11.5px; font-weight:700; color:var(--on-accent); background:var(--accent); padding:5px 12px; border-radius:999px; }
.ud-badge-tint{ font-size:11.5px; font-weight:700; color:var(--brand-deep); background:var(--tint); padding:5px 12px; border-radius:999px; }
.ud-detail__no{ font-size:12px; color:var(--ink-mute); font-family:'Poppins'; font-weight:600; }
.ud-detail__title{ font-size:40px; font-weight:700; margin:14px 0 0; letter-spacing:.01em; }
.ud-detail__loc{ font-size:14px; color:var(--ink-soft); margin-top:8px; }
.ud-detail__grid{ display:grid; grid-template-columns:1.62fr 1fr; gap:36px; margin-top:28px; align-items:start; }

.ud-gallery{ display:grid; grid-template-columns:2.3fr 1fr; gap:12px; }
.ud-gallery__main{ position:relative; aspect-ratio:4/3; border-radius:20px; overflow:hidden; box-shadow:0 14px 34px rgba(28,36,51,.12); }
.ud-gallery__main-img{ position:absolute; inset:0; background-size:cover; background-position:center; }
.ud-gallery__count{ position:absolute; left:14px; bottom:14px; display:inline-flex; align-items:center; gap:6px; font-size:11.5px; font-weight:700; color:#fff; background:rgba(28,36,51,.62); backdrop-filter:blur(4px); padding:6px 12px; border-radius:999px; }
.ud-gallery__side{ display:grid; grid-template-rows:1fr 1fr; gap:12px; }
.ud-gallery__side button{ position:relative; border-radius:14px; overflow:hidden; border:none; cursor:pointer; padding:0; width:100%; height:100%; background-size:cover; background-position:center; box-shadow:0 1px 3px rgba(28,36,51,.12); opacity:.95; transition:box-shadow .2s,opacity .2s; }
.ud-thumbs{ display:grid; grid-template-columns:repeat(6,1fr); gap:10px; margin-top:12px; }
.ud-thumbs button{ position:relative; aspect-ratio:1/1; border-radius:12px; overflow:hidden; border:none; cursor:pointer; padding:0; background-size:cover; background-position:center; box-shadow:0 1px 3px rgba(28,36,51,.12); opacity:.92; transition:box-shadow .2s,opacity .2s; }
.ud-thumbs button.is-active, .ud-gallery__side button.is-active{ box-shadow:inset 0 0 0 3px var(--accent); opacity:1; }

.ud-detail__about-title{ font-size:26px; font-weight:700; margin:10px 0 0; }
.ud-detail__about p{ font-size:15px; line-height:2.05; color:var(--ink-soft); margin:18px 0 0; }
.ud-detail__feats{ display:flex; gap:9px; flex-wrap:wrap; margin-top:26px; }

.ud-subhead{ font-size:22px; font-weight:700; margin:44px 0 0; }
.ud-subhead__note{ font-size:13.5px; color:var(--ink-soft); margin:8px 0 0; }

.ud-mosaic{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:104px; gap:12px; margin-top:18px; }
.ud-mosaic button{ position:relative; background-size:cover; background-position:center; border-radius:16px; overflow:hidden; border:none; cursor:pointer; padding:0; box-shadow:0 2px 8px rgba(28,36,51,.08); transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s; }
.ud-mosaic button:hover{ transform:translateY(-2px); box-shadow:0 12px 26px rgba(28,36,51,.16); }
.ud-mosaic__shade{ position:absolute; left:0; right:0; bottom:0; height:46%; background:linear-gradient(to top,rgba(20,28,42,.66),transparent); }
.ud-mosaic__cap{ position:absolute; left:12px; bottom:10px; font-size:11.5px; font-weight:700; color:#fff; white-space:nowrap; text-shadow:0 1px 4px rgba(0,0,0,.5); }

.ud-facts{ margin-top:16px; border-top:1px solid var(--line); }
.ud-facts__row{ display:grid; grid-template-columns:160px 1fr; gap:16px; padding:14px 0; border-bottom:1px solid var(--line); }
.ud-facts__label{ font-size:13.5px; color:var(--ink-mute); font-weight:600; }
.ud-facts__value{ font-size:13.5px; color:var(--ink); font-weight:500; }

.ud-usages{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:16px; }
.ud-usage{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:20px; }
.ud-usage__title{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:16px; color:var(--brand-deep); }
.ud-usage__body{ font-size:13px; line-height:1.9; color:var(--ink-soft); margin:8px 0 0; }

.ud-map{ aspect-ratio:21/9; border-radius:18px; overflow:hidden; margin-top:16px; background:var(--mist); position:relative; border:1px solid var(--line); }
.ud-map iframe{ width:100%; height:100%; border:0; display:block; }
.ud-map__ph{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:8px; color:var(--ink-mute); }
.ud-nearby{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:16px; }
.ud-nearby__row{ display:flex; justify-content:space-between; align-items:center; background:#fff; border:1px solid var(--line); border-radius:12px; padding:13px 16px; }
.ud-nearby__name{ font-size:13.5px; color:var(--ink); font-weight:500; }
.ud-nearby__dist{ font-size:12.5px; color:var(--accent-deep); font-weight:700; }

.ud-ownerbox{ background:var(--brand); border-radius:20px; padding:30px 32px; margin-top:44px; color:#fff; position:relative; overflow:hidden; }
.ud-ownerbox__glow{ position:absolute; right:-50px; top:-50px; width:180px; height:180px; border-radius:50%; background:rgba(232,163,58,.16); }
.ud-ownerbox__eyebrow{ font-family:'Poppins',sans-serif; font-weight:600; font-size:12px; letter-spacing:.08em; color:var(--accent); position:relative; }
.ud-ownerbox__text{ font-size:15px; line-height:2; margin:12px 0 0; color:rgba(255,255,255,.92); position:relative; }
.ud-ownerbox__sign{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:14px; margin-top:16px; position:relative; }

/* sticky CV card */
.ud-cv{ position:sticky; top:94px; background:#fff; border:1px solid var(--line); border-radius:20px; padding:26px; box-shadow:0 10px 28px rgba(28,36,51,.08); }
.ud-cv__label{ font-size:12px; color:var(--ink-mute); font-weight:600; }
.ud-cv__price{ display:flex; align-items:baseline; gap:4px; margin-top:4px; }
.ud-cv__price-num{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:38px; color:var(--ink); }
.ud-cv__price-unit{ font-size:14px; color:var(--ink-mute); }
.ud-cv__note{ font-size:11.5px; color:var(--accent-deep); font-weight:600; margin-top:4px; }
.ud-cv__rows{ display:flex; flex-direction:column; margin-top:20px; border-top:1px solid var(--line); }
.ud-cv__row{ display:flex; justify-content:space-between; padding:11px 0; border-bottom:1px solid var(--line); }
.ud-cv__row:last-child{ border-bottom:none; }
.ud-cv__row-k{ font-size:13px; color:var(--ink-mute); }
.ud-cv__row-v{ font-size:13px; font-weight:600; color:var(--ink); }
.ud-cv__btn{ display:flex; align-items:center; justify-content:center; gap:8px; text-decoration:none; background:var(--accent); color:var(--on-accent); font-size:15px; font-weight:700; padding:15px; border-radius:999px; margin-top:20px; box-shadow:0 8px 18px rgba(232,163,58,.3); transition:transform .2s cubic-bezier(.22,1,.36,1); }
.ud-cv__btn:hover{ transform:translateY(-2px); }
.ud-cv__line{ display:flex; align-items:center; justify-content:center; gap:8px; text-decoration:none; background:#fff; color:var(--brand-deep); font-size:14px; font-weight:700; padding:13px; border-radius:999px; margin-top:10px; border:1.5px solid var(--line); transition:border-color .2s; }
.ud-cv__line:hover{ border-color:var(--brand); }
.ud-cv__sub{ font-size:11.5px; color:var(--ink-mute); text-align:center; margin-top:12px; }

/* contact card on detail uses hero-bg */
.ud-contact__card--dark{ background:var(--hero-bg); box-shadow:0 24px 50px rgba(26,39,66,.25); }

/* related */
.ud-related{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:24px; }
.ud-rel-card{ display:flex; flex-direction:column; text-decoration:none; background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:0 1px 2px rgba(28,36,51,.05); transition:box-shadow .28s cubic-bezier(.22,1,.36,1),transform .28s; }
.ud-rel-card:hover{ box-shadow:0 16px 32px rgba(28,36,51,.12); transform:translateY(-4px); }
.ud-rel-card__img{ aspect-ratio:4/3; overflow:hidden; }
.ud-rel-card__img div{ width:100%; height:100%; background-size:cover; background-position:center; }
.ud-rel-card__body{ padding:16px 18px 18px; }
.ud-rel-card__use{ font-size:11.5px; font-weight:600; color:var(--accent-deep); }
.ud-rel-card__name{ font-size:17px; font-weight:700; margin:5px 0 0; color:var(--ink); }
.ud-rel-card__foot{ display:flex; align-items:baseline; justify-content:space-between; margin-top:12px; }
.ud-rel-card__rent{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:18px; color:var(--ink); }
.ud-rel-card__permo{ font-size:11.5px; color:var(--ink-mute); }
.ud-rel-card__arrow{ font-size:13px; font-weight:700; color:var(--accent-deep); }

/* mobile fixed CTA bar */
.ud-mobilebar{ display:none; position:fixed; left:0; right:0; bottom:0; z-index:95; background:#fff; border-top:1px solid var(--line); box-shadow:0 -6px 20px rgba(28,36,51,.12); padding:11px 16px; align-items:center; justify-content:space-between; gap:12px; }
.ud-mobilebar__label{ font-size:10.5px; color:var(--ink-mute); font-weight:600; }
.ud-mobilebar__price{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:21px; color:var(--ink); }
.ud-mobilebar__permo{ font-size:11px; color:var(--ink-mute); }
.ud-mobilebar__btn{ flex:1; max-width:230px; display:inline-flex; align-items:center; justify-content:center; gap:7px; text-decoration:none; background:var(--accent); color:var(--on-accent); font-size:14.5px; font-weight:700; padding:14px; border-radius:999px; box-shadow:0 6px 16px rgba(232,163,58,.3); }

/* =========================================================================
   インタビュー詳細
   ========================================================================= */
.ud-iv-head{ padding-top:28px; }
.ud-iv-head__tags{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.ud-iv-head__badge{ font-family:'Poppins',sans-serif; font-weight:700; font-size:11px; letter-spacing:.06em; color:var(--on-accent); background:var(--accent); padding:6px 13px; border-radius:999px; white-space:nowrap; }
.ud-iv-head__year{ font-size:12.5px; color:var(--ink-mute); white-space:nowrap; }
.ud-iv-head__title{ font-size:clamp(28px,5.4vw,40px); line-height:1.5; font-weight:700; margin:20px 0 0; letter-spacing:.01em; text-wrap:balance; }
.ud-iv-head__person{ display:flex; align-items:center; gap:13px; margin-top:22px; }
.ud-iv-head__avatar{ width:46px; height:46px; border-radius:50%; flex:none; box-shadow:0 2px 6px rgba(28,36,51,.18); background-size:cover; background-position:center; }
.ud-iv-head__name{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:16px; color:var(--ink); }
.ud-iv-head__role{ font-size:12px; color:var(--ink-mute); }
.ud-iv-hero{ padding-top:32px; }
.ud-iv-hero__inner{ aspect-ratio:16/8; border-radius:24px; overflow:hidden; box-shadow:0 20px 46px rgba(28,36,51,.14); position:relative; }
.ud-iv-hero__inner img{ width:100%; height:100%; object-fit:cover; }
.ud-iv-body{ padding-top:48px; }
.ud-lead{ font-size:17px; line-height:2.1; color:var(--ink); font-weight:500; margin:0; }
.ud-qa-block{ margin-top:40px; }
.ud-qa{ display:grid; grid-template-columns:34px 1fr; gap:14px; align-items:start; }
.ud-qa__q-label{ font-family:'Poppins',sans-serif; font-weight:700; font-size:18px; color:var(--accent-deep); line-height:1.4; }
.ud-qa__q{ font-size:16.5px; font-weight:700; line-height:1.7; color:var(--ink); }
.ud-qa__a-label{ font-family:'Poppins',sans-serif; font-weight:700; font-size:18px; color:var(--brand); line-height:1.9; }
.ud-qa__a{ font-size:15.5px; line-height:2.05; color:var(--ink-soft); margin:0; }
.ud-iv-quote{ position:relative; margin:8px 0; padding:8px 0 8px 26px; border-left:4px solid var(--accent); font-family:'Zen Maru Gothic',sans-serif; font-weight:700; font-size:22px; line-height:1.75; color:var(--ink); }
.ud-iv-figure{ margin:0; }
.ud-iv-figure__img{ border-radius:18px; overflow:hidden; box-shadow:0 12px 30px rgba(28,36,51,.12); }
.ud-iv-figure__img div{ width:100%; aspect-ratio:16/10; background-size:cover; background-position:center; }
.ud-iv-figure figcaption{ font-size:12.5px; color:var(--ink-mute); margin-top:10px; text-align:center; }

.ud-iv-profile{ padding-top:56px; }
.ud-iv-profile__grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.ud-profile-card{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:24px; }
.ud-profile-card__eyebrow{ font-family:'Poppins',sans-serif; font-weight:600; font-size:11.5px; letter-spacing:.06em; color:var(--accent-deep); }
.ud-profile-card__head{ display:flex; align-items:center; gap:13px; margin-top:14px; }
.ud-profile-card__avatar{ width:52px; height:52px; border-radius:50%; flex:none; background-size:cover; background-position:center; }
.ud-profile-card__name{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:17px; }
.ud-profile-card__role{ font-size:12px; color:var(--ink-mute); margin-top:2px; }
.ud-profile-card__text{ font-size:13px; line-height:1.95; color:var(--ink-soft); margin:16px 0 0; }
.ud-iv-proplink{ position:relative; display:flex; flex-direction:column; justify-content:flex-end; border-radius:18px; overflow:hidden; min-height:200px; text-decoration:none; box-shadow:0 6px 20px rgba(28,36,51,.1); transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s; }
.ud-iv-proplink:hover{ transform:translateY(-4px); box-shadow:0 18px 36px rgba(28,36,51,.16); }
.ud-iv-proplink__bg{ position:absolute; inset:0; background-size:cover; background-position:center; }
.ud-iv-proplink__overlay{ position:absolute; inset:0; background:linear-gradient(to top,rgba(13,19,32,.9),rgba(13,19,32,.25) 60%,transparent); }
.ud-iv-proplink__badge{ position:absolute; top:14px; left:14px; font-size:11px; font-weight:700; color:var(--on-accent); background:var(--accent); padding:5px 12px; border-radius:999px; }
.ud-iv-proplink__body{ position:relative; padding:20px; }
.ud-iv-proplink__use{ font-size:11.5px; font-weight:600; color:rgba(255,255,255,.85); }
.ud-iv-proplink__name{ font-size:19px; font-weight:700; color:#fff; margin:5px 0 0; }
.ud-iv-proplink__foot{ display:flex; align-items:baseline; justify-content:space-between; margin-top:12px; }
.ud-iv-proplink__rent{ font-family:'Zen Maru Gothic'; font-weight:700; font-size:19px; color:#fff; }
.ud-iv-proplink__permo{ font-size:11.5px; color:rgba(255,255,255,.75); }
.ud-iv-proplink__arrow{ font-size:13px; font-weight:700; color:#fff; }

.ud-other-stories{ padding-top:64px; }
.ud-other-stories__head{ display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.ud-story-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:28px; }
.ud-story-card{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden; text-decoration:none; box-shadow:0 1px 2px rgba(28,36,51,.05); transition:transform .28s cubic-bezier(.22,1,.36,1),box-shadow .28s; }
.ud-story-card:hover{ transform:translateY(-3px); box-shadow:0 14px 28px rgba(28,36,51,.1); }
.ud-story-card__img{ aspect-ratio:16/10; overflow:hidden; }
.ud-story-card__img div{ width:100%; height:100%; background-size:cover; background-position:center; }
.ud-story-card__body{ padding:18px 20px 20px; }
.ud-story-card__role{ font-size:11.5px; font-weight:600; color:var(--brand); }
.ud-story-card__title{ font-size:16.5px; font-weight:700; line-height:1.55; margin:8px 0 0; color:var(--ink); }
.ud-story-card__more{ font-size:12.5px; font-weight:700; color:var(--accent-deep); margin-top:14px; display:inline-block; }

/* centered CTA (interview) */
.ud-cta-center{ background:var(--brand); border-radius:28px; padding:52px; text-align:center; box-shadow:0 24px 50px rgba(42,60,107,.22); overflow:hidden; position:relative; }
.ud-cta-center__title{ font-size:clamp(26px,5vw,32px); line-height:1.45; font-weight:700; color:#fff; margin:0; }
.ud-cta-center__text{ font-size:14.5px; line-height:2; color:rgba(255,255,255,.82); margin:18px auto 0; max-width:460px; }
.ud-cta-center__actions{ display:flex; gap:13px; justify-content:center; flex-wrap:wrap; margin-top:26px; }
.ud-cta-center__ghost{ display:inline-flex; align-items:center; gap:8px; text-decoration:none; background:rgba(255,255,255,.12); color:#fff; font-size:15px; font-weight:700; padding:15px 26px; border-radius:999px; border:1.5px solid rgba(255,255,255,.4); }

.ud-footer__simple{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px; align-items:center; }
.ud-footer__back{ font-size:13px; color:var(--ink-soft); text-decoration:none; }

/* =========================================================================
   レスポンシブ
   ========================================================================= */
@media (max-width:860px){
  .ud-container{ padding-left:20px; padding-right:20px; }
  .ud-section{ padding:56px 0; }
  .ud-nav__link{ display:none; }
  .ud-burger{ display:flex; }
  .ud-nav.is-open .ud-mobile-menu{ display:flex; }

  .ud-hero{ min-height:90vh; display:flex; align-items:center; }
  .ud-hero__photo-m{ display:block; }
  .ud-hero__wrap{ padding-top:44px; padding-bottom:24px; }
  .ud-hero__grid{ grid-template-columns:1fr; min-height:auto; gap:8px; padding-bottom:8px; }
  .ud-hide-m{ display:none; }
  .ud-hero__show-m{ display:block; }
  .ud-stats{ grid-template-columns:1fr 1fr; gap:0; }
  .ud-stats__item{ border-right:none; padding:16px 6px; }

  .ud-mino__grid{ grid-template-columns:1fr; gap:32px; }
  .ud-mino__cards{ grid-template-columns:1fr 1fr; gap:32px; }

  .ud-pickup-grid{ grid-template-columns:1fr; gap:32px; }
  /* 高さ固定(16/10)だと中身がはみ出して上端で見切れるため、内容に合わせて伸ばす */
  .ud-pick-card{ aspect-ratio:auto; min-height:300px; }
  .ud-pick-card__body{ padding:22px; padding-top:56px; }
  .ud-pick-card__name{ font-size:23px; }
  .ud-prop-grid{ grid-template-columns:1fr; gap:14px; }
  .ud-prop-card{ aspect-ratio:16/9; }
  .ud-prop-card__body{ padding:22px; }
  .ud-prop-card__use{ font-size:12.5px; }
  .ud-prop-card__name{ font-size:22px; margin-top:7px; }
  .ud-prop-card__rent{ font-size:23px; }

  .ud-story-row{ grid-template-columns:1fr; gap:20px; padding:36px 0; }
  .ud-story__img{ order:0 !important; }

  .ud-owner__card{ grid-template-columns:1fr; }
  .ud-owner__img{ min-height:240px; }
  .ud-owner__body{ padding:30px; }

  .ud-steps__grid{ grid-template-columns:1fr 1fr; }
  /* 余白を詰めて白いフォームの横幅を広げる */
  .ud-contact__card{ grid-template-columns:1fr; padding:16px; gap:28px; }
  .ud-form{ padding:22px; }
  /* お名前・メールを1行ずつに */
  .ud-form__two{ grid-template-columns:1fr; }
  /* iOSでタップ時に自動ズームしないよう入力欄を16pxに */
  .ud-input, .ud-textarea, .ud-select{ font-size:16px; }

  /* 物件詳細 */
  .ud-detail__grid{ grid-template-columns:1fr; gap:28px; }
  .ud-gallery{ grid-template-columns:1fr; }
  .ud-gallery__side{ grid-template-rows:none; grid-template-columns:1fr 1fr; }
  .ud-gallery__side button{ aspect-ratio:4/3; height:auto; }
  .ud-usages{ grid-template-columns:1fr; }
  .ud-mosaic{ grid-template-columns:1fr 1fr; grid-auto-rows:130px; }
  .ud-mosaic button{ grid-column:span 1 !important; grid-row:span 1 !important; }
  .ud-cv{ position:static; }
  .ud-related{ grid-template-columns:1fr 1fr; }
  .ud-mobilebar{ display:flex; }
  .ud-page--detail{ padding-bottom:76px; }

  /* インタビュー */
  .ud-iv-profile__grid{ grid-template-columns:1fr; gap:24px; }
  .ud-story-cards{ grid-template-columns:1fr 1fr; }
  .ud-qa{ grid-template-columns:1fr; gap:6px; }
  .ud-qa__a-label{ display:none; }
}

@media (max-width:520px){
  .ud-mino__cards{ grid-template-columns:1fr; }
  .ud-steps__grid{ grid-template-columns:1fr; }
  .ud-related{ grid-template-columns:1fr; }
  .ud-story-cards{ grid-template-columns:1fr; }
}

/* mobile dropdown menu */
.ud-mobile-menu{ display:none; position:absolute; top:74px; left:0; right:0; background:var(--bg); border-bottom:1px solid var(--line); flex-direction:column; padding:12px 20px 20px; gap:4px; box-shadow:0 14px 28px rgba(28,36,51,.12); }
.ud-mobile-menu a{ padding:12px 4px; text-decoration:none; color:var(--ink-soft); font-size:15px; font-weight:600; border-bottom:1px solid var(--line); }
@media (max-width:860px){
  .ud-mobile-menu.is-open{ display:flex; }
}
