@charset "UTF-8";
/* =================================================================
   KLG RESIDENCE  —  Corporate Website Stylesheet
   -----------------------------------------------------------------
   Aesthetic direction : refined / editorial
   Palette : deep navy ink  ×  champagne brass  ×  warm paper
   Type    : Noto Serif JP + Cormorant Garamond (display) / Noto Sans JP
   ================================================================= */

/* ----------------------------------------------------------------
   1. Reset & base
   ---------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--ff-sans);
  font-weight:400;
  color:var(--ink);
  background:var(--paper);
  line-height:1.9;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  max-width:100vw;
  position:relative;
}
img,svg,video{display:block;max-width:100%}
img{height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
ul,ol{list-style:none}
input,textarea,select,button{font-family:inherit;font-size:inherit;color:inherit}
table{border-collapse:collapse;width:100%}
::selection{background:var(--brass);color:#fff}
:focus-visible{outline:2px solid var(--brass);outline-offset:3px}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
}

/* ----------------------------------------------------------------
   2. Design tokens
   ---------------------------------------------------------------- */
:root{
  /* colour */
  --ink:#1c2433;
  --navy:#22324c;
  --navy-900:#131b29;
  --navy-800:#1a2536;
  /* ベージュ × 濃紺の二色構成 — 旧ブラス系トークンも navy/ベージュ にマップ */
  --brass:#1c2433;          /* 明るい背景の上のアクセント＝紺 */
  --brass-2:#d6cdb6;        /* 暗い背景の上のアクセント＝ベージュ */
  --brass-soft:rgba(28,36,51,.18);
  --paper:#f5f1e8;
  --paper-2:#ece3d2;
  --paper-3:#e3d9c3;
  --white:#fffdf8;
  --muted:#6b6f78;
  --muted-2:#9a9486;
  --line:#dcd3bf;
  --line-2:#e7e0cf;

  /* type */
  --ff-disp:"Cormorant Garamond",serif;
  --ff-serif:"Noto Serif JP",serif;
  --ff-sans:"Noto Sans JP","Helvetica Neue",Arial,sans-serif;

  /* metrics */
  --container:1220px;
  --pad:clamp(20px,5vw,60px);
  --sec-y:clamp(76px,11vw,150px);
  --header-h:88px;

  /* motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-io:cubic-bezier(.65,0,.35,1);
  --t-fast:.3s;
  --t:.55s;
}

/* 暗背景セクションではアクセント色をベージュへ反転 */
.section--dark,
.section--ink,
.site-footer,
.cta,
.hero,
.page-hero,
.preloader,
.drawer,
.to-top,
.site-header--overlay{
  --brass:#d6cdb6;
  --brass-2:#ece5d2;
  --brass-soft:rgba(214,205,182,.28);
}

/* ----------------------------------------------------------------
   3. Typography helpers
   ---------------------------------------------------------------- */
.en{font-family:var(--ff-disp);font-style:normal}

/* 電話番号などの数字を均等な高さ・幅に揃える */
.header-tel__num,.drawer__tel,.cta__tel,.contact-side__tel,
.stat__num,.prop-card__price,.timeline__year,
.news-item__date,.footer-info dd,.preloader__name{
  font-variant-numeric:tabular-nums lining-nums;
  font-feature-settings:"tnum","lnum";
}
.jp-serif{font-family:var(--ff-serif)}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--ff-disp);
  font-size:.92rem;font-weight:600;
  letter-spacing:.34em;text-transform:uppercase;
  color:var(--brass);
}
.eyebrow::before{
  content:"";width:34px;height:1px;background:var(--brass);
  display:inline-block;
}
.eyebrow--center::after{
  content:"";width:34px;height:1px;background:var(--brass);
  display:inline-block;
}

/* ----------------------------------------------------------------
   4. Layout primitives
   ---------------------------------------------------------------- */
.container{
  width:100%;max-width:var(--container);
  margin-inline:auto;padding-inline:var(--pad);
}
.container--wide{max-width:1400px}
.container--narrow{max-width:960px}

