@charset "utf-8";

/* =========================
   Yoshida Juhan style (PDF ref)
========================= */
:root{
  --ink:#3f3c4d;     /* 濃い見出し/ボタン/フッター */
  --text:#1f1f1f;
  --muted:#6f6f6f;
  --line:#d9d9d9;
  --paper:#ffffff;
  --panel:#f2f2f2;

  --container:1120px;
  --gap:24px;
  --radius:10px;

  --shadow: 0 12px 34px rgba(20,20,30,.08);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  color:var(--text);
  background:var(--paper);
  font-family: "Noto Serif JP","Hiragino Mincho ProN","Yu Mincho","YuMincho",serif;
  line-height:1.85;
  letter-spacing:.02em;
}

img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
button,input,select,textarea{ font:inherit; }

.container{
  width:min(var(--container), calc(100% - 48px));
  margin-inline:auto;
}

.hr{
  border:none;
  border-top:1px solid var(--line);
  margin: 36px 0;
}

/*余白の原因*/

/*
.page{
  padding: 40px 0 90px;
}
*/

/* =========================
  Header
========================= */
.site-header{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}


.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:78px;
  gap:16px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width: 240px;
}
.brand-logo{
  width:144px;
  height:144px;
  flex:0 0 auto;
}
.brand-title{
  display:flex;
  flex-direction:column;
  line-height:1.2;
}
.brand-title small{
  font-size:12px;
  color:var(--muted);
}
.brand-title strong{
  font-size:18px;
  letter-spacing:.06em;
}

/* Right icons nav */
.icon-nav{
  display:flex;
  align-items:flex-end;
  gap:18px;
}
.icon-nav a{
  display:grid;
  place-items:center;
  gap:6px;
  padding:10px 8px;
  border-bottom:3px solid transparent;
}
.icon-nav a[aria-current="page"]{
  border-bottom-color: var(--ink);
}
.icon-nav svg{
  width:18px; height:18px;
  stroke: var(--ink);
}
.icon-nav span{
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size:11px;
  color:var(--muted);
  letter-spacing:.02em;
}

/* Hamburger */
.burger{
  display:flex;
  align-items:center;
  gap:10px;
}
.burger-btn{
  width:44px; height:44px;
  border:none;
  background:transparent;
  cursor:pointer;
  display:grid;
  place-items:center;
}
.burger-lines{
  width:22px;
  height:14px;
  position:relative;
}
.burger-lines span{
  position:absolute;
  left:0; right:0;
  height:1px;
  background: var(--ink);
  transition: transform .25s ease, top .25s ease, opacity .2s ease;
}
.burger-lines span:nth-child(1){ top:2px; }
.burger-lines span:nth-child(2){ top:11px; }

body.is-drawer-open .burger-lines span:nth-child(1){ top:6.5px; transform:rotate(45deg); }
body.is-drawer-open .burger-lines span:nth-child(2){ top:6.5px; transform:rotate(-45deg); }

/* Drawer */
.drawer-backdrop{
  position:fixed; inset:0;
  background: rgba(10,10,15,.40);
  opacity:0; pointer-events:none;
  transition: opacity .25s ease;
  z-index:120;
}
.drawer{
  position:fixed;
  top:0; left:0;
  width:min(420px, 88vw);
  height:100vh;
  background:#fff;
  border-right:1px solid var(--line);
  transform: translateX(-102%);
  transition: transform .25s ease;
  z-index:130;
  padding: 18px 18px 28px;
  overflow:auto;
}
body.is-drawer-open .drawer-backdrop{ opacity:1; pointer-events:auto; }
body.is-drawer-open .drawer{ transform: translateX(0); }

.drawer-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 8px 4px 16px;
}
/*
.drawer-close{
  width:44px; height:44px;
  border:none; background:transparent;
  cursor:pointer;
  display:grid; place-items:center;
}
.drawer-close span{
  width:22px; height:1px;
  background: var(--ink);
  display:block;
  transform-origin:center;
}
.drawer-close span:nth-child(1){ transform: rotate(45deg); }
.drawer-close span:nth-child(2){ transform: rotate(-45deg); margin-top:-1px; }
*/

/* Drawer close (X) */
.drawer-close{
  position: relative;
  width: 44px;
  height: 44px;
  border: none;
  background: transparent;
  cursor: pointer;
}

.drawer-close span{
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22px;
  height: 1px;
  background: var(--ink);
  transform-origin: center;
}

.drawer-close span:nth-child(1){
  transform: translate(-50%, -50%) rotate(45deg);
}

.drawer-close span:nth-child(2){
  transform: translate(-50%, -50%) rotate(-45deg);
}

.drawer-nav{
  border-top:1px solid var(--line);
  padding-top:14px;
}
.drawer-nav a{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 12px 8px;
  border-bottom:1px solid var(--line);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}
.drawer-nav a small{
  color:var(--muted);
}

.icon-nav img{
  width: 18px;
  height: 18px;
  opacity: .85;
}


/* =========================
  Titles / Buttons
========================= */
.page-title{
  text-align:center;
  font-size:34px;
  letter-spacing:.08em;
  color:var(--ink);
  margin: 46px 0 34px;
}

.section-title{
  font-size:18px;
  color:var(--ink);
  margin: 0 0 12px;
  letter-spacing:.08em;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-width: 220px;
  padding: 12px 18px;
  border:1px solid var(--ink);
  color:#fff;
  background: var(--ink);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size:14px;
  letter-spacing:.06em;
  cursor:pointer;
}
.btn--ghost{
  background: transparent;
  color: var(--ink);
}
.btn-wrap{
  text-align:center;
  margin-top: 26px;
}
.btn .tri{
  width:0; height:0;
  border-left:8px solid #fff;
  border-top:6px solid transparent;
  border-bottom:6px solid transparent;
}
.btn--ghost .tri{ border-left-color: var(--ink); }

/* =========================
  Home sections (PDF like)
========================= */
.two-col{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 34px;
  align-items:center;
  padding: 28px 0;
}
.two-col.reverse{
  grid-template-columns: 1fr 1.1fr;
}
.lead{
  color:var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size:14px;
  line-height:2.0;
}
.kagi{
  position:relative;
  padding-left:14px;
}
.kagi::before{
  content:"";
  position:absolute;
  left:0; top:.2em;
  width:3px; height:calc(100% - .4em);
  background: var(--ink);
  opacity:.9;
}

.photo{
  border-radius: 2px;
  overflow:hidden;
  box-shadow: var(--shadow);
}
.photo img{ width:100%; height:auto; }

.map-card{
  border-top:1px solid var(--line);
  padding-top: 18px;
  margin-top: 10px;
}
.map-frame{
  border:1px solid var(--line);
  border-radius: 4px;
  overflow:hidden;
  background:#fafafa;
}
.map-frame iframe{
  width:100%;
  height:360px;
  border:0;
  display:block;
}


/* =========================
  Listing cards (buy.html)
========================= */
.subhead{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 18px;
  margin: 18px 0 10px;
}
.subhead h2{
  margin:0;
  font-size:18px;
  color: var(--text);
  letter-spacing:.08em;
}
.pager{
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  color:var(--muted);
  font-size:12px;
}
.pager a{ color:inherit; padding:0 6px; }
.pager a.is-current{ color:var(--ink); font-weight:700; }

.grid-cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.card{
  border:1px solid var(--line);
  background:#fff;
}
.card .img{
  aspect-ratio: 4 / 3;
  background:#cfcfcf;
}
.card .body{
  padding: 14px 14px 16px;
}
.card .title{
  font-size:14px;
  margin:0 0 8px;
  line-height:1.6;
}
.card .price{
  color:var(--ink);
  font-size:20px;
  margin: 6px 0 6px;
  letter-spacing:.06em;
}
.card .meta{
  color:var(--muted);
  font-size:12px;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  line-height:1.7;
}



/* =========================
  Company (company.html)
========================= */
.company-box{
  background: var(--panel);
  padding: 30px 34px;
  border-radius: 4px;
}
.company-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0 14px;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}
.company-table th{
  width:160px;
  text-align:left;
  color:var(--muted);
  font-weight:500;
  vertical-align:top;
}
.company-table td{
  color:var(--text);
}

/* =========================
  Contact form (contact.html)
========================= */
.form{
  width:min(880px, 100%);
  margin-inline:auto;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}
