/* =====================================================================
   M&Company — 物件一覧 / 物件詳細 / お知らせ の追加スタイル
   （TOP共通の style.css の後に読み込み。色・余白は Claude Design 準拠）
   ===================================================================== */

:root{
  --mco-ink:#1c1b19;
  --mco-bg:#f6f5f2;
  --mco-line:#e3e0db;
  --mco-mut:#9a968f;
}

/* 全ページ共通：読み込み時のフェードイン（全ページ移動を同一挙動に統一）。
   ※ transform を使うと .mco-root 内の position:fixed 要素（画像拡大ライトボックス・
   　 業務内容モーダル）の中央配置が崩れるため、必ず不透明度のみでフェードする。 */
@keyframes mcoPageIn{ from{ opacity:0; } to{ opacity:1; } }
.mco-root{ animation:mcoPageIn .5s ease both; }

/* ---------- 共通：ページタイトル（ダークヒーロー） ---------- */
.mcl-hero{
  position:relative; background:#1c1b19; color:#f6f5f2;
  padding:clamp(32px,5vw,58px) clamp(20px,6vw,80px) clamp(34px,5vw,60px);
  overflow:hidden;
}
.mcl-hero__bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0.18; }
.mcl-hero__veil{ position:absolute; inset:0; background:linear-gradient(90deg,rgba(28,27,25,0.92) 0%,rgba(28,27,25,0.7) 100%); }
.mcl-hero__inner{ position:relative; max-width:1220px; margin:0 auto; }
.mcl-hero__crumb{ font-size:11px; letter-spacing:0.1em; color:rgba(246,245,242,0.55); margin-bottom:16px; }
.mcl-hero__crumb a{ color:rgba(246,245,242,0.55); text-decoration:none; }
.mcl-hero__crumb a:hover{ color:#f6f5f2; }
.mcl-hero__en{ font-size:11px; letter-spacing:0.3em; color:rgba(246,245,242,0.6); margin:0 0 8px; }
.mcl-hero__h1{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:clamp(26px,4vw,42px); letter-spacing:0.1em; margin:0; line-height:1.3; }
.mcl-hero__lead{ font-size:13px; letter-spacing:0.06em; color:rgba(246,245,242,0.7); margin:14px 0 0; max-width:560px; line-height:2; }

/* ---------- 物件一覧 本体 ---------- */
.mcl-main{ max-width:1220px; margin:0 auto; padding:clamp(26px,4vw,46px) clamp(20px,6vw,80px) clamp(56px,9vw,104px); }
.mcl-layout{ display:grid; grid-template-columns:300px 1fr; gap:clamp(22px,3vw,40px); align-items:start; }
.mcl-aside{ position:sticky; top:84px; display:flex; flex-direction:column; gap:14px; }

.mcl-tabs{ display:flex; gap:6px; }
.mcl-tab{ flex:1; min-width:0; display:inline-flex; flex-direction:column; gap:1px; align-items:center; justify-content:center; cursor:pointer; padding:10px 6px; border:1px solid #d9d6d0; background:#fff; color:#46443f; font-family:'Noto Sans JP',sans-serif; font-size:14px; transition:color .35s ease, background .35s ease, border-color .35s ease; }
.mcl-tab b{ font-family:'Noto Serif JP',serif; font-weight:500; letter-spacing:0.06em; }
.mcl-tab small{ font-size:10.5px; letter-spacing:0.02em; opacity:0.7; }
.mcl-tab:hover{ border-color:#1c1b19; }
.mcl-tab.is-on{ border-color:#1c1b19; background:#1c1b19; color:#f6f5f2; }

.mcl-panel{ background:#fff; border:1px solid var(--mco-line); padding:clamp(20px,2.4vw,26px); }
.mcl-panel__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; padding-bottom:11px; border-bottom:2px solid #1c1b19; }
.mcl-panel__head h2{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:16px; letter-spacing:0.1em; margin:0; }
.mcl-reset{ background:none; border:1px solid #d9d6d0; color:#9a968f; cursor:pointer; font-family:'Noto Sans JP'; font-size:10.5px; letter-spacing:0.1em; padding:5px 11px; transition:color .3s ease, border-color .3s ease; }
.mcl-reset:hover{ color:#1c1b19; border-color:#1c1b19; }

.mcl-field{ margin-bottom:14px; }
.mcl-field__label{ font-size:11px; letter-spacing:0.18em; color:#9a968f; margin:0 0 8px; display:flex; align-items:center; gap:8px; }
.mcl-field__label::before{ content:''; width:14px; height:1px; background:#1c1b19; }
.mcl-rangerow{ display:flex; align-items:center; gap:8px; }
.mcl-rangerow span{ font-size:12px; color:#9a968f; }

.mcl-sel{ flex:1; min-width:0; border:1px solid #d9d6d0; background:#fff; color:#1c1b19; font-family:'Noto Sans JP'; font-size:12.5px; padding:9px 28px 9px 11px; cursor:pointer; appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%231c1b19' stroke-width='1.2' fill='none'/></svg>");
  background-repeat:no-repeat; background-position:right 12px center; }

.mcl-acc{ border:1px solid var(--mco-line); margin-bottom:7px; }
.mcl-acc__head{ display:flex; align-items:center; justify-content:space-between; width:100%; cursor:pointer; border:none; background:#fff; color:#1c1b19; font-family:'Noto Sans JP'; padding:10px 11px; text-align:left; transition:background .25s ease; }
.mcl-acc__head:hover{ background:#f6f5f2; }
.mcl-acc.is-open .mcl-acc__head{ background:#f6f5f2; }
.mcl-acc__pref{ font-family:'Noto Serif JP',serif; font-size:13px; letter-spacing:0.08em; }
.mcl-acc__count{ font-size:10.5px; letter-spacing:0.04em; color:#9a968f; margin-left:8px; }
.mcl-acc__icon{ font-family:monospace; font-size:13px; color:#9a968f; transition:transform .3s ease; }
.mcl-acc.is-open .mcl-acc__icon{ transform:rotate(45deg); }
.mcl-acc__body{ display:none; flex-wrap:wrap; gap:6px; padding:10px 11px 12px; }
.mcl-acc.is-open .mcl-acc__body{ display:flex; }

.mcl-chip{ cursor:pointer; border:1px solid #d9d6d0; background:#fff; color:#46443f; font-family:'Noto Sans JP'; font-size:11.5px; letter-spacing:0.04em; padding:7px 12px; transition:background .3s ease, color .3s ease, border-color .3s ease; }
.mcl-chip:hover{ border-color:#1c1b19; }
.mcl-chip.is-on{ border-color:#1c1b19; background:#1c1b19; color:#f6f5f2; }

/* 結果 */
.mcl-results-head{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; padding-bottom:16px; margin-bottom:clamp(20px,2.6vw,28px); border-bottom:1px solid var(--mco-line); }
.mcl-results-head p{ margin:0; font-size:13px; letter-spacing:0.04em; color:#46443f; }
.mcl-results-head .mcl-count{ font-family:'Noto Serif JP',serif; font-weight:600; font-size:22px; color:#1c1b19; margin-right:4px; }
.mcl-sortwrap{ display:flex; align-items:center; gap:10px; }
.mcl-sortwrap span{ font-size:11px; letter-spacing:0.1em; color:#9a968f; }
.mcl-sortwrap .mcl-sel{ flex:0 0 auto; padding:9px 30px 9px 13px; }

.mcl-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(248px,1fr)); gap:clamp(16px,2vw,26px); }
.mcl-card{ display:block; text-decoration:none; background:#fff; border:1px solid #e9e7e2; overflow:hidden; transition:transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s ease; }
.mcl-card:hover{ transform:translateY(-4px); box-shadow:0 18px 44px rgba(28,27,25,0.13); }
.mcl-card__imgwrap{ position:relative; width:100%; aspect-ratio:4 / 3; overflow:hidden; background:#ececea; }
.mcl-card__img{ position:absolute; inset:0; background-size:cover; background-position:center; transition:opacity .6s ease, transform 1.4s cubic-bezier(.2,.7,.2,1); }
.mcl-card:hover .mcl-card__img{ transform:scale(1.06); }
.mcl-card__ph{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background-image:repeating-linear-gradient(135deg,#e6e4e0 0,#e6e4e0 11px,#f3f2ef 11px,#f3f2ef 22px); font-family:monospace; font-size:10px; letter-spacing:0.14em; color:#a8a39b; }
.mcl-card__type{ position:absolute; top:0; left:0; z-index:3; color:#f6f5f2; font-size:10px; letter-spacing:0.16em; padding:5px 12px; }
.mcl-card__tag{ position:absolute; top:12px; right:12px; z-index:3; font-size:10px; letter-spacing:0.12em; color:#46443f; background:rgba(246,245,242,0.92); padding:4px 10px; }
.mcl-card__body{ padding:16px 16px 18px; }
.mcl-card__loc{ font-size:11px; letter-spacing:0.08em; color:#9a968f; margin:0; }
.mcl-card__title{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:16.5px; letter-spacing:0.04em; margin:6px 0 0; color:#1c1b19; line-height:1.5; transition:color .35s ease; }
.mcl-card:hover .mcl-card__title{ color:#7a766f; }
.mcl-card__spec{ font-size:12px; letter-spacing:0.04em; color:#6f6c67; margin:9px 0 0; }
.mcl-card__access{ font-size:11.5px; letter-spacing:0.04em; color:#9a968f; margin:4px 0 0; }
.mcl-card__foot{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; margin-top:13px; padding-top:13px; border-top:1px solid #ece9e4; }
.mcl-card__price{ font-family:'Noto Serif JP',serif; font-weight:600; font-size:19px; letter-spacing:0.02em; color:#1c1b19; }
.mcl-card__go{ font-size:11px; letter-spacing:0.1em; color:#1c1b19; opacity:0; transform:translateX(-6px); transition:opacity .4s ease, transform .4s ease; }
.mcl-card:hover .mcl-card__go{ opacity:1; transform:translateX(0); }

/* ページネーション */
.mcl-pager{ display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:wrap; margin-top:clamp(32px,4vw,52px); }
.mcl-pager button{ min-width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center; cursor:pointer; font-family:'Noto Sans JP'; font-size:13px; letter-spacing:0.04em; padding:0 8px; border:1px solid #d9d6d0; background:#fff; color:#46443f; }
.mcl-pager button.is-on{ border-color:#1c1b19; background:#1c1b19; color:#f6f5f2; }
.mcl-pager button[disabled]{ cursor:default; color:#cfccc6; border-color:#ece9e4; }

.mcl-noresult{ padding:clamp(48px,8vw,90px) 20px; text-align:center; border:1px dashed #d9d6d0; background:#fff; }
.mcl-noresult p{ margin:0; }
.mcl-noresult .t{ font-family:'Noto Serif JP',serif; font-size:18px; letter-spacing:0.06em; color:#1c1b19; }
.mcl-noresult .s{ font-size:12.5px; color:#9a968f; margin:12px 0 22px; }
.mcl-noresult button{ border:1px solid #1c1b19; background:#1c1b19; color:#f6f5f2; cursor:pointer; font-family:'Noto Sans JP'; font-size:12px; letter-spacing:0.14em; padding:12px 30px; }

@media (max-width:880px){
  .mcl-layout{ grid-template-columns:1fr; }
  .mcl-aside{ position:static; }
}
@media (max-width:560px){
  .mcl-grid{ grid-template-columns:1fr; }
}

/* =====================================================================
   物件詳細（single-bukken）
   ===================================================================== */
.mcp-main{ max-width:1180px; margin:0 auto; padding:clamp(18px,2.6vw,28px) clamp(20px,6vw,80px) clamp(56px,9vw,104px); }
.mcp-crumb{ font-size:11.5px; letter-spacing:0.08em; color:#6b6760; margin-bottom:clamp(16px,2.4vw,24px); }
.mcp-crumb a{ color:#6b6760; text-decoration:none; }
.mcp-crumb a:hover{ color:#1c1b19; }

.mcp-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:18px; flex-wrap:wrap; margin-bottom:clamp(18px,2.6vw,26px); }
.mcp-badges{ display:flex; align-items:center; gap:10px; margin-bottom:12px; flex-wrap:wrap; }
.mcp-badge-type{ color:#f6f5f2; font-size:11px; letter-spacing:0.16em; padding:5px 13px; }
.mcp-badge-status{ font-size:11px; letter-spacing:0.12em; padding:4px 12px; }
.mcp-badge-tag{ font-size:11px; letter-spacing:0.1em; color:#6f6c67; }
.mcp-title{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:clamp(24px,3.6vw,38px); letter-spacing:0.06em; margin:0; line-height:1.4; }
.mcp-addr{ font-size:15px; letter-spacing:0.06em; color:#56524c; margin:13px 0 0; }
.mcp-modified{ font-size:11.5px; letter-spacing:0.08em; color:#8a857d; margin:10px 0 0; }
.mcp-headprice{ display:flex; align-items:baseline; gap:12px; flex:0 0 auto; }
.mcp-headprice .l{ font-size:18px; letter-spacing:0.14em; color:#46443f; }
.mcp-headprice .v{ font-family:'Noto Serif JP',serif; font-weight:600; font-size:clamp(28px,4.4vw,44px); letter-spacing:0.02em; color:#1c1b19; line-height:1.1; }

.mcp-grid{ display:grid; grid-template-columns:1fr 320px; gap:clamp(24px,3.4vw,48px); align-items:start; }
.mcp-grid > *{ min-width:0; }

/* スライダー */
.mcp-stage{ position:relative; width:100%; aspect-ratio:4 / 3; overflow:hidden; background:#ececea; border:1px solid var(--mco-line); }
.mcp-stage__img{ position:absolute; inset:0; background-size:cover; background-position:center; cursor:zoom-in; }
.mcp-stage__ph{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background-image:repeating-linear-gradient(135deg,#e6e4e0 0,#e6e4e0 14px,#f3f2ef 14px,#f3f2ef 28px); font-family:monospace; font-size:12px; letter-spacing:0.16em; color:#a8a39b; cursor:zoom-in; }
.mcp-stage__count{ position:absolute; left:0; top:0; background:rgba(28,27,25,0.82); color:#f6f5f2; font-size:11px; letter-spacing:0.14em; padding:6px 14px; pointer-events:none; }
.mcp-stage__zoom{ position:absolute; right:14px; top:14px; background:rgba(28,27,25,0.62); color:#f6f5f2; font-size:10px; letter-spacing:0.14em; padding:5px 11px; pointer-events:none; }
.mcp-arrow{ position:absolute; top:50%; transform:translateY(-50%); width:40px; height:64px; border:none; background:rgba(28,27,25,0.42); color:#f6f5f2; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:22px; font-weight:300; line-height:1; transition:background .35s ease; backdrop-filter:blur(2px); }
.mcp-arrow:hover{ background:rgba(28,27,25,0.72); }
.mcp-arrow--prev{ left:0; }
.mcp-arrow--next{ right:0; }
.mcp-thumbrow{ display:flex; gap:8px; margin-top:8px; overflow-x:auto; padding-bottom:4px; }
.mcp-thumb{ flex:0 0 auto; width:76px; height:57px; background-size:cover; background-position:center; background-color:#ececea; border:2px solid var(--mco-line); display:flex; align-items:center; justify-content:center; padding:0; opacity:0.65; cursor:pointer; transition:opacity .3s ease, border-color .3s ease; }
.mcp-thumb:hover{ opacity:1; }
.mcp-thumb.is-on{ border-color:#1c1b19; opacity:1; }
.mcp-thumb span{ font-family:monospace; font-size:8.5px; letter-spacing:0.08em; color:#9a968f; }

.mcp-sec{ margin-top:clamp(32px,4.4vw,52px); }
.mcp-sec__h{ display:flex; align-items:center; gap:12px; margin-bottom:clamp(16px,2.2vw,22px); }
.mcp-sec__h span{ width:22px; height:2px; background:#1c1b19; }
.mcp-sec__h h2{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:clamp(18px,2.2vw,22px); letter-spacing:0.1em; margin:0; }

/* 物件概要アコーディオン */
.mcp-specs{ border-top:2px solid #1c1b19; }
.mcp-specgrp{ border-bottom:1px solid var(--mco-line); }
.mcp-spec-head{ display:flex; align-items:center; justify-content:space-between; gap:16px; width:100%; background:none; border:none; cursor:pointer; padding:17px 6px; text-align:left; transition:background .25s ease; }
.mcp-spec-head:hover{ background:#faf9f7; }
.mcp-spec-head__l{ display:flex; align-items:baseline; gap:14px; min-width:0; }
.mcp-spec-head__t{ font-family:'Noto Sans JP'; font-size:13.5px; font-weight:500; letter-spacing:0.1em; color:#1c1b19; flex:0 0 auto; }
.mcp-spec-head__hint{ font-size:12px; letter-spacing:0.04em; color:#6b6760; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.mcp-spec-head__icon{ font-size:15px; line-height:1; color:#9a968f; transition:transform .32s cubic-bezier(.2,.7,.2,1); }
.mcp-specgrp.is-open .mcp-spec-head__icon{ transform:rotate(45deg); }
.mcp-spec-head__hint{ display:inline; }
.mcp-specgrp.is-open .mcp-spec-head__hint{ display:none; }
.mcp-spec-body{ display:none; margin:0; padding:2px 6px 14px; }
.mcp-specgrp.is-open .mcp-spec-body{ display:block; }
.mcp-spec-row{ display:grid; grid-template-columns:140px 1fr; gap:16px; padding:11px 0; border-top:1px solid #f0eeea; }
.mcp-spec-row dt{ font-size:12.5px; letter-spacing:0.08em; color:#56524c; font-weight:400; margin:0; }
.mcp-spec-row dd{ margin:0; font-size:14px; font-weight:400; line-height:1.6; color:#1c1b19; }

.mcp-feature{ background:#fff; border:1px solid #e9e7e2; padding:clamp(22px,2.8vw,32px); }
.mcp-feature p{ font-size:14px; letter-spacing:0.03em; line-height:2.1; color:#46443f; margin:0; }
.mcp-feature p + p{ margin-top:1em; }

.mcp-map{ width:100%; height:clamp(220px,28vw,340px); border:1px solid var(--mco-line); }
.mcp-map iframe{ width:100%; height:100%; border:0; display:block; }
.mcp-map__ph{ width:100%; height:100%; background-image:repeating-linear-gradient(45deg,#e7e5e2 0,#e7e5e2 1px,#f1f0ed 1px,#f1f0ed 24px),repeating-linear-gradient(-45deg,#e7e5e2 0,#e7e5e2 1px,#f1f0ed 1px,#f1f0ed 24px); display:flex; align-items:center; justify-content:center; font-family:monospace; font-size:11px; letter-spacing:0.14em; color:#a8a39b; }

/* 右サイドバー */
.mcp-aside{ position:sticky; top:84px; }
.mcp-sidecard{ background:#fff; border:1px solid var(--mco-line); padding:clamp(20px,2.4vw,26px); }
.mcp-sidecard__pl{ display:block; font-size:13px; letter-spacing:0.16em; color:#46443f; }
.mcp-sidecard__pv{ font-family:'Noto Serif JP',serif; font-weight:600; font-size:clamp(28px,3.6vw,36px); letter-spacing:0.02em; color:#1c1b19; line-height:1.2; }
.mcp-summary{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:#e9e7e2; border:1px solid #e9e7e2; margin:18px 0 20px; }
.mcp-summary > div{ background:#fff; padding:12px 13px; }
.mcp-summary .l{ display:block; font-size:11px; letter-spacing:0.1em; color:#46443f; margin-bottom:5px; }
.mcp-summary .v{ font-size:14px; font-weight:500; letter-spacing:0.02em; color:#1c1b19; }
.mcp-cta{ display:block; text-decoration:none; text-align:center; border:1px solid #1c1b19; background:#1c1b19; color:#f6f5f2; cursor:pointer; font-family:'Noto Sans JP'; font-size:13px; letter-spacing:0.14em; padding:15px 20px; transition:background .3s ease; }
.mcp-cta:hover{ background:#000; }
.mcp-tel{ margin-top:18px; padding-top:16px; border-top:1px solid #ece9e4; text-align:center; }
.mcp-tel .l{ display:block; font-size:12px; letter-spacing:0.1em; color:#46443f; margin-bottom:6px; }
.mcp-tel a{ font-family:'Noto Serif JP',serif; font-weight:600; font-size:20px; letter-spacing:0.04em; color:#1c1b19; text-decoration:none; }
.mcp-tel .h{ display:block; font-size:11.5px; color:#6b6760; margin-top:4px; }
.mcp-note{ font-size:11px; letter-spacing:0.04em; line-height:1.9; color:#7a766f; margin:14px 2px 0; }

/* ライトボックス */
.mcp-lb{ position:fixed; inset:0; z-index:200; background:rgba(20,19,17,0.94); display:flex; align-items:center; justify-content:center; padding:clamp(40px,9vh,110px) clamp(28px,8vw,140px); cursor:zoom-out; animation:mcoFade .3s ease; }
.mcp-lb[hidden]{ display:none; }
.mcp-lb__close{ position:absolute; top:clamp(14px,2.4vw,26px); right:clamp(14px,2.4vw,26px); display:flex; align-items:center; gap:9px; background:none; border:none; cursor:pointer; color:#f6f5f2; font-size:11px; letter-spacing:0.22em; }
.mcp-lb__arrow{ position:absolute; top:50%; transform:translateY(-50%); width:clamp(44px,5vw,52px); height:clamp(56px,7vw,72px); border:1px solid rgba(246,245,242,0.32); background:rgba(246,245,242,0.06); color:#f6f5f2; cursor:pointer; font-size:24px; font-weight:300; display:flex; align-items:center; justify-content:center; }
.mcp-lb__arrow:hover{ background:rgba(246,245,242,0.18); }
.mcp-lb__prev{ left:clamp(10px,2.5vw,32px); }
.mcp-lb__next{ right:clamp(10px,2.5vw,32px); }
.mcp-lb__stage{ width:min(86vw,1180px); max-height:78vh; aspect-ratio:4 / 3; background-size:contain; background-repeat:no-repeat; background-position:center; background-color:#1c1b19; cursor:default; }

@media (max-width:900px){
  .mcp-grid{ grid-template-columns:1fr; }
  .mcp-aside{ position:static; }
}
@media (max-width:600px){
  .mcp-summary{ grid-template-columns:1fr 1fr; }
  .mcp-spec-row{ grid-template-columns:1fr; gap:4px; }
}

/* =====================================================================
   お知らせ一覧（home.php）／お知らせ詳細（single.php）
   ===================================================================== */
.mcn-main{ max-width:1100px; margin:0 auto; padding:clamp(26px,4vw,46px) clamp(20px,6vw,80px) clamp(56px,9vw,104px); }
.mcn-tabs{ display:flex; flex-wrap:wrap; gap:8px; padding-bottom:clamp(18px,2.6vw,26px); margin-bottom:clamp(20px,2.6vw,30px); border-bottom:1px solid var(--mco-line); }
.mcn-tab{ cursor:pointer; border:1px solid #d9d6d0; background:#fff; color:#46443f; font-family:'Noto Sans JP'; font-size:12.5px; letter-spacing:0.08em; padding:8px 18px; text-decoration:none; transition:color .3s ease, background .3s ease, border-color .3s ease; }
.mcn-tab:hover{ border-color:#1c1b19; color:#1c1b19; }
.mcn-tab.is-on{ border-color:#1c1b19; background:#1c1b19; color:#f6f5f2; }
.mcn-list{ border-top:1px solid #1c1b19; }
.mcn-row{ display:grid; grid-template-columns:clamp(150px,22vw,210px) 1fr auto; gap:clamp(16px,3vw,34px); align-items:center; padding:clamp(16px,2.4vw,24px) 6px; border-bottom:1px solid var(--mco-line); text-decoration:none; transition:background .35s ease; }
.mcn-row:hover{ background:#efedea; }
.mcn-thumb{ position:relative; width:100%; aspect-ratio:4 / 3; overflow:hidden; background:#ececea; }
.mcn-thumb__img{ position:absolute; inset:0; background-size:cover; background-position:center; transition:transform 1.1s cubic-bezier(.2,.7,.2,1); }
.mcn-row:hover .mcn-thumb__img{ transform:scale(1.06); }
.mcn-thumb__ph{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background-image:repeating-linear-gradient(135deg,#e6e4e0 0,#e6e4e0 11px,#f3f2ef 11px,#f3f2ef 22px); font-family:monospace; font-size:10px; color:#a8a39b; }
.mcn-meta{ display:flex; align-items:center; gap:14px; margin-bottom:9px; }
.mcn-date{ font-family:'Noto Serif JP',serif; font-size:clamp(12px,1.4vw,14px); letter-spacing:0.08em; color:#46443f; }
.mcn-cat{ display:inline-flex; align-items:center; justify-content:center; min-width:62px; padding:4px 11px; font-size:10.5px; letter-spacing:0.1em; line-height:1.4; color:#f6f5f2; background:#46443f; }
.mcn-ttl{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:clamp(15px,1.8vw,19px); letter-spacing:0.04em; line-height:1.6; color:#1c1b19; margin:0; transition:color .3s ease; }
.mcn-row:hover .mcn-ttl{ color:#000; }
.mcn-excerpt{ font-size:12.5px; letter-spacing:0.02em; line-height:1.95; color:#6f6c67; margin:9px 0 0; }
.mcn-arrow{ justify-self:end; font-size:14px; color:#9a968f; transition:transform .3s ease; }
.mcn-row:hover .mcn-arrow{ transform:translateX(4px); }
.mcn-count{ margin:clamp(24px,3vw,34px) 0 0; font-size:12px; letter-spacing:0.06em; color:#9a968f; text-align:center; }
.mcn-empty{ padding:clamp(48px,8vw,90px) 20px; text-align:center; border:1px dashed #d9d6d0; background:#fff; }
.mcn-empty p{ font-family:'Noto Serif JP',serif; font-size:17px; letter-spacing:0.06em; color:#1c1b19; margin:0; }

/* お知らせ詳細 */
.mcd-article{ max-width:760px; margin:0 auto; padding:clamp(28px,4vw,48px) clamp(20px,6vw,80px) clamp(56px,9vw,104px); }
.mcd-meta{ display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.mcd-title{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:clamp(22px,3.2vw,32px); letter-spacing:0.04em; line-height:1.5; color:#1c1b19; margin:0 0 clamp(20px,3vw,28px); }
.mcd-hero{ position:relative; width:100%; aspect-ratio:16 / 9; overflow:hidden; background:#ececea; margin-bottom:clamp(26px,3.4vw,40px); }
.mcd-hero__img{ position:absolute; inset:0; background-size:cover; background-position:center; }
.mcd-body{ font-size:14.5px; letter-spacing:0.02em; line-height:2.1; color:#3a3833; }
.mcd-body p{ margin:0 0 1.6em; }
.mcd-body h2{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:clamp(17px,2vw,20px); letter-spacing:0.06em; color:#1c1b19; margin:2.2em 0 0.9em; padding-bottom:0.5em; border-bottom:1px solid #ddd9d2; }
.mcd-body img{ max-width:100%; height:auto; margin:0 0 1.8em; }
.mcd-body ul{ list-style:none; margin:0 0 1.8em; padding:clamp(18px,2.4vw,24px) clamp(18px,2.4vw,26px); background:#fff; border:1px solid var(--mco-line); }
.mcd-body ul li{ position:relative; padding-left:20px; line-height:1.9; margin:0 0 0.5em; font-size:14px; color:#3a3833; }
.mcd-body ul li::before{ content:''; position:absolute; left:0; top:0.82em; width:7px; height:1px; background:#46443f; }
.mcd-back{ margin-top:clamp(34px,5vw,52px); padding-top:clamp(24px,3vw,32px); border-top:1px solid #ddd9d2; display:flex; justify-content:center; }
.mcd-back a{ display:inline-flex; align-items:center; gap:10px; text-decoration:none; border:1px solid #1c1b19; color:#1c1b19; font-family:'Noto Sans JP'; font-size:12.5px; letter-spacing:0.14em; padding:13px 30px; transition:background .3s ease, color .3s ease; }
.mcd-back a:hover{ background:#1c1b19; color:#f6f5f2; }
.mcd-pager{ margin-top:clamp(20px,2.6vw,28px); display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.mcd-pager a{ display:flex; flex-direction:column; gap:6px; text-decoration:none; border:1px solid var(--mco-line); background:#fff; padding:16px 18px; }
.mcd-pager a.next{ text-align:right; grid-column:2; }
.mcd-pager .lbl{ font-size:10.5px; letter-spacing:0.16em; color:#9a968f; }
.mcd-pager .ttl{ font-family:'Noto Serif JP',serif; font-size:13.5px; letter-spacing:0.03em; line-height:1.6; color:#1c1b19; transition:color .3s ease; }
.mcd-pager a:hover .ttl{ color:#7a766f; }

@media (max-width:620px){
  .mcn-row{ grid-template-columns:1fr; }
  .mcn-thumb{ aspect-ratio:16 / 9; }
  .mcn-arrow{ display:none; }
}

/* =====================================================================
   物件はこちら 追従ボタン（TOP・スクロールで表示）
   ===================================================================== */
.mco-propbtn{ position:fixed; right:clamp(16px,2.4vw,30px); bottom:clamp(16px,2.4vw,30px); z-index:48; display:flex; align-items:center; gap:14px; padding:13px 18px 13px 22px; background:#1c1b19; color:#f6f5f2; text-decoration:none; box-shadow:0 12px 34px rgba(28,27,25,0.32); opacity:0; transform:translateY(18px); pointer-events:none; transition:transform .45s cubic-bezier(.2,.7,.2,1), opacity .45s ease, background .35s ease; }
.mco-propbtn.is-shown{ opacity:1; transform:none; pointer-events:auto; }
.mco-propbtn__col{ display:flex; flex-direction:column; gap:2px; line-height:1.2; }
.mco-propbtn__en{ font-family:monospace; font-size:9px; letter-spacing:0.24em; color:rgba(246,245,242,0.6); }
.mco-propbtn__jp{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:14px; letter-spacing:0.1em; }
.mco-propbtn__arrow{ font-size:14px; flex:0 0 auto; color:rgba(246,245,242,0.85); transition:transform .4s cubic-bezier(.2,.7,.2,1); }
.mco-propbtn:hover{ background:#000; }
.mco-propbtn:hover .mco-propbtn__arrow{ transform:translateX(5px); color:#f6f5f2; }

/* =====================================================================
   TOP お知らせ（サムネなし・Claude Design準拠）
   ===================================================================== */
.mco-topnews-list{ margin:0 auto; max-width:880px; border-top:2px solid #1c1b19; }
.mco-topnews-row{ display:grid; grid-template-columns:clamp(96px,12vw,124px) clamp(82px,10vw,104px) 1fr auto; gap:clamp(12px,2.4vw,30px); align-items:center; padding:clamp(17px,2.4vw,24px) 6px; border-bottom:1px solid #e3e0db; text-decoration:none; transition:background .35s ease; }
.mco-topnews-row:hover{ background:#efedea; }
.mco-topnews-row time{ font-family:'Noto Serif JP',serif; font-size:clamp(13px,1.5vw,15px); letter-spacing:0.08em; color:#46443f; }
.mco-topnews-cat{ display:inline-flex; align-items:center; justify-content:center; min-width:62px; padding:4px 11px; font-size:10.5px; letter-spacing:0.1em; line-height:1.4; color:#f6f5f2; background:#46443f; }
.mco-topnews-ttl{ font-family:'Noto Sans JP',sans-serif; font-weight:400; font-size:clamp(13.5px,1.5vw,15.5px); letter-spacing:0.03em; line-height:1.7; color:#1c1b19; margin:0; transition:color .3s ease; }
.mco-topnews-row:hover .mco-topnews-ttl{ color:#000; }
.mco-topnews-arrow{ justify-self:end; font-size:13px; color:#9a968f; transition:transform .3s ease, color .3s ease; }
.mco-topnews-row:hover .mco-topnews-arrow{ transform:translateX(4px); color:#1c1b19; }
@media (max-width:560px){
  .mco-topnews-row{ grid-template-columns:auto 1fr; gap:5px 14px; }
  .mco-topnews-row time{ grid-column:1; }
  .mco-topnews-cat{ grid-column:2; justify-self:start; }
  .mco-topnews-ttl{ grid-column:1 / -1; }
  .mco-topnews-arrow{ display:none; }
}

/* =====================================================================
   ヘッダーメニュー内 物件クイック検索
   ===================================================================== */
.mco-overlay-body--split{ display:flex; flex-direction:row; flex-wrap:wrap; gap:clamp(24px,4vw,68px); align-content:center; align-items:center; justify-content:center; width:100%; max-width:1180px; margin:0 auto; padding:clamp(16px,3vw,36px) clamp(20px,6vw,80px); overflow-y:auto; }
.mco-overlay-links{ flex:1 1 340px; min-width:260px; display:flex; flex-direction:column; justify-content:center; }
@media (max-width:760px){
  .mco-overlay-body--split{ flex-direction:column; flex-wrap:nowrap; align-content:flex-start; align-items:stretch; justify-content:flex-start; gap:22px; padding:18px clamp(20px,6vw,80px) 40px; -webkit-overflow-scrolling:touch; }
  .mco-overlay-links{ flex:0 0 auto; }
  .mco-qsearch{ flex:0 0 auto; width:100%; }
}
.mco-qsearch{ flex:0 1 392px; min-width:280px; border:1px solid rgba(246,245,242,0.2); background:rgba(246,245,242,0.05); padding:clamp(22px,2.8vw,32px); }
.mco-qsearch__en{ font-size:10px; letter-spacing:0.26em; color:rgba(246,245,242,0.5); margin:0; }
.mco-qsearch__h{ font-family:'Noto Serif JP',serif; font-weight:500; font-size:clamp(18px,2.2vw,23px); letter-spacing:0.1em; color:#f6f5f2; margin:7px 0 clamp(16px,2vw,22px); }
.mco-qsearch__label{ font-size:10.5px; letter-spacing:0.16em; color:rgba(246,245,242,0.55); margin:8px 0; }
.mco-qsearch__tabs{ display:flex; gap:6px; margin-bottom:12px; }
.mco-qtab{ flex:1; cursor:pointer; border:1px solid rgba(246,245,242,0.3); background:transparent; color:rgba(246,245,242,0.75); font-family:'Noto Sans JP'; font-size:12.5px; letter-spacing:0.08em; padding:9px 6px; transition:background .25s ease, color .25s ease; }
.mco-qtab.is-on{ border-color:#f6f5f2; background:#f6f5f2; color:#1c1b19; }
.mco-qsel{ width:100%; appearance:none; -webkit-appearance:none; border:1px solid rgba(246,245,242,0.3); background:rgba(28,27,25,0.4); color:#f6f5f2; font-family:'Noto Sans JP'; font-size:13px; padding:11px 14px; margin-bottom:12px; cursor:pointer; }
.mco-qsel option, .mco-qsel optgroup{ color:#1c1b19; }
.mco-qsearch__btn{ width:100%; border:1px solid #f6f5f2; background:#f6f5f2; color:#1c1b19; cursor:pointer; font-family:'Noto Sans JP'; font-size:13px; letter-spacing:0.16em; padding:14px 20px; margin-top:6px; transition:background .3s ease, color .3s ease; }
.mco-qsearch__btn:hover{ background:transparent; color:#f6f5f2; }
@media (max-width:760px){ .mco-overlay-body--split{ flex-direction:column; } }