.section{
  position:relative;
  padding-block:var(--sec-y);
  overflow:hidden;
}
.section[id],.svc-row[id],[id].news__layout{scroll-margin-top:96px}
.section--paper-2{background:var(--paper-2)}
.section--dark{background:var(--navy-900);color:#e7e3d8}
.section--ink{background:var(--ink);color:#e7e3d8}

/* faint oversized english watermark behind a section */
.watermark{
  position:absolute;z-index:0;
  font-family:var(--ff-disp);
  font-weight:600;font-style:italic;
  font-size:clamp(7rem,22vw,20rem);
  line-height:.8;letter-spacing:-.03em;
  color:var(--ink);opacity:.035;
  pointer-events:none;user-select:none;white-space:nowrap;
}
.section--dark .watermark,.section--ink .watermark{color:#fff;opacity:.04}
.watermark--tr{top:-.06em;right:-.04em}
.watermark--bl{bottom:-.08em;left:-.04em}

/* fine hairline rule */
.rule{height:1px;background:var(--line);border:0;width:100%}

/* ----------------------------------------------------------------
   5. Section headings
   ---------------------------------------------------------------- */
.s-head{position:relative;z-index:1;max-width:920px}

/* 見出しの不自然な折り返しを防ぐ：意図した改行のみ尊重し、フレーズ内では切らない */
.s-head__title,
.cta__title,
.message__quote{
  word-break:keep-all;
  overflow-wrap:break-word;
}
.s-head__title .ln,
.cta__title .ln,
.message__quote .ln{
  display:inline-block;
  white-space:nowrap;
}
@media (max-width:600px){
  /* 携帯版でも意図した改行を尊重するため inline-block + nowrap を維持 */
  .s-head__title .ln,
  .cta__title .ln,
  .message__quote .ln{
    display:inline-block;
    white-space:nowrap;
  }
}
.s-head--center{margin-inline:auto;text-align:center}
.s-head__index{
  font-family:var(--ff-disp);font-style:italic;
  font-size:1.1rem;color:var(--brass);letter-spacing:.05em;
  display:block;margin-bottom:1.2em;
}
.s-head__title{
  font-family:var(--ff-serif);
  font-weight:600;
  font-size:clamp(1.85rem,3.6vw,3rem);
  line-height:1.42;letter-spacing:.04em;
  margin-top:.5em;
}
.s-head__title .em{color:var(--brass)}
.s-head__lead{
  margin-top:1.7em;
  color:var(--muted);
  font-size:1.01rem;line-height:2.1;
}
.section--dark .s-head__lead,.section--ink .s-head__lead{color:#b6b3a8}
.s-head--center .eyebrow{justify-content:center}

/* ----------------------------------------------------------------
   6. Buttons & links
   ---------------------------------------------------------------- */
.btn{
  --bg:var(--ink);--fg:var(--white);--bd:var(--ink);
  position:relative;display:inline-flex;align-items:center;gap:1.1em;
  padding:1.15em 2.4em;
  font-size:.86rem;font-weight:500;letter-spacing:.16em;
  color:var(--fg);background:var(--bg);
  border:1px solid var(--bd);
  overflow:hidden;isolation:isolate;
  transition:color var(--t-fast) var(--ease);
}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--paper-2);
  transform:scaleX(0);transform-origin:right;
  transition:transform .5s var(--ease);
}
.btn:hover{color:var(--ink)}
.btn:hover::before{transform:scaleX(1);transform-origin:left}
.btn .arrow{
  display:inline-block;width:26px;height:1px;background:currentColor;
  position:relative;transition:width var(--t-fast) var(--ease);
}
.btn .arrow::after{
  content:"";position:absolute;right:0;top:50%;
  width:6px;height:6px;border-top:1px solid currentColor;border-right:1px solid currentColor;
  transform:translateY(-50%) rotate(45deg);
}
.btn:hover .arrow{width:38px}

.btn--ghost{--bg:transparent;--fg:var(--ink);--bd:var(--ink)}
.btn--ghost::before{background:var(--ink)}
.btn--ghost:hover{color:#fff}
.btn--light{--bg:transparent;--fg:#f2efe6;--bd:rgba(242,239,230,.5)}
.btn--light::before{background:var(--paper)}
.btn--light:hover{color:var(--ink)}
/* ベージュ調のボタン（旧 brass バリエーション） */
.btn--brass{--bg:var(--paper-2);--fg:var(--ink);--bd:var(--paper-3)}
.btn--brass::before{background:var(--ink)}
.btn--brass:hover{color:#fff}
.btn--lg{padding:1.35em 3em}
.btn--block{display:flex;justify-content:center;width:100%}

/* text link with animated underline */
.tlink{
  display:inline-flex;align-items:center;gap:.8em;
  font-size:.84rem;font-weight:500;letter-spacing:.14em;
  color:var(--ink);padding-bottom:.5em;
}
.tlink__bar{
  position:relative;width:40px;height:1px;background:var(--line);overflow:hidden;
}
.tlink__bar::after{
  content:"";position:absolute;inset:0;background:var(--brass);
  transform:translateX(-101%);transition:transform .45s var(--ease);
}
.tlink:hover .tlink__bar::after{transform:translateX(0)}
.section--dark .tlink,.section--ink .tlink{color:#e7e3d8}

/* ----------------------------------------------------------------
   7. Scroll progress bar
   ---------------------------------------------------------------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:100%;
  background:var(--brass);transform:scaleX(0);transform-origin:left;
  z-index:1200;
}

/* ----------------------------------------------------------------
   8. Preloader
   ---------------------------------------------------------------- */
.preloader{
  position:fixed;inset:0;z-index:2000;
  background:transparent;
  pointer-events:none;
}
.preloader__half{
  position:absolute;left:0;right:0;height:51%;
  background:var(--navy-900);z-index:1;
  transition:transform 1.05s cubic-bezier(.83,0,.17,1);
  will-change:transform;
}
.preloader__half--top{top:0}
.preloader__half--bottom{bottom:0}
.preloader.is-splitting .preloader__half--top{transform:translateY(-100%)}
.preloader.is-splitting .preloader__half--bottom{transform:translateY(100%)}

/* ホームページのみ：左右の扉が外側に開く演出（「未来へ進む、新しい家に入る」） */
body.is-homepage .preloader{perspective:1600px;perspective-origin:50% 50%}
body.is-homepage .preloader__half{
  top:0;bottom:0;height:100%;
  background:linear-gradient(180deg,#1a263a 0%,var(--navy-900) 50%,#101723 100%);
  transition:transform .9s cubic-bezier(.65,.05,.2,1);
}
body.is-homepage .preloader__half--top{
  left:0;right:50%;width:auto;
  transform-origin:0% 50%;
  /* 中央側にうっすら陰影を入れて 2 枚の扉感を演出 */
  box-shadow:inset -2px 0 0 rgba(214,205,182,.08), inset -10px 0 22px -8px rgba(0,0,0,.45);
}
body.is-homepage .preloader__half--bottom{
  left:50%;right:0;width:auto;
  transform-origin:100% 50%;
  box-shadow:inset 2px 0 0 rgba(214,205,182,.08), inset 10px 0 22px -8px rgba(0,0,0,.45);
}
body.is-homepage .preloader.is-splitting .preloader__half--top{
  transform:rotateY(-105deg);
}
body.is-homepage .preloader.is-splitting .preloader__half--bottom{
  transform:rotateY(105deg);
}

/* 会社案内ページのみ：章扉＋建築設計図の演出 */
body.is-company .preloader__mark{display:none}
body.is-company .preloader__half--top,
body.is-company .preloader__half--bottom{
  transition:opacity .35s var(--ease);
}
body.is-company .preloader.is-splitting .preloader__half--top,
body.is-company .preloader.is-splitting .preloader__half--bottom{
  opacity:0;transform:none;
}

.preloader__intro{
  position:absolute;inset:0;z-index:4;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1rem;padding:0 var(--pad);
  pointer-events:none;
  transition:opacity .35s var(--ease);
}
body.is-company .preloader.is-splitting .preloader__intro{
  opacity:0;
}
.preloader__chapter{
  font-family:var(--ff-disp);font-style:italic;font-weight:500;
  font-size:clamp(.78rem,2vw,.95rem);letter-spacing:.42em;
  color:var(--brass-2);text-transform:uppercase;
  opacity:0;
  animation:introIn .55s var(--ease) .1s forwards;
}
.preloader__title{
  font-family:var(--ff-disp);font-style:italic;font-weight:500;
  font-size:clamp(1.9rem,5.6vw,3.2rem);letter-spacing:.05em;
  color:var(--paper);text-align:center;margin:0;
  opacity:0;
  animation:introIn .6s var(--ease) .4s forwards;
}
.preloader__title i{font-style:italic;color:var(--brass-2);font-weight:600}
.preloader__blueprint{
  width:clamp(160px,22vw,220px);height:auto;
  margin-top:.6rem;
  opacity:0;
  animation:introIn .45s var(--ease) .55s forwards;
  overflow:visible;
}
/* 3本柱：ブランド配色 Warm Beige を fill。下から立ち上がるように構築 */
.preloader__blueprint .art-bar{
  fill:#E8E0D2;
  transform-origin:50% 100%;
  transform:scaleY(0);
  animation:barRise .55s cubic-bezier(.34,.05,.2,1) forwards;
  animation-delay:var(--d, .7s);
}
/* 三層の基礎：ブランド配色 Antique Gold で左から右へ描画 */
.preloader__blueprint .art-line{
  fill:none;stroke:#B9A079;stroke-width:2.4;stroke-linecap:round;
  stroke-dasharray:100;stroke-dashoffset:100;
  animation:blueprintDraw .6s ease forwards;
  animation-delay:var(--d, 1.2s);
}
@keyframes barRise{
  from{transform:scaleY(0);opacity:.45}
  to  {transform:scaleY(1);opacity:1}
}
.preloader__subtitle{
  font-family:var(--ff-sans);font-weight:300;
  font-size:clamp(.76rem,1.8vw,.86rem);letter-spacing:.24em;
  color:var(--brass-2);text-align:center;
  margin-top:.6rem;opacity:0;
  animation:introIn .55s var(--ease) 1.7s forwards;
}
@keyframes introIn{
  from{opacity:0;transform:translateY(10px)}
  to  {opacity:1;transform:none}
}
@keyframes blueprintDraw{
  to{stroke-dashoffset:0}
}

/* カルーセル横スクロールバー（携帯版で表示） */
.carousel-bar{
  display:none;position:relative;
  height:3px;background:rgba(28,36,51,.10);
  margin:.5rem var(--pad) 0;
  border-radius:2px;overflow:hidden;
}
.carousel-bar__thumb{
  position:absolute;left:0;top:0;bottom:0;width:30%;
  background:var(--ink);border-radius:2px;
  transition:left .15s linear,width .15s linear;
}
.carousel-bar.is-idle{opacity:.4}
.section--dark .carousel-bar,.section--ink .carousel-bar{
  background:rgba(214,205,182,.14);
}
.section--dark .carousel-bar__thumb,.section--ink .carousel-bar__thumb{
  background:var(--paper-2);
}
@media (max-width:600px){
  .carousel-bar{display:block}
}
.preloader.is-done{visibility:hidden}
.preloader__mark{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;
  transition:opacity .45s var(--ease) .05s,transform .8s var(--ease);
}
.preloader.is-splitting .preloader__mark{opacity:0;transform:translateY(-12px)}
.preloader__name{
  font-family:var(--ff-disp);font-size:2.2rem;letter-spacing:.5em;
  color:var(--white);padding-left:.5em;
  opacity:0;animation:plName 1s var(--ease) .15s forwards;
}
.preloader__line{
  width:0;height:1px;background:var(--brass-2);
  animation:plLine 1.3s var(--ease) .4s forwards;
}
.preloader__sub{
  font-family:var(--ff-disp);font-style:italic;
  font-size:.95rem;letter-spacing:.2em;color:var(--brass-2);
  opacity:0;animation:plName .8s var(--ease) .7s forwards;
}
.preloader__logo{
  display:block;
  width:clamp(190px, 26vw, 300px);
  height:auto;
  opacity:0;
  transform:translateY(8px);
  animation:plLogo .6s var(--ease) .1s forwards;
}
@keyframes plName{to{opacity:1}}
@keyframes plLine{to{width:160px}}
@keyframes plLogo{to{opacity:1;transform:translateY(0)}}

/* ----------------------------------------------------------------
   9. Header
   ---------------------------------------------------------------- */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  transition:background var(--t) var(--ease),box-shadow var(--t) var(--ease),
             border-color var(--t) var(--ease);
  border-bottom:1px solid transparent;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);
  padding-inline:var(--pad);
  transition:height var(--t) var(--ease);
}
/* overlay (transparent) variant — used over the hero */
.site-header--overlay{background:transparent}
.site-header--overlay .gnav__link,
.site-header--overlay .brand__name,
.site-header--overlay .brand__tag,
.site-header--overlay .nav-toggle__line{color:#f3efe5}
.site-header--overlay .brand__mark{color:var(--brass-2)}
.site-header--overlay .header-tel{color:#f3efe5}

/* scrolled / solid state */
.site-header.is-solid{
  background:rgba(245,241,232,.92);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-bottom-color:var(--line);
  box-shadow:0 12px 40px -28px rgba(20,27,41,.5);
}
.site-header.is-solid .header-inner{height:74px}
.site-header.is-solid .gnav__link,
.site-header.is-solid .brand__name,
.site-header.is-solid .brand__tag,
.site-header.is-solid .nav-toggle__line,
.site-header.is-solid .header-tel{color:var(--ink)}
.site-header.is-solid .brand__mark{color:var(--brass)}

/* brand / logo */
.brand{display:flex;align-items:center;line-height:1}
.brand__logo{
  display:block;height:48px;width:auto;
  transition:height var(--t) var(--ease),opacity var(--t-fast) var(--ease),transform .5s var(--ease);
}
.brand:hover .brand__logo{transform:scale(1.03)}
.brand__logo--white{display:none}

/* ヒーロー上の透過ヘッダー＝白版ロゴ */
.site-header--overlay .brand__logo--color{display:none}
.site-header--overlay .brand__logo--white{display:block}

/* スクロール後の白背景ヘッダー＝カラー版ロゴ（少し小さく） */
.site-header.is-solid .brand__logo--color{display:block}
.site-header.is-solid .brand__logo--white{display:none}
.site-header.is-solid .brand__logo{height:40px}

/* フッターは常に白版（ダークネイビー背景の上） */
.footer-brand .brand__logo--color{display:none}
.footer-brand .brand__logo--white{display:block}
.footer-brand .brand__logo{height:46px}

/* global nav */
.gnav{display:flex;align-items:center;gap:clamp(1.3rem,2.6vw,2.7rem)}
.gnav__list{display:flex;align-items:center;gap:clamp(1.3rem,2.6vw,2.7rem)}
.gnav__link{
  position:relative;
  font-size:.86rem;font-weight:500;letter-spacing:.1em;
  color:var(--ink);padding:.4em 0;
  transition:color var(--t-fast) var(--ease);
}
.gnav__link .en-sm{
  display:block;font-family:var(--ff-disp);font-style:italic;
  font-size:.66rem;letter-spacing:.1em;color:var(--brass);
  text-align:center;margin-bottom:.1em;opacity:.85;
}
.gnav__link::after{
  content:"";position:absolute;left:0;bottom:0;
  width:100%;height:1px;background:var(--brass);
  transform:scaleX(0);transform-origin:right;
  transition:transform var(--t-fast) var(--ease);
}
.gnav__link:hover::after,.gnav__link[aria-current="page"]::after{
  transform:scaleX(1);transform-origin:left;
}
.gnav__link[aria-current="page"]{color:var(--brass)}

.header-tel{
  display:flex;flex-direction:column;align-items:flex-end;
  line-height:1.3;color:var(--ink);
}
.header-tel__num{
  font-family:var(--ff-disp);font-size:1.32rem;font-weight:600;
  letter-spacing:.06em;
}
.header-tel__num::before{
  content:"";display:inline-block;width:13px;height:13px;
  margin-right:.45em;vertical-align:-1px;
  background:currentColor;
  -webkit-mask:var(--ic-phone) center/contain no-repeat;
  mask:var(--ic-phone) center/contain no-repeat;
}
.header-tel__hours{font-size:.6rem;letter-spacing:.16em;color:var(--muted-2)}

.header-cta{display:flex;align-items:center;gap:1.4rem}

/* hamburger */
.nav-toggle{
  display:none;width:46px;height:46px;position:relative;z-index:1101;flex:none;
}
.nav-toggle__line{
  position:absolute;left:9px;width:28px;height:1.6px;
  background:var(--ink);
  transition:transform .4s var(--ease),opacity .25s var(--ease),background var(--t) var(--ease);
}
.nav-toggle__line:nth-child(1){top:16px}
.nav-toggle__line:nth-child(2){top:23px}
.nav-toggle__line:nth-child(3){top:30px}
.is-nav-open .nav-toggle__line{background:#f3efe5}
.is-nav-open .nav-toggle__line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.is-nav-open .nav-toggle__line:nth-child(2){opacity:0}
.is-nav-open .nav-toggle__line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ----------------------------------------------------------------
   10. Mobile drawer
   ---------------------------------------------------------------- */
.drawer{
  position:fixed;inset:0;z-index:1100;
  background:var(--navy-900);
  display:flex;flex-direction:column;justify-content:center;
  padding:7rem var(--pad) 3rem;
  clip-path:circle(0% at calc(100% - 46px) 44px);
  transition:clip-path .7s var(--ease);
  visibility:hidden;
}
.is-nav-open .drawer{
  clip-path:circle(150% at calc(100% - 46px) 44px);
  visibility:visible;
}
.drawer__list{
  display:flex;flex-direction:column;gap:.2rem;
  max-width:var(--container);margin-inline:auto;width:100%;
}
.drawer__item{
  border-bottom:1px solid rgba(255,255,255,.1);
  opacity:0;transform:translateY(22px);
}
.is-nav-open .drawer__item{
  animation:drawerIn .6s var(--ease) forwards;
}
.drawer__link{
  display:flex;align-items:baseline;gap:1.1rem;
  padding:1.15rem .2rem;color:#f1ede2;
}
.drawer__link .num{
  font-family:var(--ff-disp);font-style:italic;
  font-size:.9rem;color:var(--brass-2);
}
.drawer__link .jp{
  font-family:var(--ff-serif);font-size:1.32rem;letter-spacing:.05em;
}
.drawer__link .en-sm{
  margin-left:auto;font-family:var(--ff-disp);font-style:italic;
  font-size:.85rem;color:var(--muted-2);
}
.drawer__foot{
  max-width:var(--container);margin:2.4rem auto 0;width:100%;
  display:flex;flex-wrap:wrap;gap:1.4rem;align-items:center;
  color:#cfcabb;
}
.drawer__tel{font-family:var(--ff-disp);font-size:1.6rem;color:#fff}
@keyframes drawerIn{to{opacity:1;transform:translateY(0)}}

/* ----------------------------------------------------------------
   11. Hero (home)
   ---------------------------------------------------------------- */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  overflow:hidden;color:#f3efe5;
  isolation:isolate;
}
.hero__media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero__media img,
.hero__media video{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.86) contrast(1.06) saturate(.92);
}
.hero__media img{animation:heroZoom 16s var(--ease) forwards}
.hero__media video{
  transform:scale(1.04);
  animation:heroZoom 22s var(--ease) forwards;
}
@keyframes heroZoom{from{transform:scale(1.12)}to{transform:scale(1.04)}}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:
    /* 文字エリア（左下〜中央寄り）を重点的に暗く */
    radial-gradient(ellipse 95% 80% at 28% 75%,
      rgba(11,16,26,.78) 0%,
      rgba(11,16,26,.55) 28%,
      rgba(11,16,26,.28) 55%,
      rgba(11,16,26,.16) 100%),
    /* 縦方向：上下に重み、中央少し透ける */
    linear-gradient(180deg,
      rgba(11,16,26,.55) 0%,
      rgba(11,16,26,.18) 32%,
      rgba(11,16,26,.55) 70%,
      rgba(11,16,26,.94) 100%);
}
.hero__inner{
  width:100%;max-width:var(--container);
  margin-inline:auto;padding:0 var(--pad) clamp(120px,18vh,200px);
  position:relative;z-index:1;
  /* テキストの輪郭をくっきり保つグロー */
  text-shadow:0 2px 28px rgba(0,0,0,.55),0 1px 3px rgba(0,0,0,.35);
}
.hero__eyebrow{
  margin-bottom:1.8rem;color:var(--brass-2);
  opacity:0;animation:heroUp 1s var(--ease) .5s forwards;
}
.hero__eyebrow::before{background:var(--brass-2)}
.hero__title{
  font-family:var(--ff-serif);font-weight:500;
  font-size:clamp(2.05rem,4.7vw,4.3rem);
  line-height:1.4;letter-spacing:.045em;
}
.hero__title>span{
  display:block;overflow:hidden;
}
.hero__title>span>i{
  display:block;font-style:normal;
  transform:translateY(110%);
}
.hero__title>span:nth-child(1)>i{animation:heroLine 1.1s var(--ease) .6s forwards}
.hero__title>span:nth-child(2)>i{animation:heroLine 1.1s var(--ease) .76s forwards}
.hero__title>span:nth-child(3)>i{animation:heroLine 1.1s var(--ease) .92s forwards}
.hero__title .accent{color:var(--brass-2);position:relative}
.hero__title .accent::after{
  content:"";position:absolute;left:0;right:0;bottom:-.06em;
  height:2px;background:var(--brass-2);transform:scaleX(0);transform-origin:left;
  animation:heroUnderline .9s var(--ease) 1.5s forwards;
}
@keyframes heroUnderline{to{transform:scaleX(1)}}
.hero__title .en{font-family:var(--ff-disp);font-style:italic;color:var(--brass-2)}
@keyframes heroLine{to{transform:translateY(0)}}
.hero__lead{
  max-width:34em;margin-top:2rem;
  font-size:1.02rem;line-height:2.15;color:#ddd9cd;
  opacity:0;animation:heroUp 1s var(--ease) 1.15s forwards;
}
.hero__actions{
  display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.6rem;
  opacity:0;animation:heroUp 1s var(--ease) 1.32s forwards;
}
@keyframes heroUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

/* vertical side label */
.hero__side{
  position:absolute;right:max(28px,3vw);bottom:230px;z-index:1;
  writing-mode:vertical-rl;
  font-family:var(--ff-disp);font-style:italic;letter-spacing:.22em;
  font-size:.92rem;color:#cdc8bb;
  display:flex;align-items:center;gap:1.4em;
  opacity:0;animation:heroUp 1s var(--ease) 1.5s forwards;
}
.hero__side::before{content:"";width:1px;height:64px;background:var(--brass-2)}

/* scroll cue */
.hero__scroll{
  position:absolute;left:max(28px,3vw);bottom:34px;z-index:1;
  display:flex;align-items:center;gap:1em;
  font-family:var(--ff-disp);font-style:italic;font-size:.82rem;
  letter-spacing:.18em;color:#cdc8bb;
  opacity:0;animation:heroUp 1s var(--ease) 1.6s forwards;
}
.hero__scroll-track{
  position:relative;width:1px;height:54px;background:rgba(255,255,255,.25);overflow:hidden;
}
.hero__scroll-track::after{
  content:"";position:absolute;left:0;top:0;width:100%;height:40%;
  background:var(--brass-2);animation:scrollCue 2.1s var(--ease) infinite;
}
@keyframes scrollCue{
  0%{transform:translateY(-100%)}
  60%,100%{transform:translateY(260%)}
}

/* hero search bar */
.hero-search{
  position:relative;z-index:2;margin-top:-66px;
}
.hero-search__box{
  background:var(--white);
  border:1px solid var(--line);
  box-shadow:0 40px 80px -50px rgba(20,27,41,.6);
}
.hero-search__head{
  display:flex;align-items:center;gap:1em;
  padding:1.15rem 1.8rem;border-bottom:1px solid var(--line-2);
}
.hero-search__head .en{
  font-family:var(--ff-disp);font-style:italic;color:var(--brass);
  font-size:1.05rem;
}
.hero-search__head .jp{
  font-family:var(--ff-serif);font-size:.95rem;letter-spacing:.08em;
}
.hero-search__grid{
  display:grid;grid-template-columns:repeat(4,1fr);
}
.hero-search__cell{
  padding:1.5rem 1.8rem;
  border-right:1px solid var(--line-2);
  display:flex;flex-direction:column;gap:.5rem;
}
.hero-search__cell:last-of-type{border-right:0}
.hero-search__cell label{
  font-size:.66rem;letter-spacing:.18em;color:var(--brass);font-weight:500;
}
.hero-search__cell select{
  border:0;border-bottom:1px solid var(--line);
  padding:.45em 1.6em .45em 0;
  font-size:.95rem;background:transparent;
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:var(--ic-caret);
  background-repeat:no-repeat;background-position:right .2em center;
  background-size:9px;
}
.hero-search__submit{
  grid-column:1/-1;
}
.hero-search__submit .btn{width:100%;justify-content:center}

/* ----------------------------------------------------------------
   12. Intro / about
   ---------------------------------------------------------------- */
.intro__grid{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:clamp(2.4rem,6vw,6rem);align-items:center;
  position:relative;z-index:1;
}
.intro__figure{position:relative}
.intro__figure .img-main{
  aspect-ratio:4/5;overflow:hidden;background:var(--paper-3);
}
.intro__figure .img-main img{width:100%;height:100%;object-fit:cover}
.intro__figure .img-sub{
  position:absolute;right:-8%;bottom:-12%;width:52%;
  aspect-ratio:1/1;overflow:hidden;
  border:8px solid var(--paper);background:var(--paper-3);
}
.intro__figure .img-sub img{width:100%;height:100%;object-fit:cover}
.intro__figure .badge{
  position:absolute;left:-7%;top:9%;
  width:128px;height:128px;border-radius:50%;
  background:var(--ink);color:var(--brass-2);
  display:grid;place-items:center;text-align:center;
  font-family:var(--ff-disp);font-style:italic;
  box-shadow:0 26px 50px -28px rgba(20,27,41,.7);
}
.intro__figure .badge b{display:block;font-size:2.3rem;font-style:normal;line-height:1;color:#fff}
.intro__figure .badge span{font-size:.62rem;letter-spacing:.16em;margin-top:.4em}

/* Intro art — 建築物のラインアートが描かれる SVG アニメーション */
.intro__art{
  position:relative;aspect-ratio:4/5;
  background:
    radial-gradient(ellipse at 28% 18%, rgba(255,253,248,.55) 0%, transparent 55%),
    linear-gradient(160deg, var(--paper-2) 0%, var(--paper-3) 100%);
  border:1px solid var(--line);
  overflow:hidden;color:var(--ink);
}
.intro__art::before{
  content:"";position:absolute;inset:14px;
  border:1px solid rgba(28,36,51,.10);
  pointer-events:none;
}
.intro__art-en{
  position:absolute;left:6%;bottom:6%;z-index:1;
  font-family:var(--ff-disp);font-style:italic;font-weight:500;
  font-size:clamp(2.4rem,6vw,3.6rem);line-height:.85;
  color:var(--ink);opacity:.10;letter-spacing:.02em;
  pointer-events:none;user-select:none;
}
.intro__art-en i{display:block;font-style:italic}
.intro__art-svg{
  position:absolute;left:11%;top:10%;
  width:78%;height:80%;color:var(--ink);z-index:2;
}
.art-line{
  stroke-dasharray:100;stroke-dashoffset:100;
  transition:stroke-dashoffset 1.8s var(--ease);
  transition-delay:var(--d,.2s);
}
.intro__art.is-visible .art-line{stroke-dashoffset:0}
.art-line--shell{--d:.2s;stroke-width:1.5}
.art-line--center{--d:.65s}
.art-line--orbit{--d:.5s}
.art-line--door{--d:1.4s}
.art-line--ground{--d:1.5s;stroke-width:1.5}
.art-line--tree{--d:1.7s}
.art-line--tree2{--d:1.85s}
.art-window{
  opacity:0;transition:opacity .9s var(--ease);
  transition-delay:var(--d,1.8s);
}
.art-window--1{--d:1.8s}
.art-window--2{--d:2s}
.art-window--3{--d:2.2s}
.intro__art.is-visible .art-window--1{opacity:.65}
.intro__art.is-visible .art-window--2{opacity:.35}
.intro__art.is-visible .art-window--3{opacity:.50}

/* 浮遊する幾何モチーフ */
.intro__art-chip{
  position:absolute;border-radius:50%;
  opacity:0;will-change:transform;z-index:2;
  transition:opacity 1s var(--ease) var(--cd,1s);
}
.intro__art.is-visible .intro__art-chip{
  opacity:1;animation:chipFloat 7s ease-in-out infinite;
  animation-delay:var(--cd,1s);
}
.intro__art-chip--1{
  --cd:1s;
  width:11px;height:11px;top:14%;left:18%;
  background:var(--ink);
}
.intro__art-chip--2{
  --cd:1.6s;
  width:7px;height:7px;top:60%;left:85%;
  background:transparent;border:1px solid var(--ink);
}
.intro__art-chip--3{
  --cd:1.3s;
  width:16px;height:16px;top:78%;left:9%;
  background:var(--paper);border:1px solid var(--ink);
}
@keyframes chipFloat{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(7px,-12px)}
}

/* 16 Years バッジ（既存と同等＋出現アニメ＋パルス輪） */
.intro__art-badge{
  position:absolute;left:-7%;top:9%;z-index:4;
  width:128px;height:128px;border-radius:50%;
  background:var(--ink);color:var(--paper-2);
  display:grid;place-items:center;text-align:center;
  font-family:var(--ff-disp);font-style:italic;
  box-shadow:0 26px 50px -28px rgba(20,27,41,.55);
  opacity:0;transform:scale(.55) rotate(-15deg);
  transition:opacity .9s var(--ease) 1.4s, transform 1s var(--ease) 1.4s;
}
.intro__art.is-visible .intro__art-badge{
  opacity:1;transform:scale(1) rotate(0);
}
.intro__art-badge b{
  display:block;font-size:2.3rem;font-style:normal;line-height:1;color:#fff;
  font-family:var(--ff-disp);font-weight:600;
}
.intro__art-badge em{
  display:block;font-size:.62rem;letter-spacing:.16em;margin-top:.4em;
  font-style:italic;font-weight:400;
}
.intro__art-badge::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  border:1px solid var(--ink);opacity:0;
}
.intro__art.is-visible .intro__art-badge::after{
  animation:badgePulse 2.8s ease-out infinite 2.4s;
}
@keyframes badgePulse{
  0%{transform:scale(1);opacity:.5}
  100%{transform:scale(1.35);opacity:0}
}

.intro__body .s-head__title{margin-top:.7em}
.intro__sign{
  margin-top:2.2rem;display:flex;align-items:flex-end;gap:1.2rem;
}
.intro__sign .role{font-size:.74rem;letter-spacing:.14em;color:var(--muted)}
.intro__sign .name{
  font-family:var(--ff-serif);font-size:1.2rem;letter-spacing:.1em;
}
.intro__sign .en{
  margin-left:auto;font-family:var(--ff-disp);font-style:italic;
  font-size:1.5rem;color:var(--brass);
}

/* ----------------------------------------------------------------
   13. Services
   ---------------------------------------------------------------- */
.svc-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:var(--line);
  border:1px solid var(--line);
  margin-top:clamp(2.6rem,5vw,4.4rem);
  position:relative;z-index:1;
}
.svc-card{
  position:relative;background:var(--white);
  padding:clamp(2rem,3.6vw,3.4rem);
  display:flex;flex-direction:column;gap:1.3rem;
  overflow:hidden;transition:background var(--t) var(--ease);
}
.svc-card__bg{
  position:absolute;inset:0;z-index:0;opacity:0;
  transition:opacity .6s var(--ease);
}
.svc-card__bg img{width:100%;height:100%;object-fit:cover}
.svc-card__bg::after{content:"";position:absolute;inset:0;background:rgba(19,27,41,.78)}
.svc-card:hover .svc-card__bg{opacity:1}
.svc-card>*:not(.svc-card__bg){position:relative;z-index:1;transition:color var(--t) var(--ease)}
.svc-card__top{display:flex;align-items:center;justify-content:space-between}
.svc-card__no{
  font-family:var(--ff-disp);font-style:italic;
  font-size:2.4rem;color:var(--paper-3);
  transition:color var(--t) var(--ease);
}
.svc-card:hover .svc-card__no{color:var(--brass-2)}
.svc-card__icon{
  width:54px;height:54px;color:var(--brass);
}
.svc-card:hover .svc-card__icon{color:var(--brass-2)}
.svc-card__en{
  font-family:var(--ff-disp);font-style:italic;
  font-size:1rem;letter-spacing:.12em;color:var(--brass);
}
.svc-card__title{
  font-family:var(--ff-serif);font-weight:600;
  font-size:1.42rem;letter-spacing:.05em;
}
.svc-card__desc{
  font-size:.93rem;line-height:2.05;color:var(--muted);
  flex:1;
}
.svc-card:hover .svc-card__title,
.svc-card:hover .svc-card__desc{color:#f1ede2}
.svc-card:hover .svc-card__en{color:var(--brass-2)}
.svc-card__more{
  display:inline-flex;align-items:center;gap:.7em;
  font-size:.78rem;letter-spacing:.16em;color:var(--ink);
  transition:color var(--t) var(--ease);
}
.svc-card:hover .svc-card__more{color:var(--brass-2)}
.svc-card__more::after{
  content:"";width:24px;height:1px;background:currentColor;position:relative;
}
.svc-card__more span{
  display:inline-block;transition:transform var(--t-fast) var(--ease);
}
.svc-card:hover .svc-card__more span{transform:translateX(5px)}

/* ----------------------------------------------------------------
   14. Property cards
   ---------------------------------------------------------------- */
.prop-tabs{
  display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;
  margin-top:2.6rem;position:relative;z-index:1;
}
.prop-tab{
  padding:.85em 1.9em;font-size:.82rem;letter-spacing:.12em;
  border:1px solid var(--line);background:transparent;color:var(--muted);
  transition:all var(--t-fast) var(--ease);
}
.prop-tab .en{font-family:var(--ff-disp);font-style:italic;margin-right:.5em;color:var(--brass)}
.prop-tab:hover{border-color:var(--brass);color:var(--ink)}
.prop-tab.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.prop-tab.is-active .en{color:var(--brass-2)}

.prop-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1.4rem,2.6vw,2.2rem);
  margin-top:clamp(2.2rem,4vw,3.4rem);
  position:relative;z-index:1;
}
.prop-card{
  background:var(--white);border:1px solid var(--line-2);
  display:flex;flex-direction:column;
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),
             border-color var(--t) var(--ease);
}
.prop-card:hover{
  transform:translateY(-8px);
  box-shadow:0 38px 60px -42px rgba(20,27,41,.55);
  border-color:var(--brass-soft);
}
.prop-card__thumb{
  position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--paper-3);
}
.prop-card__thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease);
}
.prop-card:hover .prop-card__thumb img{transform:scale(1.07)}
.prop-card__tag{
  position:absolute;top:0;left:0;
  padding:.55em 1.3em;font-size:.68rem;letter-spacing:.14em;
  background:var(--ink);color:#f1ede2;
}
.prop-card__tag--rent{background:var(--paper-2);color:var(--ink)}
.prop-card__fav{
  position:absolute;top:.7rem;right:.7rem;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,253,248,.92);display:grid;place-items:center;
  transition:background var(--t-fast) var(--ease);
}
.prop-card__fav svg{width:17px;height:17px;color:var(--brass)}
.prop-card__fav:hover{background:var(--brass)}
.prop-card__fav:hover svg{color:#fff}
.prop-card__body{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;gap:.85rem;flex:1}
.prop-card__cat{
  font-size:.68rem;letter-spacing:.14em;color:var(--brass);
}
.prop-card__name{
  font-family:var(--ff-serif);font-weight:600;font-size:1.12rem;
  line-height:1.6;letter-spacing:.03em;
}
.prop-card__price{
  font-family:var(--ff-disp);font-weight:600;
  font-size:2rem;color:var(--ink);line-height:1;
  display:flex;align-items:baseline;gap:.18em;
}
.prop-card__price small{font-family:var(--ff-sans);font-size:.82rem;font-weight:500}
.prop-card__addr{
  font-size:.82rem;color:var(--muted);
  display:flex;align-items:center;gap:.5em;
}
.prop-card__addr::before{
  content:"";width:13px;height:13px;flex:none;background:var(--brass);
  -webkit-mask:var(--ic-pin) center/contain no-repeat;
  mask:var(--ic-pin) center/contain no-repeat;
}
.prop-card__specs{
  display:flex;flex-wrap:wrap;gap:.4rem;
  margin-top:auto;padding-top:1rem;border-top:1px solid var(--line-2);
}
.prop-card__specs li{
  font-size:.72rem;letter-spacing:.04em;color:var(--muted);
  background:var(--paper);padding:.4em .8em;
}
.prop-card__specs li b{color:var(--ink);font-weight:600}

/* -------- プレビュー／準備中 状態 -------- */
.prop-card__placeholder,
.column-card__placeholder{
  position:relative;width:100%;height:100%;
  background:radial-gradient(ellipse at center, var(--paper-2) 0%, var(--paper-3) 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;
  color:var(--ink);overflow:hidden;
}
.prop-card__placeholder::before,
.column-card__placeholder::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle, rgba(28,36,51,.13) 1px, transparent 1.5px);
  background-size:18px 18px;
}
.prop-card__placeholder > *,
.column-card__placeholder > *{position:relative;z-index:1}
.prop-card__placeholder .ph-mark,
.column-card__placeholder .ph-mark{
  width:42px;height:42px;color:var(--ink);opacity:.55;
}
.prop-card__placeholder .ph-en,
.column-card__placeholder .ph-en{
  font-family:var(--ff-disp);font-style:italic;font-weight:500;
  font-size:1.05rem;letter-spacing:.18em;color:var(--ink);opacity:.75;
}
.prop-card__placeholder .ph-jp,
.column-card__placeholder .ph-jp{
  font-size:.66rem;letter-spacing:.2em;color:var(--ink);opacity:.5;
}
.prop-card__placeholder .ph-rule,
.column-card__placeholder .ph-rule{
  width:34px;height:1px;background:var(--ink);opacity:.3;
}
.prop-card__preview-badge{
  position:absolute;top:.8rem;right:.8rem;z-index:1;
  font-family:var(--ff-disp);font-style:italic;font-weight:500;
  font-size:.72rem;letter-spacing:.18em;
  background:var(--ink);color:var(--paper-2);
  padding:.42em 1.05em;
}
.prop-card__price small{color:var(--muted);font-style:italic}