.form h2{
  margin: 0 0 12px;
  font-size:16px;
  color:var(--text);
}
.check-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px 18px;
  align-items:center;
  padding: 8px 0 10px;
}
.check-row label{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
}
.field{
  display:grid;
  grid-template-columns: 220px 1fr;
  gap: 18px;
  padding: 14px 0;
  border-bottom:1px solid #eee;
}
.field .label{
  color:var(--text);
}
.field .control{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
input[type="text"], input[type="email"], input[type="tel"], textarea{
  width:100%;
  border:1px solid var(--line);
  padding: 10px 12px;
  border-radius:2px;
  background:#fff;
}
textarea{ min-height:160px; resize:vertical; }
.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  width:100%;
}
.small-input{ width:min(240px, 100%); }
.privacy{
  color:#c21d1d;
  font-weight:700;
  margin-top: 18px;
  font-family: "Noto Serif JP", serif;
}
.form-actions{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap: 18px;
  padding-top: 18px;
}
.form-actions .btn{ min-width: 160px; }

/* =========================
  Property detail (property.html)
========================= */
.detail-top{
  width:min(980px, 100%);
  margin-inline:auto;
}
.detail-head{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap: 18px;
  align-items:end;
  margin: 6px 0 10px;
}
.detail-head .place{
  color:var(--text);
  font-weight:700;
}
.detail-head .copy{
  color:var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}
.tags{
  display:flex;
  flex-wrap:wrap;
  gap: 10px 12px;
  border-top:1px solid var(--line);
  padding-top: 12px;
}
.tag{
  display:flex;
  gap:10px;
  align-items:center;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size:12px;
  color:var(--muted);
}
.tag b{
  font-weight:700;
  color:#fff;
  background: var(--ink);
  padding: 4px 10px;
  border-radius:2px;
  letter-spacing:.06em;
}
.gallery{
  margin-top: 18px;
  border-top:1px solid var(--line);
  padding-top: 18px;
}
.slider{
  position:relative;
  background:#efefef;
  border:1px solid var(--line);
  overflow:hidden;
}
.slider .stage{
  width:100%;
  aspect-ratio: 16/9;
  display:grid;
  place-items:center;
  background:#e9e9e9;
}
.slider img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:none;
}
.slider img.is-active{ display:block; }
.nav-arrow{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:42px; height:42px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.85);
  display:grid;
  place-items:center;
  cursor:pointer;
}
.nav-arrow.prev{ left:12px; }
.nav-arrow.next{ right:12px; }
.nav-arrow svg{ width:18px; height:18px; stroke: var(--ink); }

.thumbs{
  display:flex;
  gap: 14px;
  padding: 14px 0 8px;
  overflow:auto;
}
.thumb{
  width:160px;
  aspect-ratio: 16/9;
  border:1px solid var(--line);
  background:#d6d6d6;
  flex:0 0 auto;
  cursor:pointer;
  opacity:.78;
}
.thumb.is-active{ outline:2px solid var(--ink); opacity:1; }
.thumb img{ width:100%; height:100%; object-fit:cover; }

.detail-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 26px;
  margin-top: 20px;
  align-items:start;
}
.kv-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0 10px;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}
.kv-table th{
  text-align:left;
  color:var(--muted);
  font-weight:500;
}
.kv-table td{
  text-align:right;
  color:var(--text);
}
.plan{
  border:1px solid var(--line);
  background:#d6d6d6;
  aspect-ratio: 4 / 5;
  overflow:hidden;
}
.plan img{
  width:100%; height:100%;
  object-fit:cover;
}
.reco{
  margin-top: 20px;
  border-top:1px solid var(--line);
  padding-top: 18px;
}
.reco-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.reco-card{
  border:1px solid var(--line);
  background:#fff;
  padding: 10px;
}
.reco-card .ph{
  aspect-ratio: 4/3;
  background:#cfcfcf;
  margin-bottom: 10px;
}
.reco-card p{
  margin:0;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  color:var(--muted);
  font-size:12px;
}

/* =========================
  CTA + Footer (PDF like)
========================= */
.cta{
  padding: 40px 0 0;
  text-align:center;
}
.cta .note{
  margin-top: 10px;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  color:var(--muted);
  font-size:12px;
  letter-spacing:.02em;
}

.site-footer{
  background: var(--ink);
  color:#fff;
  padding: 40px 0 30px;
}
.footer-top{
  display:flex;
  gap: 26px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
}
.footer-brand{
  display:flex;
  gap: 14px;
  align-items:center;
}
.footer-brand .mark{
  width:144px; height:144px;
  filter: brightness(0) invert(1);
}
.footer-brand .name{
  line-height:1.2;
}
.footer-brand .name small{
  display:block;
  opacity:.8;
  font-size:12px;
  letter-spacing:.04em;
}
.footer-brand .name strong{
  display:block;
  font-size:22px;
  letter-spacing:.08em;
}
.footer-tel{
  border:1px solid rgba(255,255,255,.35);
  padding: 14px 16px;
  min-width: 320px;
}
.footer-tel .cap{
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  opacity:.85;
  font-size:12px;
}
.footer-tel .num{
  font-size:24px;
  letter-spacing:.06em;
  margin-top: 6px;
}
.footer-tel .sub{
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  opacity:.85;
  font-size:12px;
}

.footer-nav{
  margin-top: 26px;
  display:flex;
  gap: 22px;
  flex-wrap:wrap;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size:13px;
  opacity:.92;
}
.footer-bottom{
  text-align:center;
  margin-top: 28px;
  opacity:.75;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size:12px;
}

/* =========================
  Hero (screenshot-like)
========================= */
.hero{
  position: relative;
  width: 100vw;          /* ← 画面いっぱい */
  height: 100vh;         /* ← 高さも画面いっぱい */
  min-height: 520px;     /* ← 小さすぎ防止 */
  margin: 0;
  overflow: hidden;
  background: #fff;
}


/* 左側グラデーション（文字可読性強化） */
.hero__bg{
  position:absolute;
  inset:0;
  pointer-events:none;

  /* 中央→左をしっかり白く */
  background:
    linear-gradient(
      90deg,
      rgba(255,255,255,1) 0%,
      rgba(255,255,255,0.98) 30%,
      rgba(255,255,255,0.92) 45%,
      rgba(255,255,255,0.75) 52%,
      rgba(255,255,255,0.40) 60%,
      rgba(255,255,255,0.00) 72%
    );
}

.hero__copy{
  text-shadow:
    0 1px 2px rgba(255,255,255,.6),
    0 0 12px rgba(255,255,255,.4);
}


/* 右の写真 */
.hero__media{
  position:absolute;
  inset:0;
}
.hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position: 75% center; /* 木の看板側を見せたいので右寄せ */
  display:block;
}

/* 左コピー */
.hero__copy{
  position:absolute;
  left: 7%;
  top: 50%;
  transform: translateY(-50%);
  max-width: 420px;
  color:#3f3c4d; /* 見出しの濃い紫グレー */
}

.hero__lead{
  margin:0 0 10px;
  font-size: 30px;
  letter-spacing:.06em;
  font-weight:700;
}

.hero__title{
  margin:0 0 18px;
  font-size: 44px;
  letter-spacing:.08em;
  line-height:1.2;
  font-weight:700;
}

.hero__meta{
  margin:0;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
  line-height: 2.0;
  color: rgba(63,60,77,.80);
}

.hero{ position: relative; }

/* 右の写真（いちばん下） */
.hero__media{
  position:absolute;
  inset:0;
  z-index: 1;
}
.hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position: 75% center;
  display:block;
}

/* グラデ（写真の上） */
.hero__bg{
  position:absolute;
  inset:0;
  z-index: 2;
  pointer-events:none;
  background: linear-gradient(
    90deg,
    rgba(255,255,255,1) 0%,
    rgba(255,255,255,0.98) 30%,
    rgba(255,255,255,0.92) 45%,
    rgba(255,255,255,0.75) 52%,
    rgba(255,255,255,0.40) 60%,
    rgba(255,255,255,0.00) 72%
  );
}

/* ❌ これが隙間の原因 */
.hero{
  padding-top: 76px;
}


/* 文字（いちばん上） */
.hero__copy{
  position:absolute;
  z-index: 3;
  left: 7%;
  top: 50%;
  transform: translateY(-50%);
  max-width: 420px;
  color:#3f3c4d;
  text-shadow:
    0 1px 2px rgba(255,255,255,.6),
    0 0 12px rgba(255,255,255,.4);
}

/* =========================
  Intro section (hero under)
========================= */
.intro{
  padding: 80px 0 40px;
}

.intro-block{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 48px;
  align-items:center;
  margin-bottom: 90px;
}

.intro-block.reverse{
  grid-template-columns: .95fr 1.05fr;
}

.intro-text{
  font-family:"Noto Serif JP","Hiragino Mincho ProN","Yu Mincho",serif;
}

.intro-title{
  font-size:20px;
  letter-spacing:.08em;
  color: var(--ink);
  margin: 0 0 18px;
}

.intro-text p{
  font-size:14px;
  line-height:2.1;
  color: var(--text);
  margin: 0 0 14px;
}