/* ----------------------------------------------------------------
   15. Reasons / strengths (dark)
   ---------------------------------------------------------------- */
.reason__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1.6rem,3vw,2.8rem);
  margin-top:clamp(2.8rem,5vw,4.6rem);position:relative;z-index:1;
}
.reason-card{
  padding:2.6rem 0 0;border-top:1px solid rgba(255,255,255,.16);
  position:relative;
}
.reason-card__no{
  font-family:var(--ff-disp);font-style:italic;
  font-size:3.4rem;color:var(--brass-2);line-height:1;
}
.reason-card__en{
  font-family:var(--ff-disp);font-style:italic;font-size:.92rem;
  letter-spacing:.14em;color:var(--muted-2);margin-top:1.4rem;
}
.reason-card__title{
  font-family:var(--ff-serif);font-weight:600;
  font-size:1.34rem;letter-spacing:.05em;color:#f3efe5;
  margin-top:.5rem;
}
.reason-card__desc{
  margin-top:1.1rem;font-size:.92rem;line-height:2.05;color:#aeaa9f;
}

/* stats row */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.14);
  margin-top:clamp(2.6rem,5vw,4rem);position:relative;z-index:1;
}
.stat{
  background:var(--navy-900);padding:2.4rem 1.4rem;text-align:center;
}
.stat__num{
  font-family:var(--ff-disp);font-weight:600;
  font-size:clamp(2.6rem,5vw,3.8rem);color:#fff;line-height:1;
  display:flex;align-items:baseline;justify-content:center;gap:.06em;
}
.stat__num .unit{font-size:1.1rem;color:var(--brass-2)}
.stat__label{
  margin-top:1rem;font-size:.78rem;letter-spacing:.1em;color:#aeaa9f;
}
.stat__en{
  font-family:var(--ff-disp);font-style:italic;font-size:.78rem;
  color:var(--brass-2);margin-top:.3em;
}