.intro-photo{
  box-shadow: var(--shadow);
}
.intro-photo img{
  width:100%;
  height:auto;
  display:block;
}

/* =========================
  Access / Map
========================= */
.access{
  padding: 44px 0 28px;
}

.access .section-title{
  margin-bottom: 10px;
}

.access-lead{
  margin: 0 0 16px;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
  line-height: 2;
}

.access-map{
  border: 1px solid var(--line);
  background: #fff;
  overflow: hidden;
}

.access-map iframe{
  width: 100%;
  height: 380px;   /* スクショの横長感 */
  border: 0;
  display: block;
}

/* 全幅（100vw / 50vwトリック）を強制解除 */
.access,
.access *{
  max-width: 100%;
}
.access-map{
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* =========================
  Access CTA
========================= */
.access-cta{
  margin-top: 42px;
  padding-top: 26px;
  border-top: 1px solid var(--line);
  text-align: center;
}

.access-cta__title{
  margin: 0 0 14px;
  font-size: 18px;
  color: var(--ink);
  letter-spacing: .08em;
}

.access-cta__text{
  margin: 0 auto 24px;
  max-width: 640px;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
  line-height: 2.0;
}

.access-cta__actions{
  margin-bottom: 18px;
}

.access-cta__meta{
  margin: 0;
  font-size: 12px;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  line-height: 1.8;
}


/* SP */
@media (max-width: 640px){
  .access{
    padding: 34px 0 22px;
  }
  .access-map iframe{
    height: 320px;
  }
}




/* =========================
  Responsive
========================= */
@media (max-width: 980px){
  .hero{
    height: 520px;
    margin-top: 10px;
  }
  .hero__copy{
    left: 7%;
    right: 7%;
    max-width: none;
  }
  .hero__lead{ font-size: 26px; }
  .hero__title{ font-size: 38px; }
}

@media (max-width: 640px){
  .hero{
    height: 520px;
  }
  .hero__bg{
    /* SPは白帯を少し強める（文字が読みやすい） */
    background: linear-gradient(180deg,
      rgba(255,255,255,.95) 0%,
      rgba(255,255,255,.92) 55%,
      rgba(255,255,255,.05) 100%);
  }
  .hero__copy{
    top: 58%;
  }
  .hero__lead{ font-size: 22px; }
  .hero__title{ font-size: 34px; }
}



/* =========================
  Responsive
========================= */
@media (max-width: 980px){
  .icon-nav{ gap:10px; }
  .icon-nav span{ display:none; }
  .grid-cards{ grid-template-columns: repeat(2, 1fr); }
  .news-item{ grid-template-columns: 280px 1fr; }
  .two-col, .two-col.reverse{ grid-template-columns: 1fr; }
  .detail-grid{ grid-template-columns: 1fr; }
  .reco-grid{ grid-template-columns: 1fr 1fr; }
}

@media (max-width: 980px){

  /* アイコンは非表示 */
  .icon-nav{ display:none; }

  /* burger行を“横幅100%”にして、その中でロゴを中央寄せ */
  .header-inner{
    position: relative;
    justify-content: flex-start;
  }

  .burger{
    position: relative;
    flex: 1;
    width: 100%;
    display: flex;
    justify-content: center; /* ←ロゴの親を中央寄せ */
    align-items: center;
    gap: 0;
  }

  /* ハンバーガーは左固定 */
  .burger-btn{
    position: absolute;
    left: 0;
  }

  /* ロゴ（brand）は通常配置に戻す */
  .brand{
    position: static;
    transform: none;
  }
}


@media (max-width: 640px){
  .header-inner{ height:70px; }
  .brand{ min-width:auto; }
  .brand-title strong{ font-size:16px; }
  .page-title{ font-size:28px; }
  .grid-cards{ grid-template-columns: 1fr; }
  .news-item{ grid-template-columns: 1fr; }
  .field{ grid-template-columns: 1fr; }
  .footer-tel{ min-width: 100%; }
  .reco-grid{ grid-template-columns: 1fr; }
  .thumb{ width:140px; }
}
@media (max-width: 980px){
  .icon-nav{ display:none; } /* ←アイコンごと非表示 */
}

/* =========================
  Responsive
========================= */
@media (max-width: 980px){
  .intro{
    padding: 60px 0 20px;
  }
  .intro-block,
  .intro-block.reverse{
    grid-template-columns: 1fr;
    gap: 28px;
    margin-bottom: 60px;
  }
}


/* =========================
  Home News width controller
========================= */

/* ★ここを変えると「お知らせ全体の幅」だけ調整できます */
:root{
  --news-w: 1100px;  /* ← 例：880だと細め / 980で少し広め / 1040でさらに広め */
}

/* section 自体の余白 */
.home-news{
  margin-top: 34px;
}

/* お知らせの“内枠”＝タイトルとリストを同じ幅に揃える */
.home-news__inner{
  width: min(var(--news-w), calc(100% - 48px));
  margin-inline: auto;
}

/* ここから下は中身の整形 */
.home-news .section-title{
  margin: 0 0 14px;
}

/* リストは内枠いっぱいに */
.home-news .news-mini{
  width: 100%;
  border-top: 1px solid var(--line);
  margin-top: 14px;
}

.home-news .news-mini > a{
  display: grid;
  grid-template-columns: 240px 1fr; /* ←左の箱幅（広すぎなら 220px とか） */
  gap: 24px;
  align-items: start;

  padding: 18px 0;
  border-bottom: 1px solid var(--line);
}

.home-news .news-mini > a > .thumb{
  width: 100%;
  height: 110px; /* ←左の箱高さ（大きいなら 96px） */
  background: #d6d6d6;
}

.home-news .news-mini .meta{
  display:flex;
  gap:14px;
  align-items:baseline;
  color: var(--muted);
  font-size: 12px;
  margin: 0 0 10px;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

.home-news .badge-new{
  color:#c21d1d;
  font-weight:700;
}

.home-news .news-mini > a > div:last-child > div:last-child{
  font-size: 18px;
  line-height: 1.75;
  color: var(--text);
  font-family: "Noto Serif JP","Hiragino Mincho ProN","Yu Mincho","YuMincho",serif;

  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.home-news .news-mini > a:hover{
  background: rgba(0,0,0,.015);
}

/* SP */
@media (max-width: 640px){
  :root{ --news-w: 100%; }

  .home-news__inner{
    width: calc(100% - 32px);
  }

  .home-news .news-mini > a{
    grid-template-columns: 120px 1fr;
    gap: 14px;
    padding: 14px 0;
  }
  .home-news .news-mini > a > .thumb{
    height: 80px;
  }
  .home-news .news-mini > a > div:last-child > div:last-child{
    font-size: 14px;
    -webkit-line-clamp: 3;
  }
}

/* =========================
  Home News：サムネ非表示
========================= */

/* グレーのボックスを消す */
.home-news .news-mini .thumb{
  display: none;
}

/* 2カラム → 1カラムに戻す */
.home-news .news-mini > a{
  grid-template-columns: 1fr;
}

/* =========================================================
  HOME: Buy block + CTA (COMPLETE)
  既存の .two-col / .btn / .tri / .hr を活かしつつ整える
========================================================= */

/* -------- Buy block -------- */
.home-buy{
  /* セクションの上下余白（カンプ寄せ） */
  padding: 56px 0 30px;
}

/* two-colの土台が無い/弱い場合の保険（既存があるなら上書きされてもOK） */
.two-col{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 44px;
  align-items: center;
}
.two-col.reverse{ direction: rtl; }
.two-col.reverse > *{ direction: ltr; }

/* 左テキスト側 */
.home-buy__text{
  max-width: 520px;
}

/* kagi + section-title を想定（既存があるならそれを優先でOK） */
.home-buy .section-title{
  margin: 0 0 12px;
}

/* 冒頭の短い説明 */
.home-buy__sub{
  margin: 0 0 26px;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
  line-height: 2;
}

/* 太めの見出し（カンプの強弱） */
.home-buy__headline{
  margin: 0 0 14px;
  color: var(--text);
  font-size: 20px;
  line-height: 1.9;
  letter-spacing: .02em;
  font-weight: 700;
}

/* 説明 */
.home-buy__desc{
  margin: 0 0 24px;
  color: var(--text);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
  line-height: 2;
}

/* ボタン位置（左寄せ） */
.home-buy__btn{
  text-align: left;
}

/* 右画像側 */
.home-buy__media{
  /* 右の写真枠を“カンプの四角”に寄せる */
  width: 100%;
  max-width: 520px;
  margin-left: auto;
  border: 1px solid var(--line);
  background:#fff;
  overflow: hidden;
}
.home-buy__media img{
  width:100%;
  height:100%;
  display:block;
  object-fit: cover;
  aspect-ratio: 4 / 3; /* きれいに揃う比率 */
}

/* -------- CTA block -------- */
.home-cta{
  padding: 44px 0 56px;
}

.home-cta__inner{
  /* AccessやNewsと揃う“中央内枠” */
  width: min(980px, calc(100% - 48px));
  margin-inline: auto;
  border-top: 1px solid var(--line);
  padding-top: 28px;
  text-align: center;
}

.home-cta__title{
  margin: 0 0 12px;
  font-size: 18px;
  color: var(--text);
  letter-spacing: .08em;
  font-weight: 700;
}

.home-cta__lead{
  margin: 0 auto 22px;
  max-width: 860px;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
  line-height: 2;
}

.home-cta__btn{
  margin: 0 0 14px;
}

.home-cta__note{
  margin: 0;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 12px;
  line-height: 1.9;
}

/* -------- Responsive -------- */
@media (max-width: 900px){
  .two-col{
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .home-buy__text{ max-width: none; }
  .home-buy__media{ max-width: none; margin-left: 0; }
}

@media (max-width: 640px){
  .home-buy{ padding: 40px 0 22px; }
  .home-buy__headline{ font-size: 18px; }
  .home-cta__inner{ width: calc(100% - 32px); padding-top: 22px; }
}

/* =========================
  Global content width (1100px)
========================= */
:root{
  --content-w: 1100px;
  --gutter: 24px;          /* 余白（PC） */
  --gutter-sp: 16px;       /* 余白（SP） */
}

/* 既に .container がある前提で上書き（無ければそのまま新規定義として効きます） */
.container{
  width: min(var(--content-w), calc(100% - (var(--gutter) * 2)));
  margin-inline: auto;
}

/* sectionが直下にフル幅で並んでいる場合の保険（必要なら） */
main > section,
main > .section,
main > .home-news,
main > .access{
  width: 100%;
}

/* SP */
@media (max-width: 640px){
  .container{
    width: calc(100% - (var(--gutter-sp) * 2));
  }
}

/* =========================
  Buy stock slider
========================= */
.buy-stock{
  padding: 40px 0 28px;
}

.buy-stock__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 22px;
  margin: 0 0 14px;
}

.buy-stock__title{
  margin:0 0 8px;
  font-size: 18px;
  color: var(--text);
  letter-spacing: .08em;
}

.buy-stock__lead{
  margin:0;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
  line-height: 2;
  max-width: 760px;
}

.buy-stock__meta{
  display:flex;
  align-items:center;
  gap: 14px;
  white-space: nowrap;
}

.buy-stock__count{
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 12px;
}
.buy-stock__count b{
  color: var(--text);
  font-weight: 700;
}

.buy-stock__nav{
  display:flex;
  gap: 10px;
}

.buy-stock__btn{
  width: 40px;
  height: 40px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  border-radius: 999px;
  cursor: pointer;
  line-height: 1;
  font-size: 20px;
}
.buy-stock__btn:disabled{
  opacity: .35;
  cursor: default;
}

/* rail */
.buy-stock__rail{
  border: 1px solid var(--line);
  background: #fff;
  overflow: hidden;
  padding: 18px 18px 16px;
}

/* track */
.buy-stock__track{
  display:flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.buy-stock__track::-webkit-scrollbar{ display:none; }

/* card */
.stock-card{
  scroll-snap-align: start;
  flex: 0 0 240px; /* ここでカード幅を調整 */
  border: 1px solid var(--line);
  background:#fff;
}

.stock-card__img{
  aspect-ratio: 4 / 3;
  background: #d6d6d6; /* 画像が無い場合のダミー */
}
.stock-card__img img{
  width:100%;
  height:100%;
  display:block;
  object-fit: cover;
}

.stock-card__body{
  padding: 12px 12px 14px;
}

.stock-card__title{
  margin: 0 0 10px;
  font-size: 13px;
  line-height: 1.7;
  color: var(--text);
}

.stock-card__price{
  margin: 0 0 8px;
  font-size: 18px;
  letter-spacing: .06em;
  color: var(--ink);
  font-weight: 700;
}

.stock-card__meta{
  margin: 0;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 12px;
  line-height: 1.8;
}

/* progress bar */
.buy-stock__bar{
  height: 6px;
  background: #e8e8e8;
  border-radius: 999px;
  margin-top: 12px;
  overflow: hidden;
}
.buy-stock__barfill{
  height: 100%;
  width: 20%;
  background: #3f3f52; /* フッターに近い色 */
  border-radius: 999px;
  transform-origin: left;
  transform: scaleX(.2);
}

/* SP */
@media (max-width: 640px){
  .buy-stock__head{
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  .buy-stock__rail{
    padding: 14px 14px 12px;
  }
  .stock-card{
    flex-basis: 78vw; /* SPは大きめ */
  }
}

/* =========================
  Guide block (under Buy)
========================= */
.home-guide{
  padding: 44px 0 22px;
}

.home-guide__inner{
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 34px;
  align-items: start;
}

/* 左：画像 */
.home-guide__media{
  background: #fff;
}
.home-guide__media img{
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

/* 右：文章 */
.home-guide__title{
  margin: 0 0 10px;
  font-size: 22px;
  letter-spacing: .04em;
  color: var(--ink);
}

.home-guide__text{
  margin: 0;
  color: var(--text);
  font-size: 13px;
  line-height: 2.05;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

/* 下の追記文 */
.home-guide__note{
  margin: 18px 0 0;
  color: var(--text);
  font-size: 13px;
  line-height: 2.05;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

/* ボタン中央 */
.home-guide__btn{
  margin-top: 18px;
  text-align: center;
}

/* SP */
@media (max-width: 900px){
  .home-guide__inner{
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .home-guide__title{
    font-size: 20px;
  }
}

/* =========================
  Rent guide
========================= */
/*
.home-rent{
  padding: 46px 0 34px;
}

.home-rent__inner{
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 48px;
  align-items: start;
}
*/

/* 左 */
.home-rent__title{
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 0 14px;
  font-size: 22px;
  color: var(--ink);
  letter-spacing: .04em;
}

.home-rent__bar{
  width: 4px;
  height: 28px;
  background: var(--ink);
  display: inline-block;
}

.home-rent__catch{
  font-size: 16px;
  font-weight: 600;
  line-height: 1.9;
  margin: 0 0 12px;
}

.home-rent__text{
  font-size: 13px;
  line-height: 2;
  margin: 0 0 10px;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

.home-rent__btn{
  margin-top: 16px;
  text-align: left;
}



/* =========================
  Home Rent (COMP)
========================= */

/* 全体の最大幅（このページ内を 1100px基準に） */
.container{
  width: min(1100px, calc(100% - 48px));
  margin-inline: auto;
}

/* 上：2カラム */
.home-rent{
  padding: 56px 0 10px;
}
.home-rent__inner{
  display: grid;
  grid-template-columns: 1fr 520px; /* 左テキスト / 右ビジュアル */
  gap: 56px;
  align-items: start;
}

/* 左：罫線つきテキスト枠 */
.home-rent__body{
  position: relative;
  padding: 6px 0 22px 18px;  /* 左の太線の分だけ内側へ */
}
.home-rent__bar{
  position: absolute;
  left: 0;
  top: 10px;
  width: 4px;
  height: calc(100% - 10px);
  background: #2f2e3b; /* いつもの濃いグレー */
}
.home-rent__title{
  margin: 0 0 18px;
  font-size: 28px;
  letter-spacing: .02em;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 12px;
}
.home-rent__line{
  height: 1px;
  background: var(--line);
  flex: 1;
  margin-left: 14px;
  opacity: .9;
}

.home-rent__catch{
  font-size: 18px;
  font-weight: 700;
  line-height: 1.9;
  margin: 0 0 18px;
  color: var(--ink);
}
.home-rent__text{
  margin: 0 0 12px;
  color: var(--text);
  line-height: 2.05;
  font-size: 14px;
}

/* 下線（左ブロックの最下部の横線） */
.home-rent__bottomline{
  display: block;
  height: 2px;
  background: var(--line);
  margin-top: 18px;
  width: 100%;
  opacity: .9;
}

/* 右：グレーの大枠（画像を入れるなら background-image でもOK） */
.home-rent__media{
  background: #9c9c9c;
  width: 100%;
  aspect-ratio: 1 / 1;  /* カンプの正方形感 */
}

/* =========================
  Note block (これからの暮らし)
========================= */
.home-rent__note{
  margin-top: 38px;
}
.home-rent__noteTitle{
  margin: 0 0 14px;
  font-size: 22px;
  letter-spacing: .02em;
  color: var(--ink);
  position: relative;
  padding-bottom: 10px;
}
.home-rent__noteTitle::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background: var(--line);
}
.home-rent__note p{
  margin: 0 0 14px;
  line-height: 2.1;
  color: var(--text);
  font-size: 14px;
}

/* =========================
  Consult block (お気軽にご相談ください)
========================= */
.home-consult{
  margin-top: 34px;
  padding-bottom: 22px;
}
.home-consult__title{
  margin: 0 0 10px;
  font-size: 22px;
  letter-spacing: .02em;
  color: var(--ink);
}
.home-consult__rule{
  height: 1px;
  background: var(--line);
  margin-bottom: 18px;
}

.home-consult__inner{
  display: grid;
  grid-template-columns: 1fr 420px; /* 左文章 / 右画像 */
  gap: 40px;
  align-items: center;
}

.home-consult__text{
  margin: 0;
  line-height: 2.1;
  color: var(--text);
  font-size: 14px;
}

/* 右の画像（img111-100.jpg） */
.home-consult__art{
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.home-consult__art img{
  width: min(420px, 100%);
  height: auto;
  display: block;
}

/* ボタン中央 */
.home-consult__btn{
  margin-top: 22px;
  text-align: center;
}

/* =========================
  Responsive
========================= */
@media (max-width: 980px){
  .home-rent__inner{
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .home-rent__media{
    aspect-ratio: 16 / 9;
  }
  .home-consult__inner{
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .home-consult__art{
    justify-content: center;
  }
}

/* =========================
  Home Share (COMP)
========================= */
.home-share{
  padding: 56px 0 10px;
}

/* 上：2カラム */
.home-share__inner{
  display: grid;
  grid-template-columns: 1fr 520px; /* 左テキスト / 右ビジュアル */
  gap: 56px;
  align-items: start;
}

/* 左：罫線つき枠 */
.home-share__body{
  position: relative;
  padding: 6px 0 22px 18px;
}
.home-share__bar{
  position: absolute;
  left: 0;
  top: 10px;
  width: 4px;
  height: calc(100% - 10px);
  background: #2f2e3b;
}
.home-share__title{
  margin: 0 0 18px;
  font-size: 28px;
  letter-spacing: .02em;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 12px;
}
.home-share__line{
  height: 1px;
  background: var(--line);
  flex: 1;
  margin-left: 14px;
  opacity: .9;
}
.home-share__catch{
  font-size: 18px;
  font-weight: 700;
  line-height: 1.9;
  margin: 0 0 12px;
  color: var(--ink);
}
.home-share__text{
  margin: 0 0 12px;
  color: var(--text);
  line-height: 2.05;
  font-size: 14px;
}
.home-share__bottomline{
  display: block;
  height: 2px;
  background: var(--line);
  margin-top: 18px;
  width: 100%;
  opacity: .9;
}

/* 右：グレー枠 */
/* =====================================================
  home-share media（縦横バランス調整）
===================================================== */
.home-share__media{
  width: 80%;
  max-width: 560px;

  aspect-ratio: 4 / 3; /* ← 賃貸より横長 */
  overflow: hidden;
  border-radius: 6px;
  background: #eee;

  display: flex;
  align-items: center;
  justify-content: center;
}

.home-share__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 45%; /* 少し下寄り（建物全体見せ） */
}


/* NOTE */
.home-share__note{
  margin-top: 38px;
}
.home-share__noteTitle{
  margin: 0 0 14px;
  font-size: 22px;
  letter-spacing: .02em;
  color: var(--ink);
  position: relative;
  padding-bottom: 10px;
}
.home-share__noteTitle::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background: var(--line);
}
.home-share__note p{
  margin: 0 0 14px;
  line-height: 2.1;
  color: var(--text);
  font-size: 14px;
}

/* =========================
  Share Stock Slider
========================= */
.share-stock{
  margin-top: 18px;
  padding-top: 10px;
}

.share-stock__head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 18px;
  margin: 12px 0 12px;
}

.share-stock__stockTitle{
  margin: 0;
  font-size: 18px;
  letter-spacing: .02em;
  color: var(--ink);
}

.share-stock__nav{
  display:flex;
  gap: 10px;
}
.share-stock__btn{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  cursor: pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.share-stock__btn:hover{
  background: rgba(0,0,0,.03);
}

.share-stock__rail{
  border: 1px solid var(--line);
  background: #fff;
  overflow: hidden;
}

.share-stock__track{
  display:flex;
  gap: 18px;
  padding: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
}
.share-stock__track::-webkit-scrollbar{
  height: 10px;
}
.share-stock__track::-webkit-scrollbar-thumb{
  background: rgba(0,0,0,.2);
  border-radius: 999px;
}
.share-stock__track::-webkit-scrollbar-track{
  background: rgba(0,0,0,.08);
  border-radius: 999px;
}

.share-card{
  flex: 0 0 240px;
  border: 1px solid var(--line);
  background: #fff;
  scroll-snap-align: start;
}
.share-card__thumb{
  height: 120px;
  background: #cfcfcf;
}
.share-card__body{
  padding: 12px;
}
.share-card__title{
  margin: 0 0 8px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink);
}
.share-card__meta{
  margin: 0;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.8;
}

/* 下のバー（カンプの細いゲージ） */
.share-stock__bar{
  height: 8px;
  background: rgba(0,0,0,.12);
  border-radius: 999px;
  margin: 12px 0 0;
  overflow: hidden;
}
.share-stock__barfill{
  height: 100%;
  width: 30%;
  background: #2f2e3b;
  border-radius: 999px;
  transform-origin: left center;
}

/* SP */
@media (max-width: 980px){
  .home-share__inner{
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .home-share__media{
    aspect-ratio: 16 / 9;
  }
}

/* =========================
  Buy Stock Slider (Latest)
========================= */

.buy-stock__head{
  display:flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 24px;
  margin-bottom: 16px;
}

.buy-stock__title{
  margin: 0 0 10px;
  font-size: 28px;
  letter-spacing: .02em;
}

.buy-stock__lead{
  margin: 0;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
  line-height: 2;
}

.buy-stock__meta{
  display:flex;
  align-items:center;
  gap: 14px;
  white-space: nowrap;
  color: var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size: 13px;
}

.buy-stock__count b{
  color: var(--text);
  font-weight: 700;
}

.buy-stock__nav{
  display:flex;
  gap: 10px;
}

.buy-stock__btn{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background:#fff;
  cursor: pointer;
  line-height: 1;
  font-size: 20px;
  color: var(--text);
}
.buy-stock__btn:disabled{
  opacity: .35;
  cursor: not-allowed;
}

/* 枠 */
.buy-stock__rail{
  border: 1px solid var(--line);
  background:#fff;
  overflow: hidden;
}

/* ★横並びの本体（これが無いと1枚だけの巨大カードになります） */
.buy-stock__track{
  display: flex;
  gap: 18px;
  padding: 18px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;        /* Firefox */
}
.buy-stock__track::-webkit-scrollbar{ display:none; }

/* カード（JSが吐く stock-card に合わせる） */
.stock-card{
  flex: 0 0 calc((100% - 18px * 3) / 4); /* ★PCは4枚見せ */
  min-width: 240px;                      /* 縮みすぎ防止 */
  border: 1px solid var(--line);
  background:#fff;
  text-decoration:none;
  color: inherit;
  scroll-snap-align: start;
}

.stock-card__img{
  width: 100%;
  aspect-ratio: 4 / 3;
  background: #d6d6d6;
  overflow:hidden;
}
.stock-card__img img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.stock-card__body{
  padding: 14px 14px 16px;
}

.stock-card__title{
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 1.7;
}

.stock-card__price{
  margin: 0 0 10px;
  font-size: 20px;
  letter-spacing: .06em;
}

.stock-card__meta{
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.75;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

/* 下の進捗バー */
.buy-stock__bar{
  height: 6px;
  background:#e6e6e6;
  border-radius: 999px;
  overflow:hidden;
  margin-top: 12px;
}
.buy-stock__barfill{
  height: 100%;
  background:#3f3f51;
  border-radius: 999px;
  transform-origin: left; /* ★左から伸びる */
  transform: scaleX(.12); /* 初期値 */
}

/* SP */
@media (max-width: 900px){
  .buy-stock__head{ align-items: flex-start; }
  .stock-card{
    flex-basis: calc((100% - 18px) / 2);  /* タブレットは2枚 */
  }
}
@media (max-width: 640px){
  .buy-stock .container{ padding: 0 16px; }
  .buy-stock__head{
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .stock-card{
    flex-basis: 80%;                      /* SPはほぼ1枚 */
    min-width: 0;
  }
}

/* =========================
  Share Stock Slider
========================= */

.share-stock{
  margin-top: 26px;
}

/* head */
.share-stock__head{
  display:flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 0 0 12px;
}

.share-stock__stockTitle{
  margin: 0;
  font-size: 18px;
  letter-spacing: .02em;
}

/* nav btn */
.share-stock__nav{
  display:flex;
  gap: 10px;
}
.share-stock__btn{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background:#fff;
  cursor: pointer;
  line-height: 1;
  font-size: 20px;
  color: var(--text);
}
.share-stock__btn:disabled{
  opacity: .35;
  cursor: not-allowed;
}

/* rail + track */
.share-stock__rail{
  border: 1px solid var(--line);
  background:#fff;
  overflow: hidden;
}

.share-stock__track{
  display:flex;
  gap: 18px;
  padding: 18px;
  overflow-x:auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width:none;
}
.share-stock__track::-webkit-scrollbar{ display:none; }

/* card（buyと共通の stock-card をそのまま使う） */
.share-stock .stock-card{
  flex: 0 0 calc((100% - 18px * 3) / 4);
  min-width: 240px;
  scroll-snap-align: start;
}

/* bar */
.share-stock__bar{
  height: 6px;
  background:#e6e6e6;
  border-radius: 999px;
  overflow:hidden;
  margin-top: 12px;
}
.share-stock__barfill{
  height:100%;
  background:#3f3f51;
  border-radius: 999px;
  transform-origin: left;
  transform: scaleX(.12);
}

/* share-stock head meta（在庫◯件 + 丸ボタン） */
.share-stock__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
}

.share-stock__meta{
  display:flex;
  align-items:center;
  gap:16px;
}

.share-stock__count{
  font-size:14px;
  color: var(--muted);
  white-space:nowrap;
}
.share-stock__count b{
  color: var(--text);
  font-weight:700;
}


/* responsive */
@media (max-width: 900px){
  .share-stock .stock-card{
    flex-basis: calc((100% - 18px) / 2);
  }
}
@media (max-width: 640px){
  .share-stock__head{ align-items: flex-start; }
  .share-stock .stock-card{
    flex-basis: 80%;
    min-width: 0;
  }
}

/* =========================
   HERO: SPでは白い影(幕)を消す
========================= */
@media (max-width: 699px){

  /* 白い幕の犯人が hero__bg / ::before / ::after のどれでも消えるように */
  .hero__bg{ background: transparent !important; }

  .hero::before,
  .hero::after{
    background: transparent !important;
    opacity: 1 !important;
  }

  /* もし画像側に opacity/filter が当たってたら解除 */
  .hero__media,
  .hero__media img{
    opacity: 1 !important;
    filter: none !important;
  }

  /* 画像はcoverで見せる */
  .hero__media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 70% 30%; /* ここは好みで調整 */
  }
}

/* =========================
   HERO 文字背景（白い影）
========================= */
.hero__copy{
  position: relative;
  z-index: 2;
  padding: 28px 32px;
  max-width: 520px;

  /* 白い影の正体 */
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

/* SP：ヒーローコピーを左上に配置 */
@media (max-width: 899px){
  .hero{
    position: relative;
  }

  .hero__copy{
    position: absolute;
    top: 88px;        /* ← ヘッダー＋ロゴ分の安全距離 */
    left: 16px;
    right: auto;
    bottom: auto;
    transform: none;

    max-width: 78%;
  }
}

/* SP：ヒーローコピー 左から出現 */
@media (max-width: 899px){
  .hero{ position: relative; }

  .hero__copy{
    position:absolute;
    top: 88px;
    left: 12px;
    right: auto;
    transform: translateX(-14px);  /* ← 最初は左に少しオフ */
    opacity: 0;

    max-width: 72%;
    padding: 12px 14px;
    background: rgba(255,255,255,0.32);
    backdrop-filter: blur(5px);
    border-radius: 6px;

    /* アニメ */
    animation: heroCopyInL2R .55s cubic-bezier(.22,.9,.2,1) .15s forwards;
  }

  @keyframes heroCopyInL2R{
    to{
      transform: translateX(0);
      opacity: 1;
    }
  }

  /* 文字サイズ（前回の一回り小さく） */
  .hero__lead{ font-size: 14px; }
  .hero__title{ font-size: 22px; line-height: 1.35; }
  .hero__meta{ font-size: 12px; line-height: 1.6; }

  /* モーション苦手な人へ配慮 */
  @media (prefers-reduced-motion: reduce){
    .hero__copy{ animation: none; opacity: 1; transform: none; }
  }
}

@media (max-width: 899px){
  .hero__copy{
    opacity: 0;
    transform: translateX(-14px);
    transition: transform .55s cubic-bezier(.22,.9,.2,1), opacity .55s ease;
    transition-delay: .12s;
  }
  body.is-hero-in .hero__copy{
    opacity: 1;
    transform: translateX(0);
  }

  @media (prefers-reduced-motion: reduce){
    .hero__copy{ transition: none; opacity: 1; transform: none; }
  }
}



@media (max-width: 699px){
  .hero__copy{
    padding: 20px 18px;
    max-width: none;
    margin: 0 16px;

    background: rgba(255,255,255,0.85);
    backdrop-filter: blur(4px);
  }
}

/* =========================
   Hero copy box
========================= */

.hero-copy--left{
  position:absolute;
  top:18%;
  left:0;                 /* ← 左にぴったり */
  max-width:520px;
  padding:28px 36px 30px 32px;

  background: rgba(255,255,255,.65); /* ← 薄い */
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);

  border-radius:0;        /* ← カード感を消す */
  box-shadow:none;

  /* アニメーション初期状態 */
  transform: translateX(-40px);
  opacity:0;
}

/* 表示状態 */
.hero-copy--left.is-show{
  transform: translateX(0);
  opacity:1;
  transition:
    transform .9s cubic-bezier(.22,.61,.36,1),
    opacity   .8s ease;
}

/* text */
.hero-copy__lead{
  font-size:16px;
  margin-bottom:6px;
}

.hero-copy__title{
  font-size:34px;
  line-height:1.35;
  margin-bottom:12px;
}

.hero-copy__meta{
  font-size:14px;
  line-height:1.6;
  opacity:.85;
}

/* =========================
   SP調整
========================= */
@media (max-width: 768px){
  .hero-copy--left{
    top:14%;
    max-width:88%;
    padding:22px 20px 22px 18px;
    background: rgba(255,255,255,.72); /* SPは少し濃く */
  }

  .hero-copy__title{
    font-size:26px;
  }
}

/* ヒーローの重なり順を固定（文字が消えるのを防ぐ） */
.hero__media{ z-index:1; }
.hero__bg{ z-index:2; }
.hero-copy--left{ z-index:3; } /* ★これが重要 */

/* ===== Hero copy：PC位置修正（下寄せ） ===== */
@media (min-width: 981px){
  .hero-copy--left{
    position: absolute;
    left: 6vw;          /* ← 左にくっつける */
    bottom: 12vh;       /* ← ★ここがポイント：下の位置 */
    top: auto;          /* 上の指定を無効化 */
    transform: translateX(-48px); /* 初期アニメ位置（左から） */
    max-width: 520px;   /* サイズ一回り小さく */
  }

  .hero-copy--left.is-show{
    transform: translateX(0);
  }
}


/* SP：薄い白背景を付ける（読みやすさ優先） */
@media (max-width: 980px){
  .hero-copy--left{
    background: rgba(255,255,255,.55); /* ←薄め（好みで .45〜.65） */
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    text-shadow: none;
  }
}



/* =========================================
  SP typography: 全体を少し小さく
========================================= */
@media (max-width: 640px){
  body{
    font-size: 14px;
  }

  /* 共通見出し/リード */
  .section-title{ font-size: 16px; }
  .lead{ font-size: 13px; }

  /* ボタン */
  .btn{
    font-size: 14px;
    padding: 12px 16px;
  }

  /* 住まいの購入（HOME） */
  .home-buy__sub{ font-size: 12px; }
  .home-buy__headline{ font-size: 18px; line-height: 1.8; }
  .home-buy__desc{ font-size: 12px; }
}


/* =========================================================
  home-buy（住まいの購入）: 余白・中央揃え・SP最適化
========================================================= */

/* SP: 1カラム化して左ズレ解消 + 文字サイズ全体を少し小さく */
@media (max-width: 700px){

  /* 全体的に文字を一回り小さく */
  body{
    font-size: 14px;
  }

  /* 2カラム → 1カラム */
  .two-col{
    grid-template-columns: 1fr;
    gap: 22px;
  }

  /* reverseのRTLはSPでは解除（ズレ/並び順事故防止） */
  .two-col.reverse{
    direction: ltr;
  }

  /* セクション自体の左右余白を確保（左に寄るのを止める） */
  .home-buy.two-col{
    width: 100%;
    margin-inline: 0;
    padding-inline: 20px;
  }

  /* テキスト側の幅制限を解除 */
  .home-buy__text{
    max-width: none;
  }

  /* 画像側も幅制限解除 & 左寄せに */
  .home-buy__media{
    max-width: none;
    margin-left: 0;
  }

  /* 見出し類を少し小さく */
  .home-buy__sub,
  .home-buy__desc{
    font-size: 12.5px;
    line-height: 1.9;
  }

  .home-buy__headline{
    font-size: 18px;
    line-height: 1.8;
  }
}
/* PC */
@media (min-width: 900px){
  .home-rent__media{
    aspect-ratio: 3 / 4;
    max-width: 520px;
  }
}

/* タブレット */
@media (max-width: 899px){
  .home-rent__media{
    width: 100%;
    aspect-ratio: 4 / 5;
  }
}

/* スマホ */
@media (max-width: 600px){
  .home-rent__media{
    width: 100%;
    aspect-ratio: 1 / 1; /* SPは正方形にすると安定 */
  }

  .home-rent__media img{
    object-position: 50% 40%;
  }
}

/* タブレット */
@media (max-width: 900px){
  .home-share__media{
    width: 100%;
    aspect-ratio: 16 / 9; /* 横いっぱいで気持ちいい */
  }
}

/* スマホ */
@media (max-width: 600px){
  .home-share__media{
    width: 100%;
    aspect-ratio: 1 / 1; /* SPは正方形が安定 */
    border-radius: 4px;
  }

  .home-share__media img{
    object-position: 50% 40%;
  }
}

/* =====================================================
  FIX: home-rent__note がフル幅になって崩れるのを修正
  + SPの文字サイズを全体的に少し小さく
===================================================== */

/* まず“幅の基準”を1つに固定（containerの上書き事故を吸収） */
:root{
  --content-w: 1100px;
  --gutter-pc: 24px;
  --gutter-sp: 16px;
}

/* containerは常にこの幅 */
.container{
  width: min(var(--content-w), calc(100% - (var(--gutter-pc) * 2)));
  margin-inline: auto;
}


/* タイトル・段落の見た目を安定させる */
.home-rent__noteTitle{
  margin: 0 0 14px;
  font-size: 22px;
  letter-spacing: .02em;
  color: var(--ink);
  position: relative;
  padding-bottom: 10px;
}
.home-rent__noteTitle::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background: var(--line);
}

/* “間延び”防止（ここ重要） */
.home-rent__note p{
  margin: 0 0 14px;
  line-height: 2.1;
  font-size: 14px;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  letter-spacing: .02em;
  text-align: left;
  word-break: normal;
  overflow-wrap: anywhere;
}

/* SP：左右余白と文字サイズを少し小さく */
@media (max-width: 640px){
  body{ font-size: 14px; }

  .container{
    width: calc(100% - (var(--gutter-sp) * 2));
  }

  .home-rent__note{
    padding-inline: var(--gutter-sp);
    margin-top: 28px;
  }

  /* 全体の見出し系を少しだけ小さく */
  .section-title{ font-size: 16px; }
  .home-rent__title,
  .home-share__title,
  .buy-stock__title{ font-size: 22px; }

  /* 本文系も一段小さく */
  .home-rent__text,
  .home-share__text,
  .home-rent__note p,
  .home-share__note p{
    font-size: 13px;
    line-height: 2.0;
  }

  .btn{
    font-size: 13px;
    padding: 11px 14px;
    min-width: 200px;
  }
}

/* =====================================================
  FIX: home-consult（お気軽にご相談ください）も幅崩れ防止
===================================================== */

/* タイトルと罫線も揃える */
.home-consult__title{
  margin: 0 0 10px;
  font-size: 22px;
  letter-spacing: .02em;
  color: var(--ink);
}

/* 横罫線をフルに伸ばす */
.home-consult__rule{
  height: 1px;
  background: var(--line);
  margin-bottom: 18px;
  width: 100%;
}

/* 中身2カラムが変な幅にならないように */
.home-consult__inner{
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 40px;
  align-items: center;
}

/* 右画像がはみ出す事故防止 */
.home-consult__art img{
  max-width: 100%;
  height: auto;
  display: block;
}

/* SP：左右余白と並びを最適化 */
@media (max-width: 640px){
  .home-consult{
    padding-inline: var(--gutter-sp);
    margin-top: 28px;
  }

  .home-consult__title{
    font-size: 20px;
  }

  .home-consult__inner{
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .home-consult__text{
    font-size: 13px;
    line-height: 2.0;
  }
}

/* =====================================
  FIX：賃貸 右画像を「横向き」にする
===================================== */
.home-rent__media{
  width: 100%;
  max-width: 520px;

  aspect-ratio: 4 / 3;   /* ← 横向き（16/9にしたければ 16 / 9） */
  background: #eee;
  overflow: hidden;
  border-radius: 6px;
}

.home-rent__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 45%; /* 建物が切れにくい位置 */
  display: block;
}

/* =========================================
  Footer layout fix (responsive)
  - PC: Brand / Tel box / Nav in a stable grid
  - SP: stack + nav 2 columns
========================================= */

/* 外枠 */
.site-footer{
  padding: 44px 0 28px;
}

/* 上段を「グリッド」で安定させる */
.footer-top{
  display: grid;
  grid-template-columns: 1fr 1.2fr; /* 左：ブランド / 右：TEL */
  gap: 22px 28px;
  align-items: start;
}

/* ブランド */
.footer-brand{
  display:flex;
  align-items:center;
  gap: 14px;
  min-width: 0;
}
.footer-brand .mark{
  width: 144px;  /* 144 → 少し小さく */
  height: auto;
}
.footer-brand .name strong{
  font-size: 20px;
}

/* TEL枠：右に揃えて、幅も安定 */
.footer-tel{
  justify-self: end;
  width: min(520px, 100%);
  min-width: 0;
  padding: 16px 18px;
}
.footer-tel .num{
  font-size: 26px;
  letter-spacing: .08em;
}

/* ナビ：flex wrap をやめて “グリッド” にする */
.footer-nav{
  margin-top: 26px;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr)); /* 5個横並び */
  gap: 14px 18px;
  font-size: 13px;
  opacity: .92;
}
.footer-nav a{
  display:block;
  padding: 6px 0;
  white-space: nowrap; /* 変な改行防止 */
}

/* 下段 */
.footer-bottom{
  margin-top: 26px;
  font-size: 12px;
  opacity: .75;
}

/* =========================
  Tablet
========================= */
@media (max-width: 980px){
  .footer-top{
    grid-template-columns: 1fr; /* 縦積み */
  }
  .footer-tel{
    justify-self: start; /* 左寄せ */
    width: 100%;
  }
  .footer-nav{
    grid-template-columns: repeat(3, minmax(0, 1fr)); /* 3列 */
  }
}

/* =========================
  SP
========================= */
@media (max-width: 640px){
  .site-footer{
    padding: 38px 0 24px;
  }

  .footer-brand{
    gap: 12px;
  }
  .footer-brand .mark{
    width: 140px;
  }
  .footer-brand .name strong{
    font-size: 18px;
  }

  .footer-tel{
    padding: 14px 14px;
  }
  .footer-tel .cap{ font-size: 12px; }
  .footer-tel .num{ font-size: 22px; }
  .footer-tel .sub{ font-size: 12px; }

  /* ナビは2列に固定して段差をなくす */
  .footer-nav{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 18px;
    font-size: 13px;
  }
  .footer-nav a{
    padding: 8px 0;
  }
}

/* =========================
  Scroll Inview (ふわっと出現)
========================= */
.js-inview{
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .7s ease, transform .7s cubic-bezier(.22,.9,.2,1);
  will-change: opacity, transform;
}

/* 画面に入ったら */
.js-inview.is-inview{
  opacity: 1;
  transform: translateY(0);
}

/* モーション苦手な人へ配慮 */
@media (prefers-reduced-motion: reduce){
  .js-inview{
    transition: none;
    opacity: 1;
    transform: none;
  }
}


/* buy.html：固定ヘッダーとページ見出しの被り対策 */
main.page{
  padding-top: 110px; /* ヘッダー高さ + 余白（必要なら増減）
*/
  padding-bottom: 0;
}

.js-inview {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.8s ease,
    transform 0.8s ease;
  will-change: opacity, transform;
}

.js-inview.is-inview {
  opacity: 1;
  transform: translateY(0);
}


/* -------------------------
   トップページのお知らせ
------------------------- */
.home-news{
  padding:64px 0;
}

.home-news .section-title{
  font-size:clamp(28px, 3.2vw, 44px);
  margin:0 0 28px;
  color:var(--text);
}

.news-mini{
  border-top:1px solid var(--line);
}

.news-mini > a{
  display:block;
  text-decoration:none;
  color:inherit;
  padding:28px 0 30px;
  border-bottom:1px solid var(--line);
  transition:opacity .25s ease;
}

.news-mini > a:hover{
  opacity:.72;
}

.news-mini .thumb{
  display:none !important;
}

.news-mini .meta{
  display:flex;
  align-items:center;
  gap:18px;
  margin:0 0 16px;
  font-size:14px;
  color:var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

.news-mini .meta time{
  color:var(--muted);
}

.news-mini > a > div:last-child > div:last-child{
  font-size:clamp(22px, 2.2vw, 28px);
  line-height:1.7;
  letter-spacing:.02em;
  color:var(--text);
  font-weight:600;
}

.home-news .btn-wrap{
  margin-top:44px;
  text-align:center;
}

/* -------------------------
   お知らせ一覧ページ
------------------------- */
.news-list{
  margin-top:28px;
  border-top:1px solid var(--line);
}

.news-item{
  padding:30px 0 34px;
  border-bottom:1px solid var(--line);
}

.news-item .meta{
  display:flex;
  align-items:center;
  gap:18px;
  margin:0 0 16px;
  font-size:14px;
  color:var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

.news-item .meta time{
  color:var(--muted);
}

.news-item h3{
  margin:0 0 14px;
  font-size:clamp(26px, 2.3vw, 40px);
  line-height:1.6;
  letter-spacing:.02em;
  color:var(--text);
  font-weight:600;
}

.news-item .lead{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:2;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

.news-item .thumb{
  display:none !important;
}

/* ニュースページのページャ */
.page[data-page="news"] .subhead{
  margin-top:24px;
}

.page[data-page="news"] .pager{
  font-size:14px;
  color:var(--muted);
}

.page[data-page="news"] .pager a{
  color:var(--text);
  text-decoration:none;
  font-weight:700;
  margin-left:8px;
}

.page[data-page="news"] .pager a.is-current{
  color:var(--text);
}

/* スマホ */
@media (max-width: 768px){
  .home-news{
    padding:48px 0;
  }

  .home-news__inner{
    width:min(100%, calc(100% - 32px));
  }

  .news-mini > a{
    padding:22px 0 24px;
  }

  .news-mini .meta,
  .news-item .meta{
    gap:12px;
    font-size:13px;
    margin-bottom:12px;
  }

  .news-mini > a > div:last-child > div:last-child{
    font-size:20px;
    line-height:1.75;
  }

  .news-item{
    padding:24px 0 28px;
  }

  .news-item h3{
    font-size:19px;
    line-height:1.75;
  }

  .news-item .lead{
    font-size:14px;
    line-height:1.9;
  }
}

/* =========================
   News / Home news
   画像なし・小さめ・バランス調整版
========================= */

/* 共通NEWバッジ */
.badge-new{
  display:inline-block;
  color:#d93025;
  font-weight:700;
  letter-spacing:.04em;
}

/* -------------------------
   トップページのお知らせ
------------------------- */
.home-news{
  padding:52px 0;
}

.home-news__inner{
  width:min(1100px, calc(100% - 48px));
  margin:0 auto;
}

.home-news .section-title{
  font-size:16px;
  margin:0 0 14px;
  color:var(--ink);
  letter-spacing:.08em;
}

.news-mini{
  border-top:1px solid var(--line);
}

.news-mini > a{
  display:block;
  text-decoration:none;
  color:inherit;
  padding:18px 0 20px;
  border-bottom:1px solid var(--line);
  transition:opacity .25s ease, background-color .25s ease;
}

.news-mini > a:hover{
  opacity:.8;
  background:rgba(0,0,0,.01);
}

.news-mini .thumb{
  display:none !important;
}

.news-mini .meta{
  display:flex;
  align-items:center;
  gap:14px;
  margin:0 0 10px;
  font-size:12px;
  color:var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  line-height:1.6;
}

.news-mini .meta time{
  color:var(--muted);
}

.news-mini > a > div:last-child > div:last-child{
  font-size:14px;
  line-height:1.9;
  letter-spacing:.02em;
  color:var(--text);
  font-weight:600;
}

.home-news .btn-wrap{
  margin-top:28px;
  text-align:center;
}

/* -------------------------
   お知らせ一覧ページ
------------------------- */
.news-list{
  margin-top:18px;
  border-top:1px solid var(--line);
}

.news-item{
  padding:20px 0 22px;
  border-bottom:1px solid var(--line);
}

.news-item .thumb{
  display:none !important;
}

.news-item .meta{
  display:flex;
  align-items:center;
  gap:14px;
  margin:0 0 10px;
  font-size:12px;
  color:var(--muted);
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  line-height:1.6;
}

.news-item .meta time{
  color:var(--muted);
}

.news-item h3{
  margin:0 0 8px;
  font-size:14px;
  line-height:1.9;
  letter-spacing:.02em;
  color:var(--text);
  font-weight:600;
}

.news-item .lead{
  margin:0;
  color:var(--muted);
  font-size:12px;
  line-height:1.9;
  font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

/* ニュースページのページャ */
.page[data-page="news"] .subhead{
  margin-top:18px;
}

.page[data-page="news"] .pager{
  font-size:12px;
  color:var(--muted);
}

.page[data-page="news"] .pager a{
  color:var(--text);
  text-decoration:none;
  font-weight:700;
  margin-left:8px;
}

.page[data-page="news"] .pager a.is-current{
  color:var(--text);
}

/* SP */
@media (max-width: 768px){
  .home-news{
    padding:40px 0;
  }

  .home-news__inner{
    width:calc(100% - 32px);
  }

  .news-mini > a{
    padding:16px 0 18px;
  }

  .news-mini .meta,
  .news-item .meta{
    gap:10px;
    font-size:11px;
    margin-bottom:8px;
  }

  .news-mini > a > div:last-child > div:last-child,
  .news-item h3{
    font-size:13px;
    line-height:1.8;
  }

  .news-item .lead{
    font-size:11px;
    line-height:1.8;
  }
}

/* =========================
   Main → Footer spacing
========================= */
main.page{
  padding-top: 110px;   /* 既存維持 */
  padding-bottom: 72px; /* ← フッター前の余白を追加 */
}

/* CTAがあるページは、CTAの下にも少し余白 */
main.page .cta{
  padding-bottom: 8px;
}

/* SP */
@media (max-width: 640px){
  main.page{
    padding-top: 96px;
    padding-bottom: 56px;
  }

  main.page .cta{
    padding-bottom: 4px;
  }
}

/* =====================================
   INDEX 各セクションの横幅統一
===================================== */
:root{
  --index-w: 1100px;
  --index-gap-pc: 24px;
  --index-gap-sp: 16px;
}

/* index 全体の共通内枠 */
body[data-page="top"] .container,
body[data-page="top"] .home-news__inner,
body[data-page="top"] .home-buy.two-col,
body[data-page="top"] .home-rent__note,
body[data-page="top"] .home-consult,
body[data-page="top"] .home-cta__inner{
  width: min(var(--index-w), calc(100% - (var(--index-gap-pc) * 2)));
  max-width: var(--index-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

/* buy-stock だけ container を使っているので上書き */
body[data-page="top"] .buy-stock .container{
  width: min(var(--index-w), calc(100% - (var(--index-gap-pc) * 2)));
  max-width: var(--index-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: 0;
  padding-right: 0;
}

/* セクション自体は full width のまま */
body[data-page="top"] .intro,
body[data-page="top"] .access,
body[data-page="top"] .home-news,
body[data-page="top"] .home-buy,
body[data-page="top"] .buy-stock,
body[data-page="top"] .home-guide,
body[data-page="top"] .home-rent,
body[data-page="top"] .home-share,
body[data-page="top"] .home-cta{
  width: 100%;
}

/* 相談セクションの中身も揃える */
body[data-page="top"] .home-consult__inner,
body[data-page="top"] .home-rent__inner,
body[data-page="top"] .home-share__inner,
body[data-page="top"] .home-guide__inner,
body[data-page="top"] .intro-block{
  width: 100%;
  box-sizing: border-box;
}

/* SP */
@media (max-width: 640px){
  body[data-page="top"] .container,
  body[data-page="top"] .home-news__inner,
  body[data-page="top"] .home-buy.two-col,
  body[data-page="top"] .home-rent__note,
  body[data-page="top"] .home-consult,
  body[data-page="top"] .home-cta__inner,
  body[data-page="top"] .buy-stock .container{
    width: calc(100% - (var(--index-gap-sp) * 2));
  }
}

/* TOP page: layout fix */
body[data-page="top"] main.page{
  padding-bottom: 0 !important;
}

body[data-page="top"] .home-cta{
  padding-bottom: 40px;
}

body[data-page="top"] .site-footer{
  margin: 0;
}