/* ----------------------------------------------------------------
   16. Flow steps
   ---------------------------------------------------------------- */
.flow-list{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(1rem,2.4vw,1.8rem);
  margin-top:clamp(2.6rem,5vw,4rem);position:relative;z-index:1;
}
.flow-step{
  background:var(--white);border:1px solid var(--line-2);
  padding:2.2rem 1.7rem;position:relative;
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease);
}
.flow-step:hover{transform:translateY(-6px);box-shadow:0 30px 50px -40px rgba(20,27,41,.5)}
.flow-step__no{
  font-family:var(--ff-disp);font-style:italic;
  font-size:.92rem;letter-spacing:.1em;color:var(--brass);
}
.flow-step__no b{font-size:2.2rem;font-style:normal;color:var(--ink);margin-right:.15em}
.flow-step__icon{width:40px;height:40px;color:var(--brass);margin:1.2rem 0 1rem}
.flow-step__title{
  font-family:var(--ff-serif);font-weight:600;font-size:1.1rem;letter-spacing:.04em;
}
.flow-step__desc{margin-top:.7rem;font-size:.85rem;line-height:1.95;color:var(--muted)}
.flow-step::after{
  content:"";position:absolute;top:50%;right:-22px;
  width:18px;height:18px;
  border-top:1.5px solid var(--brass);border-right:1.5px solid var(--brass);
  transform:translateY(-50%) rotate(45deg);
}
.flow-step:last-child::after{display:none}

/* ----------------------------------------------------------------
   17. News list
   ---------------------------------------------------------------- */
.news__layout{
  display:grid;grid-template-columns:300px 1fr;
  gap:clamp(2rem,5vw,5rem);position:relative;z-index:1;
}
.news-list{border-top:1px solid var(--line)}
.news-item{
  display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap;
  padding:1.5rem .4rem;border-bottom:1px solid var(--line);
  transition:background var(--t-fast) var(--ease),padding var(--t-fast) var(--ease);
}
.news-item:hover{background:var(--white);padding-inline:1.4rem}
.news-item__date{
  font-family:var(--ff-disp);font-size:1.05rem;color:var(--muted);
  letter-spacing:.04em;flex:none;
}
.news-item__cat{
  font-size:.66rem;letter-spacing:.12em;
  padding:.42em 1.1em;border:1px solid var(--ink);color:var(--ink);
  flex:none;
}
.news-item__cat--news{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.news-item__title{
  font-size:.96rem;flex:1;min-width:200px;
  transition:color var(--t-fast) var(--ease);
}
.news-item:hover .news-item__title{color:var(--brass)}
.news-item__arrow{
  width:30px;height:1px;background:var(--line);position:relative;flex:none;
}
.news-item__arrow::after{
  content:"";position:absolute;right:0;top:50%;width:6px;height:6px;
  border-top:1px solid var(--brass);border-right:1px solid var(--brass);
  transform:translateY(-50%) rotate(45deg);
}

/* column cards (within news section) */
.column-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.column-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line-2)}
.column-card__thumb{aspect-ratio:16/10;overflow:hidden;background:var(--paper-3)}
.column-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.column-card:hover .column-card__thumb img{transform:scale(1.07)}
.column-card__body{padding:1.3rem 1.3rem 1.5rem}
.column-card__title{font-family:var(--ff-serif);font-size:1rem;line-height:1.7;font-weight:600}

/* ----------------------------------------------------------------
   18. CTA band
   ---------------------------------------------------------------- */
.cta{
  position:relative;overflow:hidden;color:#f3efe5;
  background:var(--navy-900);
}
.cta__media{position:absolute;inset:0;z-index:0}
.cta__media img{width:100%;height:100%;object-fit:cover;opacity:.26}
.cta__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(19,27,41,.95),rgba(19,27,41,.6));
}
.cta__inner{
  position:relative;z-index:1;
  padding-block:clamp(64px,9vw,118px);
  display:grid;grid-template-columns:1.3fr 1fr;
  gap:clamp(2rem,5vw,5rem);align-items:center;
}
.cta__title{
  font-family:var(--ff-serif);font-weight:500;
  font-size:clamp(1.7rem,3.4vw,2.7rem);line-height:1.5;letter-spacing:.04em;
}
.cta__title .accent{color:var(--brass-2)}
.cta__title .en{color:var(--brass-2);font-family:var(--ff-disp);font-style:italic}
.cta__lead{margin-top:1.4rem;color:#bdb9ad;font-size:.96rem;line-height:2.05}
.cta__panel{
  background:rgba(255,253,248,.06);
  border:1px solid rgba(255,255,255,.16);
  padding:2.4rem;
}
.cta__panel-label{font-size:.68rem;letter-spacing:.18em;color:var(--brass-2)}
.cta__tel{
  font-family:var(--ff-disp);font-weight:600;font-size:2.7rem;
  color:#fff;letter-spacing:.04em;margin:.3rem 0 .2rem;
  display:block;
}
.cta__hours{font-size:.78rem;color:#9a9589;margin-bottom:1.5rem}
.cta__panel .btn{width:100%;justify-content:center}

/* ----------------------------------------------------------------
   19. Footer
   ---------------------------------------------------------------- */
.site-footer{background:var(--ink);color:#bdbaae}
.footer-top{
  padding-block:clamp(56px,8vw,92px);
  display:grid;grid-template-columns:1.2fr 2fr;
  gap:clamp(2.4rem,5vw,5rem);
}
.footer-brand .brand__name{color:#fff}
.footer-brand .brand__mark{color:var(--brass-2)}
.footer-brand .brand__tag{color:var(--muted-2)}
.footer-brand__desc{
  margin-top:1.6rem;font-size:.88rem;line-height:2.05;color:#9a9589;
  max-width:30em;
}
.footer-info{margin-top:1.8rem;font-size:.85rem;line-height:1.95;color:#bdbaae}
.footer-info dt{
  font-size:.64rem;letter-spacing:.14em;color:var(--brass-2);
  margin-top:1rem;
}
.footer-info dd{color:#d6d3c8}
.footer-nav{
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
}
.footer-col h3{
  font-family:var(--ff-disp);font-style:italic;font-size:1.05rem;
  color:var(--brass-2);margin-bottom:1.2rem;
  padding-bottom:.7rem;border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-col li{margin-bottom:.7rem}
.footer-col a{
  font-size:.85rem;color:#bdbaae;
  display:inline-flex;align-items:center;gap:.5em;
  transition:color var(--t-fast) var(--ease);
}
.footer-col a::before{
  content:"";width:0;height:1px;background:var(--brass-2);
  transition:width var(--t-fast) var(--ease);
}
.footer-col a:hover{color:#fff}
.footer-col a:hover::before{width:14px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-block:1.8rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;
}
.footer-bottom small{font-size:.72rem;letter-spacing:.06em;color:#8c8579}
.footer-bottom .en{font-family:var(--ff-disp);font-style:italic}
.footer-legal{display:flex;gap:1.6rem;flex-wrap:wrap}
.footer-legal a{font-size:.72rem;color:#8c8579;transition:color var(--t-fast) var(--ease)}
.footer-legal a:hover{color:var(--brass-2)}

/* back-to-top */
.to-top{
  position:fixed;right:24px;bottom:24px;z-index:900;
  width:52px;height:52px;background:var(--ink);color:var(--brass-2);
  display:grid;place-items:center;
  opacity:0;visibility:hidden;transform:translateY(14px);
  transition:all var(--t-fast) var(--ease);
  border:1px solid rgba(255,255,255,.12);
}
.to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{background:var(--brass);color:#fff}
.to-top svg{width:16px;height:16px}

/* ----------------------------------------------------------------
   20. Sub-page hero & breadcrumb
   ---------------------------------------------------------------- */
.page-hero{
  position:relative;min-height:clamp(340px,46vh,480px);
  display:flex;align-items:center;
  color:#f3efe5;overflow:hidden;isolation:isolate;
  margin-top:0;
}
.page-hero__media{position:absolute;inset:0;z-index:-2}
.page-hero__media img{width:100%;height:100%;object-fit:cover}
.page-hero__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(19,27,41,.7),rgba(19,27,41,.82));
}

/* Skyline 版（写真の代わりに名古屋風 都市シルエットを描画） */
.page-hero--skyline .page-hero__media{
  background:
    radial-gradient(ellipse 90% 70% at 50% 100%, rgba(11,16,26,.55) 0%, transparent 70%),
    linear-gradient(165deg, var(--navy-900) 0%, var(--ink) 55%, var(--navy-900) 100%);
}
.page-hero--skyline .page-hero__media::after{
  background:
    linear-gradient(180deg,
      rgba(19,27,41,.62) 0%,
      rgba(19,27,41,.32) 40%,
      rgba(19,27,41,.10) 75%,
      rgba(19,27,41,0) 100%);
}
.page-hero__skyline{
  position:absolute;left:0;bottom:0;
  width:100%;height:78%;
  color:var(--paper-2);opacity:.55;
  pointer-events:none;
}
.page-hero__skyline .city-line{
  stroke-dasharray:100;stroke-dashoffset:100;
  transition:stroke-dashoffset 1.8s var(--ease);
  transition-delay:var(--d,.2s);
}
.page-hero__skyline .city-window{
  opacity:0;
  transition:opacity 1.2s var(--ease);
  transition-delay:var(--d,1.8s);
}
body.intro-ready .page-hero__skyline .city-line{stroke-dashoffset:0}
body.intro-ready .page-hero__skyline .city-window{opacity:.85}

/* 文字を読みやすくするための柔らかなシャドウ */
.page-hero--skyline .page-hero__en,
.page-hero--skyline .page-hero__title{
  text-shadow:0 2px 24px rgba(0,0,0,.6),0 1px 3px rgba(0,0,0,.3);
}

/* 浮遊する小さな粒子 */
.page-hero__sparkle{
  position:absolute;border-radius:50%;
  background:var(--paper-2);opacity:0;
  pointer-events:none;
  transition:opacity 1s var(--ease) var(--cd,2s);
}
body.intro-ready .page-hero__sparkle{
  opacity:.45;
  animation:citySpark 7s ease-in-out infinite var(--cd,2s);
}
@keyframes citySpark{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(8px,-14px)}
}
.page-hero__sparkle--1{width:5px;height:5px;top:24%;left:28%;--cd:2.2s}
.page-hero__sparkle--2{width:4px;height:4px;top:38%;left:62%;--cd:2.8s}
.page-hero__sparkle--3{width:6px;height:6px;top:18%;left:82%;--cd:3.4s}

/* Service ページ専用：SVG内のテキストラベル */
.page-hero__skyline .svc-num{
  font-family:var(--ff-disp);font-style:italic;font-weight:500;
  font-size:32px;letter-spacing:.04em;
  fill:currentColor;
  opacity:0;
  transition:opacity .9s var(--ease);
  transition-delay:var(--d,1.5s);
}
.page-hero__skyline .svc-lbl{
  font-family:var(--ff-disp);font-style:italic;font-weight:500;
  font-size:18px;letter-spacing:.18em;
  fill:currentColor;
  opacity:0;
  transition:opacity .9s var(--ease);
  transition-delay:var(--d,2s);
}
body.intro-ready .page-hero__skyline .svc-num{opacity:.95}
body.intro-ready .page-hero__skyline .svc-lbl{opacity:.7}
.page-hero--service .page-hero__skyline{opacity:.7}

/* Property ページ専用：タイル内の窓がタイル描画より少し遅れて灯る */
.page-hero--property .page-hero__skyline .city-window{
  transition-delay:calc(var(--d, .3s) + 1.3s);
}
.page-hero--property .page-hero__skyline{opacity:.6}
.page-hero--news .page-hero__skyline{opacity:.6}

/* 携帯版：SVGコンテンツが横方向に途切れないよう、コンテナ中央下端を基点に縮小 */
@media (max-width:600px){
  .page-hero__skyline > g{
    transform:scale(.5);
    transform-origin:50% 100%;
    transform-box:view-box;
  }
  /* スケールでテキストが小さくなるため、フォントサイズを補正 */
  .page-hero__skyline .svc-num{font-size:60px;letter-spacing:.02em}
  .page-hero__skyline .svc-lbl{font-size:34px;letter-spacing:.1em}
  /* 携帯版は線のストロークも見えやすく調整 */
  .page-hero__skyline .city-line{stroke-width:1.4}
}
.page-hero__inner{
  width:100%;max-width:var(--container);
  margin-inline:auto;padding:var(--header-h) var(--pad) 0;
  position:relative;z-index:1;text-align:center;
}
.page-hero__en{
  font-family:var(--ff-disp);font-style:italic;
  font-size:clamp(3rem,8vw,6rem);color:var(--brass-2);line-height:1;
  opacity:0;animation:heroUp .9s var(--ease) .2s forwards;
}
.page-hero__title{
  font-family:var(--ff-serif);font-weight:600;
  font-size:clamp(1.3rem,2.6vw,1.7rem);letter-spacing:.16em;
  margin-top:.6rem;
  opacity:0;animation:heroUp .9s var(--ease) .34s forwards;
}
.page-hero__deco{
  width:1px;height:46px;background:var(--brass-2);margin:1.4rem auto 0;
  opacity:0;animation:heroUp .9s var(--ease) .48s forwards;
}

.breadcrumb{
  background:var(--white);border-bottom:1px solid var(--line-2);
}
.breadcrumb ol{
  max-width:var(--container);margin-inline:auto;padding:1rem var(--pad);
  display:flex;flex-wrap:wrap;gap:.7em;
  font-size:.74rem;letter-spacing:.06em;color:var(--muted);
}
.breadcrumb li{display:flex;align-items:center;gap:.7em}
.breadcrumb li:not(:last-child)::after{content:"—";color:var(--line)}
.breadcrumb a{transition:color var(--t-fast) var(--ease)}
.breadcrumb a:hover{color:var(--brass)}
.breadcrumb [aria-current]{color:var(--ink)}

/* offset for solid header on subpages */
.has-fixed-header{padding-top:0}

/* ----------------------------------------------------------------
   21. Company page blocks
   ---------------------------------------------------------------- */
.message__grid{
  display:grid;grid-template-columns:1fr 1.15fr;
  gap:clamp(2.4rem,6vw,6rem);align-items:center;position:relative;z-index:1;
}
.message__figure{position:relative}
.message__figure img{
  width:100%;aspect-ratio:3/4;object-fit:cover;background:var(--paper-3);
}
.message__figure::before{
  content:"";position:absolute;left:-22px;top:-22px;
  width:60%;height:60%;border:1px solid var(--brass);z-index:-1;
}
.message__quote{
  font-family:var(--ff-serif);font-weight:500;
  font-size:clamp(1.3rem,2.6vw,1.95rem);line-height:1.85;letter-spacing:.05em;
  margin-top:1rem;
}
.message__quote .em{color:var(--brass)}
.message__text{margin-top:1.8rem;color:var(--muted);font-size:.97rem;line-height:2.15}
.message__text p+p{margin-top:1.2rem}

/* philosophy values */
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  margin-top:clamp(2.4rem,5vw,4rem);position:relative;z-index:1;
}
.value-card{
  background:var(--white);padding:clamp(2rem,3.4vw,3rem);
  display:flex;flex-direction:column;gap:1rem;
}
.value-card__no{
  font-family:var(--ff-disp);font-style:italic;font-size:1rem;color:var(--brass);
}
.value-card__icon{width:46px;height:46px;color:var(--brass)}
.value-card__title{font-family:var(--ff-serif);font-weight:600;font-size:1.22rem;letter-spacing:.05em}
.value-card__desc{font-size:.9rem;line-height:2.05;color:var(--muted)}

/* overview table */
.overview-table{
  margin-top:clamp(2rem,4vw,3rem);position:relative;z-index:1;
  border-top:1px solid var(--line);
}
.overview-table tr{border-bottom:1px solid var(--line)}
.overview-table th,.overview-table td{
  text-align:left;padding:1.4rem 1rem;vertical-align:top;font-size:.93rem;
}
.overview-table th{
  width:230px;font-family:var(--ff-serif);font-weight:600;
  letter-spacing:.08em;color:var(--ink);
}
.overview-table th .en{
  display:block;font-family:var(--ff-disp);font-style:italic;
  font-size:.78rem;color:var(--brass);font-weight:400;margin-top:.1em;
}
.overview-table td{color:var(--muted)}

/* history timeline */
.timeline{
  margin-top:clamp(2.4rem,5vw,4rem);position:relative;z-index:1;
  border-left:1px solid var(--line);padding-left:clamp(1.6rem,4vw,3rem);
}
.timeline__item{position:relative;padding-bottom:2.6rem}
.timeline__item:last-child{padding-bottom:0}
.timeline__item::before{
  content:"";position:absolute;left:calc(-1*clamp(1.6rem,4vw,3rem) - 5px);
  top:.4rem;width:9px;height:9px;border-radius:50%;
  background:var(--brass);box-shadow:0 0 0 5px var(--paper);
}
.timeline__year{
  font-family:var(--ff-disp);font-weight:600;font-size:1.5rem;color:var(--brass);
}
.timeline__year .month{font-size:.84rem;color:var(--muted);margin-left:.7em;font-weight:400}
.timeline__text{margin-top:.4rem;font-size:.94rem;color:var(--ink)}

/* access */
.access__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--line);position:relative;z-index:1;
}
.access__map{min-height:340px;background:var(--paper-3)}
.access__map iframe{width:100%;height:100%;border:0;min-height:340px;filter:grayscale(.3)}
.access__info{padding:clamp(2rem,4vw,3.4rem);background:var(--white)}
.access__info dl{margin-top:1.4rem}
.access__info dt{
  font-size:.66rem;letter-spacing:.14em;color:var(--brass);margin-top:1.2rem;
}
.access__info dd{font-size:.95rem;color:var(--ink);margin-top:.2rem}

/* ----------------------------------------------------------------
   22. Service detail rows
   ---------------------------------------------------------------- */
.svc-row{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,5rem);align-items:center;
  position:relative;z-index:1;
}
.svc-row+.svc-row{margin-top:clamp(3.4rem,7vw,7rem)}
.svc-row:nth-child(even) .svc-row__figure{order:2}
.svc-row__figure{position:relative}
.svc-row__figure img{
  width:100%;aspect-ratio:5/4;object-fit:cover;background:var(--paper-3);
}
.svc-row__figure .tag{
  position:absolute;left:0;bottom:0;
  background:var(--ink);color:var(--brass-2);
  font-family:var(--ff-disp);font-style:italic;
  padding:.7em 1.6em;font-size:1.1rem;letter-spacing:.1em;
}
.svc-row__no{
  font-family:var(--ff-disp);font-style:italic;font-size:1.1rem;color:var(--brass);
}
.svc-row__title{
  font-family:var(--ff-serif);font-weight:600;
  font-size:clamp(1.5rem,2.8vw,2.1rem);letter-spacing:.05em;margin-top:.5rem;
}
.svc-row__desc{margin-top:1.4rem;color:var(--muted);font-size:.97rem;line-height:2.15}
.svc-row__list{
  margin-top:1.8rem;display:flex;flex-direction:column;gap:.2rem;
  border-top:1px solid var(--line);
}
.svc-row__list li{
  padding:.85rem .2rem;border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:.9em;font-size:.92rem;
}
.svc-row__list li::before{
  content:"";width:18px;height:18px;flex:none;color:var(--brass);
  background:var(--brass);
  -webkit-mask:var(--ic-check) center/contain no-repeat;
  mask:var(--ic-check) center/contain no-repeat;
}

/* ----------------------------------------------------------------
   23. Contact page
   ---------------------------------------------------------------- */
.contact__grid{
  display:grid;grid-template-columns:1fr 1.4fr;
  gap:clamp(2.4rem,5vw,5rem);position:relative;z-index:1;
}
.contact-side__block{
  padding:2rem 0;border-bottom:1px solid var(--line);
}
.contact-side__block:first-child{padding-top:0}
.contact-side__label{
  font-family:var(--ff-disp);font-style:italic;font-size:1.05rem;color:var(--brass);
}
.contact-side__tel{
  font-family:var(--ff-disp);font-weight:600;font-size:2.5rem;
  color:var(--ink);letter-spacing:.04em;margin:.3rem 0;
}
.contact-side__note{font-size:.84rem;color:var(--muted)}

/* form */
.form{
  background:var(--white);border:1px solid var(--line);
  padding:clamp(1.8rem,4vw,3.2rem);
}
.form__row{margin-bottom:1.7rem}
.form__row--2{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.form label{
  display:flex;align-items:center;gap:.7em;
  font-size:.84rem;font-weight:500;letter-spacing:.06em;
  margin-bottom:.7rem;
}
.form .req,.form .opt{
  font-size:.6rem;letter-spacing:.08em;padding:.3em .7em;
}
.form .req{background:var(--brass);color:#fff}
.form .opt{background:var(--paper-2);color:var(--muted)}
.form input,.form textarea,.form select{
  width:100%;padding:.95em 1.1em;
  background:var(--paper);border:1px solid var(--line);
  font-size:.95rem;transition:border-color var(--t-fast) var(--ease),background var(--t-fast) var(--ease);
}
.form input:focus,.form textarea:focus,.form select:focus{
  outline:0;border-color:var(--brass);background:var(--white);
}
.form textarea{resize:vertical;min-height:150px;line-height:1.9}
.form select{
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:var(--ic-caret);background-repeat:no-repeat;
  background-position:right 1em center;background-size:11px;
}
.form__consent{
  display:flex;align-items:flex-start;gap:.7em;
  font-size:.86rem;color:var(--muted);margin-bottom:1.7rem;
  background:var(--paper);padding:1rem 1.2rem;border:1px solid var(--line-2);
}
.form__consent input{width:auto;flex:none;margin-top:.35em}
.form__consent a{color:var(--brass);text-decoration:underline;text-underline-offset:3px}
.form__submit{display:flex;justify-content:center}
.form__submit .btn{min-width:280px;justify-content:center}

/* Contact Form 7 互換（.form レイアウトに合わせる調整） */
.form .wpcf7-form-control-wrap{display:block}
.form input.wpcf7-form-control,
.form textarea.wpcf7-form-control,
.form select.wpcf7-form-control{width:100%}
.form__consent .wpcf7-form-control-wrap{display:inline}
.form__consent .wpcf7-acceptance,
.form__consent .wpcf7-list-item{margin:0;display:inline}
.form__consent .wpcf7-list-item label{display:flex;align-items:flex-start;gap:.7em;margin:0;font-weight:400;letter-spacing:normal;line-height:1.7}
.form__consent .wpcf7-list-item-label{color:var(--muted)}
.form .wpcf7-not-valid-tip{color:#c0392b;font-size:.78rem;margin-top:.45rem;display:block}
.form .wpcf7-response-output{margin:1.6rem 0 0;padding:.95em 1.2em;border:1px solid var(--line);font-size:.86rem;line-height:1.7}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output{border-color:#c0392b;color:#c0392b}
.wpcf7 form.sent .wpcf7-response-output{border-color:var(--brass);color:var(--ink);background:var(--paper)}
.form .wpcf7-spinner{margin:0 0 0 .8em}
.form input[type="submit"].btn{cursor:pointer}

/* faq accordion */
.faq{margin-top:clamp(2rem,4vw,3rem);position:relative;z-index:1;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;display:flex;align-items:center;gap:1.2rem;
  padding:1.5rem .4rem;text-align:left;
}
.faq-q__mark{
  font-family:var(--ff-disp);font-style:italic;font-size:1.4rem;
  color:var(--brass);flex:none;
}
.faq-q__text{font-family:var(--ff-serif);font-weight:600;font-size:1rem;flex:1;letter-spacing:.03em}
.faq-q__icon{
  position:relative;width:16px;height:16px;flex:none;
}
.faq-q__icon::before,.faq-q__icon::after{
  content:"";position:absolute;background:var(--brass);
  left:50%;top:50%;
}
.faq-q__icon::before{width:16px;height:1.5px;transform:translate(-50%,-50%)}
.faq-q__icon::after{width:1.5px;height:16px;transform:translate(-50%,-50%);transition:transform var(--t-fast) var(--ease)}
.faq-item.is-open .faq-q__icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .4s var(--ease);
}
.faq-a__inner{overflow:hidden}
.faq-item.is-open .faq-a{grid-template-rows:1fr}
.faq-a__text{
  padding:0 .4rem 1.7rem 3.3rem;
  font-size:.92rem;line-height:2.05;color:var(--muted);
}

/* ----------------------------------------------------------------
   24. Properties page — filter bar
   ---------------------------------------------------------------- */
.filter-bar{
  background:var(--white);border:1px solid var(--line);
  position:relative;z-index:3;
  box-shadow:0 40px 80px -54px rgba(20,27,41,.55);
}
.filter-bar__head{
  padding:1.1rem 1.8rem;border-bottom:1px solid var(--line-2);
  display:flex;align-items:center;gap:.8em;
}
.filter-bar__head .en{font-family:var(--ff-disp);font-style:italic;color:var(--brass)}
.filter-bar__grid{
  display:grid;grid-template-columns:repeat(5,1fr);
}
.filter-cell{
  padding:1.4rem 1.6rem;border-right:1px solid var(--line-2);
  display:flex;flex-direction:column;gap:.5rem;
}
.filter-cell:last-child{border-right:0}
.filter-cell label{font-size:.64rem;letter-spacing:.16em;color:var(--brass);font-weight:500}
.filter-cell select,.filter-cell input{
  border:0;border-bottom:1px solid var(--line);padding:.45em 0;
  background:transparent;font-size:.92rem;
}
.filter-cell select{
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:var(--ic-caret);background-repeat:no-repeat;
  background-position:right .1em center;background-size:9px;
}
.filter-bar__submit{padding:1.2rem 1.8rem;border-top:1px solid var(--line-2)}
.filter-bar__submit .btn{width:100%;justify-content:center}

.result-head{
  display:flex;align-items:baseline;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;margin-bottom:2rem;
  position:relative;z-index:1;
}
.result-head__count{
  font-family:var(--ff-serif);font-size:1.15rem;letter-spacing:.04em;
}
.result-head__count b{
  font-family:var(--ff-disp);font-size:2.2rem;color:var(--brass);margin:0 .15em;
}
.result-head__sort{display:flex;align-items:center;gap:.7em;font-size:.82rem;color:var(--muted)}
.result-head__sort select{
  border:1px solid var(--line);padding:.5em 2em .5em .9em;background:var(--white);
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:var(--ic-caret);background-repeat:no-repeat;
  background-position:right .8em center;background-size:9px;
}

/* pagination */
.pager{
  display:flex;justify-content:center;align-items:center;gap:.4rem;
  margin-top:clamp(2.6rem,5vw,4rem);position:relative;z-index:1;
}
.pager a,.pager span{
  min-width:46px;height:46px;display:grid;place-items:center;
  font-family:var(--ff-disp);font-size:1.05rem;
  border:1px solid var(--line);background:var(--white);color:var(--ink);
  transition:all var(--t-fast) var(--ease);
}
.pager a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager .is-current{background:var(--brass);color:#fff;border-color:var(--brass)}
.pager .pager__nav{font-family:var(--ff-sans);font-size:.78rem;letter-spacing:.1em;padding-inline:1.2rem}

/* ----------------------------------------------------------------
   25. Scroll reveal
   ---------------------------------------------------------------- */
[data-reveal]{
  opacity:0;transform:translateY(34px);
  transition:opacity .9s var(--ease),transform .9s var(--ease);
  transition-delay:var(--reveal-d,0ms);
  will-change:opacity,transform;
}
[data-reveal="left"]{transform:translateX(-40px)}
[data-reveal="right"]{transform:translateX(40px)}
[data-reveal="scale"]{transform:scale(.92)}
[data-reveal].is-visible{opacity:1;transform:none}

/* line-mask reveal for headings */
.reveal-line{display:block;overflow:hidden}
.reveal-line>*{
  display:block;transform:translateY(105%);
  transition:transform 1s var(--ease);transition-delay:var(--reveal-d,0ms);
}
.reveal-line.is-visible>*{transform:translateY(0)}

/* ----------------------------------------------------------------
   26. Responsive
   ---------------------------------------------------------------- */
@media (max-width:1080px){
  .hero-search__grid{grid-template-columns:repeat(2,1fr)}
  .hero-search__cell:nth-child(2){border-right:0}
  .filter-bar__grid{grid-template-columns:repeat(3,1fr)}
  .filter-cell:nth-child(3){border-right:0}
  .news__layout{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-nav{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:900px){
  :root{--header-h:72px}
  .gnav__list,.header-tel{display:none}
  .nav-toggle{display:block}
  .header-cta .btn{display:none}
  .intro__grid,.svc-row,.message__grid,.cta__inner,.contact__grid,.access__grid{
    grid-template-columns:1fr;
  }
  .svc-row:nth-child(even) .svc-row__figure{order:0}
  .svc-grid,.values-grid{grid-template-columns:1fr}
  .prop-grid,.column-grid{grid-template-columns:repeat(2,1fr)}
  .reason__grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .flow-list{grid-template-columns:repeat(2,1fr)}
  .flow-step::after{display:none}
  .hero__side{display:none}
  .intro__figure,.intro__art{max-width:480px;margin-inline:auto}
  .access__map{min-height:280px}
  .access__map iframe{min-height:280px}
}

@media (max-width:600px){
  :root{--sec-y:clamp(58px,14vw,86px)}
  .hero-search__grid{grid-template-columns:1fr}
  .hero-search__cell{border-right:0!important;border-bottom:1px solid var(--line-2)}
  .filter-bar__grid{grid-template-columns:1fr}
  .filter-cell{border-right:0!important;border-bottom:1px solid var(--line-2)}
  .prop-grid,.column-grid{grid-template-columns:1fr}
  .stats,.flow-list{grid-template-columns:1fr}
  .form__row--2{grid-template-columns:1fr}
  .overview-table th,.overview-table td{display:block;width:100%;padding:.7rem 0}
  .overview-table th{padding-top:1.3rem;border:0}
  .overview-table td{padding-bottom:1.3rem}
  .footer-nav{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .hero__title{font-size:clamp(1.85rem,6.8vw,2.5rem);line-height:1.5}
  /* 携帯版：ヒーローのリードテキストは非表示 */
  .hero__lead{display:none}
  /* 携帯版：eyebrow を小さくして letter-spacing も詰める */
  .hero__eyebrow{
    font-size:.62rem;letter-spacing:.18em;
    margin-bottom:1.3rem;
  }
  .hero__eyebrow::before{width:22px}
  .hero__actions{margin-top:1.6rem}
  /* 携帯版：長いキャッチコピーが意図した行数に収まるサイズへ */
  .s-head__title{font-size:clamp(.9rem,4vw,1.5rem);letter-spacing:.015em;line-height:1.55}
  .cta__title{font-size:clamp(.9rem,3.8vw,1.45rem);letter-spacing:.015em;line-height:1.55}
  .message__quote{font-size:clamp(.95rem,3.8vw,1.35rem);letter-spacing:.02em;line-height:1.7}
  /* 携帯版：日本語の自然なフレーズ単位改行（モダンブラウザ）+ 長語のフォールバック */
  .s-head__lead,.svc-card__desc,.reason-card__desc,.flow-step__desc,
  .value-card__desc,.footer-brand__desc,.cta__lead,
  .column-card__title,.news-item__title,.prop-card__name,
  .intro__body p,.message__text p,.access__info dd,
  .contact-side__note,.faq-a__text,.svc-row__desc,
  .timeline__text{
    word-break:normal;
    word-break:auto-phrase;
    overflow-wrap:break-word;
    line-break:strict;
  }
  /* 携帯版：カードや見出しブロックの幅を確実にビューポート内へ */
  .svc-row,.svc-row__body,.svc-row__list,.svc-row__figure,
  .svc-card,.prop-card,.flow-step,.reason-card,.value-card,
  .form,.column-card,.access__grid,.message__grid{
    max-width:100%;
  }
  .container,.container--wide,.container--narrow{
    max-width:100%;
  }
  .btn{padding:1.05em 1.8em}
  .news-item{gap:.8rem 1rem}
  .to-top{right:14px;bottom:14px}

  /* 携帯版：複数カードセクションを横スワイプカルーセルに変更してスクロール量を削減 */
  .svc-grid,
  .prop-grid,
  .column-grid,
  .reason__grid,
  .flow-list{
    display:flex;
    grid-template-columns:none;
    align-items:stretch;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    touch-action:pan-x pinch-zoom;
    scrollbar-width:none;
    gap:1rem;
    background:transparent;
    border:none;
    padding:.4rem var(--pad) 1.5rem;
    margin-inline:calc(-1 * var(--pad));
    scroll-padding-left:var(--pad);
  }
  /* スクロール中にdata-revealの transform/opacity が再発火して縦ブレを起こすのを防ぐ */
  .svc-grid [data-reveal],
  .prop-grid [data-reveal],
  .column-grid [data-reveal],
  .reason__grid [data-reveal],
  .flow-list [data-reveal],
  .svc-grid > .svc-card,
  .prop-grid > .prop-card,
  .column-grid > .column-card,
  .reason__grid > .reason-card,
  .flow-list > .flow-step{
    transform:none !important;
    opacity:1 !important;
    transition:none !important;
    will-change:auto;
  }
  .svc-grid > *,
  .prop-grid > *,
  .column-grid > *,
  .reason__grid > *,
  .flow-list > *{
    scroll-snap-stop:always;
  }
  .svc-grid::-webkit-scrollbar,
  .prop-grid::-webkit-scrollbar,
  .column-grid::-webkit-scrollbar,
  .reason__grid::-webkit-scrollbar,
  .flow-list::-webkit-scrollbar{display:none}

  .svc-grid > .svc-card,
  .prop-grid > .prop-card,
  .column-grid > .column-card,
  .reason__grid > .reason-card,
  .flow-list > .flow-step{
    flex:0 0 80%;
    max-width:80%;
    scroll-snap-align:start;
  }
  /* svc-card は元グリッドで border 区切りだったので、カルーセル用に枠線を付与 */
  .svc-grid > .svc-card{
    border:1px solid var(--line);
  }
  /* reason-card は元々ボーダー上線のみ。カルーセルでも自然に */
  .reason__grid > .reason-card{
    padding:1.4rem 1.4rem 1.6rem;
    border:1px solid rgba(255,255,255,.16);
    border-top-width:1px;
    background:rgba(255,255,255,.03);
  }
  /* 矢印（>）が消えても流れが伝わるよう調整 */
  .flow-list > .flow-step::after{display:none}

  /* スワイプを促す視覚ヒント：次カードの一部を見せる + 右にフェード */
  .svc-grid,
  .prop-grid,
  .column-grid,
  .reason__grid,
  .flow-list{
    -webkit-mask-image:linear-gradient(90deg,#000 0,#000 calc(100% - 28px),transparent 100%);
            mask-image:linear-gradient(90deg,#000 0,#000 calc(100% - 28px),transparent 100%);
  }
}

/* ----------------------------------------------------------------
   27. Icon mask data-URIs
   ---------------------------------------------------------------- */
/* intro gating — hero/page-hero animations wait until curtain opens */
.hero__eyebrow,
.hero__title>span>i,
.hero__lead,
.hero__actions,
.hero__side,
.hero__scroll,
.page-hero__en,
.page-hero__title,
.page-hero__deco{
  animation-play-state:paused;
}
body.intro-ready .hero__eyebrow,
body.intro-ready .hero__title>span>i,
body.intro-ready .hero__lead,
body.intro-ready .hero__actions,
body.intro-ready .hero__side,
body.intro-ready .hero__scroll,
body.intro-ready .page-hero__en,
body.intro-ready .page-hero__title,
body.intro-ready .page-hero__deco{
  animation-play-state:running;
}

:root{
  --ic-phone:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M6.6 10.8a15 15 0 006.6 6.6l2.2-2.2a1 1 0 011-.24 11 11 0 003.5.56 1 1 0 011 1V20a1 1 0 01-1 1A17 17 0 013 4a1 1 0 011-1h3.5a1 1 0 011 1 11 11 0 00.56 3.5 1 1 0 01-.24 1z"/></svg>');
  --ic-pin:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M12 2a7 7 0 00-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 00-7-7zm0 9.5A2.5 2.5 0 1112 6.5a2.5 2.5 0 010 5z"/></svg>');
  --ic-caret:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 12 8" fill="none" stroke="%231c2433" stroke-width="1.6"><path d="M1 1l5 5 5-5"/></svg>');
  --ic-check:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M9 16.2l-3.5-3.5L4 14.2 9 19l11-11-1.5-1.5z"/></svg>');
}
