@charset "UTF-8";
@-ms-viewport {
  width: device-width;
}
/*--------------------------------------------------------------------------
CSS　カスタム設定(flag/top-style.css)ver.1 2026.04.16
--------------------------------------------------------------------------*/
/*■■■■■■ 基本設定 ■■■■■■■*/
/*FLAG 青緑　濃い*/
/*FLAG 青緑　薄い*/
/*FLAG 緑　*/
/*■　共有設定　■*/
.text-left {
  text-align: left;
}

/*■■■■■■　#0 ムービー　■■■■■■■*/
/* ========================================
FV VIDEO
======================================== */
.top-fv {
  margin: 80px auto 0;
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  overflow: hidden;
}

/* 共通 */
.top-fv-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: -1;
  background: #000;
}

/* PC */
.top-fv-video-pc {
  display: block;
}

/* SP */
.top-fv-video-sp {
  display: none;
}

/* ========================================
SP
======================================== */
@media screen and (max-width: 767px) {
  /* PC動画を非表示 */
  .top-fv-video-pc {
    display: none;
  }
  /* SP動画を表示 */
  .top-fv-video-sp {
    display: block;
  }
}
/* ========================================
初回FV再生中
======================================== */
/* ヘッダー隠す */
body.fv-intro-playing #header {
  -webkit-transform: translateY(-200%);
          transform: translateY(-200%);
}

/* PCのみ margin を消す */
@media screen and (min-width: 1024px) {
  body.fv-intro-playing .top-fv {
    margin-top: 0;
    height: auto;
    aspect-ratio: 16/9;
  }
}
/* ========================================
MOVIE
======================================== */
.fv-movie-wrap {
  margin: 80px auto 0;
  position: absolute;
  inset: 0;
  z-index: 10;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  background: #58799c;
  opacity: 1;
  visibility: visible;
  overflow: hidden;
  -webkit-transition: opacity 1s ease, visibility 1s ease;
  transition: opacity 1s ease, visibility 1s ease;
}
.fv-movie-wrap video.pc-view {
  display: block;
}
.fv-movie-wrap video.sp-view {
  display: none;
}

/* フェードアウト */
.fv-movie-wrap.hide {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* 動画 */
.fv-movie {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: block;
}

/* iPhone黒線対策 */
.fv-movie,
.top-fv img {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
}

/* ========================================
SKIP
======================================== */
.fv-skip-btn {
  position: absolute;
  z-index: 20;
  padding: 0;
  border: none;
  background: none;
  font-family: "Montserrat", sans-serif;
  letter-spacing: 0.15em;
  color: #FFF;
  cursor: pointer;
  -webkit-animation: skipBlink 1.4s ease infinite;
          animation: skipBlink 1.4s ease infinite;
}

/* 点滅 */
@-webkit-keyframes skipBlink {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.3;
  }
  100% {
    opacity: 1;
  }
}
@keyframes skipBlink {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.3;
  }
  100% {
    opacity: 1;
  }
}
.swipe-guide {
  display: none;
}

/* Skip */
.fv-skip-btn {
  right: 20px;
  bottom: 25px;
  font-size: 1.3rem;
}

/* ========================================
FV INTRO
======================================== */
/* 初回はヘッダー隠す */
body.fv-intro-playing #header {
  -webkit-transform: translateY(-200%);
          transform: translateY(-200%);
}

/* PCのみFVを上に詰める */
@media screen and (min-width: 1024px) {
  body.fv-intro-playing .fv-movie-wrap {
    margin-top: 0;
  }
  body.fv-intro-playing .top-fv {
    margin-top: 0;
  }
}
/*■■■■■■　#0 伏見稲荷　FLAG　俯瞰　■■■■■■■*/
.top-fv img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.top-fv img.sp-view {
  display: none;
}

.swipe-guide {
  display: none;
}

/*タイトル*/
.top-title {
  padding: 0;
  font-family: "Noto Serif JP", serif;
  font-size: 4.6rem;
  line-height: 1.6;
  letter-spacing: 4px;
  text-align: center;
  font-weight: 400;
  color: #FFF;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  position: absolute;
  z-index: 2;
  top: 12%;
  left: 0;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  display: block;
  gap: 2px;
  width: 100%;
  text-shadow: 0 0 6px #2b7cdd, 0 0 12px #2b7cdd, 0 0 18px #2b7cdd;
}
.top-title span {
  margin-right: -1rem;
}

.top-img-caption {
  padding: 5px 10px;
  font-family: "Noto Serif JP", serif;
  font-size: 1rem;
  color: #FFF;
  position: absolute;
  right: 0;
  bottom: 0;
  text-shadow: 0 0 1px #000, 0 0 3px #000, 0 0 5px #000, 0 0 7px #000;
}

/*■■■■■■　#1 ウェルカム　■■■■■■■*/
.bg-top-flag {
  margin: 0 auto;
  padding: 2em 0 6em;
  width: 100%;
  background: -webkit-gradient(linear, left bottom, left top, from(#003663), to(#58799c));
  background: linear-gradient(to top, #003663, #58799c);
  background: url(../images/top/bg-flag-drape_pc.webp) bottom center no-repeat;
  background-size: cover;
  color: #FFF;
}
.bg-top-flag .breadcrumb li {
  color: #FFF;
}
.bg-top-flag .breadcrumb li a {
  color: #FFF;
}

.top-text-mi-en {
  margin-bottom: 40px;
  font-family: "Cormorant", serif;
  font-size: 6rem;
  line-height: 1.2;
  font-weight: 300;
}
.top-text-mi-en strong {
  font-size: 6.2rem;
  line-height: 1;
  font-weight: 200;
}

.top-data-block {
  margin: 4em auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  border: 0;
}

.top-point-box {
  margin: 0;
  border-right: 1px solid #FFF;
  padding: 10px 18px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.top-point-box:first-child {
  border-top: 0;
  border-left: 1px solid #FFF;
}

.top-point-text {
  font-family: "Noto Serif JP", serif;
  font-size: 1.3rem;
  line-height: 1.4;
  font-weight: 400;
}
.top-point-text span {
  font-size: 1.8rem;
}
.top-point-text strong {
  font-family: "Cormorant", serif;
  font-size: 3.4rem;
  line-height: 1;
  font-weight: 300;
}

.top-point-note {
  margin: 0 auto 2em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.top-point-note p {
  font-family: "Noto Serif JP", serif;
  font-size: 1rem;
  line-height: 1.4;
  text-align: left;
}

.ico-first-time {
  padding: 0 0 0 70px;
  position: relative;
}
.ico-first-time:before {
  content: "";
  display: block;
  width: 50px;
  height: 50px;
  background: url(../images/top/ico-first-time.svg?20260619) center center no-repeat;
  background-size: cover;
  position: absolute;
  left: 0;
  top: 0;
}
.ico-first-time:after {
  content: "※1";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  left: 47px;
  top: 35px;
  font-size: 1rem;
  line-height: 1.2;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  color: #FFF;
}

/*■　リンクボタン　■*/
.top-btn-box {
  margin: 180px 0 40px;
}

a.link-btn-gra {
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 5px;
  width: 320px;
  height: 52px;
  border-radius: 26px;
  background: -webkit-gradient(linear, left top, right top, from(#4d8cbe), to(#54b77f));
  background: linear-gradient(to right, #4d8cbe, #54b77f);
  color: #FFF;
  font-size: 1.5rem;
  font-weight: 500;
}
a.link-btn-gra:after {
  content: "";
  display: block;
  width: 26px;
  height: 16px;
  background: url(../images/top/btn-arrow.svg) center center no-repeat;
  background-size: cover;
}
a.link-btn-gra:link, a.link-btn-gra:visited, a.link-btn-gra:hover, a.link-btn-gra:active {
  color: #FFF;
}

.text-foot-note {
  margin: 0 auto;
  display: inline-block;
  font-size: 1rem;
  text-align: left;
}

/*■■■■■■　#2 伏見稲荷FLAGイメージ　■■■■■■■*/
.apartment-img-block {
  margin: 0 auto;
  margin-top: -21em;
  width: 100%;
  aspect-ratio: 3/4;
  overflow: hidden;
  background: #eee;
  position: relative;
}
.apartment-img-block img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.crip-flag-wave {
  position: relative;
  -webkit-mask-image: url("../images/crip-flag-wave-top.svg");
  mask-image: url("../images/crip-flag-wave-top.svg");
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: top;
  mask-position: top;
}

.apartment-img-title {
  width: 100%;
  position: absolute;
  left: 0;
  top: 30%;
  text-align: center;
}
.apartment-img-title img {
  margin: 0 auto;
  width: 600px;
  height: auto;
}

.apartment-sub-title {
  font-family: "Noto Serif JP", serif;
  font-size: 1.3rem;
  line-height: 1.6;
  color: #222;
  position: absolute;
  left: 0;
  bottom: 10%;
  text-align: center;
  width: 100%;
}

.img-caption-bk {
  padding: 5px 10px;
  font-family: "Noto Serif JP", serif;
  font-size: 1rem;
  color: #333;
  position: absolute;
  right: 0;
  bottom: 18%;
  text-shadow: 0 0 1px #FFF, 0 0 3px #FFF, 0 0 5px #FFF, 0 0 7px #FFF;
}

/*■　スクリプトムービー　■*/
/* ========================================
APARTMENT MOVIE
======================================== */
.bg-wave-gra {
  margin: 0 auto;
  width: 100%;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(10%, #003663), color-stop(90%, #b2cae3));
  background: linear-gradient(to bottom, #003663 10%, #b2cae3 90%);
}

.top-apartment-movie {
  padding: 0;
  width: 100%;
  aspect-ratio: 6/5;
  position: relative;
  overflow: hidden;
  background: #FFF;
  margin: auto;
}

/* 初期状態では停止 */
.visual-flag,
.visual-flag img,
.visual-base,
.visual-base img,
.white-flash,
.apartment-img-title,
.apartment-sub-title,
.img-caption-bk {
  -webkit-animation: none;
          animation: none;
}

/* =========================
アニメーション開始後
========================= */
.top-apartment-movie.active .visual-flag {
  -webkit-animation: none;
          animation: none;
  opacity: 0;
  pointer-events: none;
}

.top-apartment-movie.active .visual-flag img {
  -webkit-animation: none;
          animation: none;
  -webkit-transform: none;
          transform: none;
}

.top-apartment-movie.active .white-flash {
  -webkit-animation: none;
          animation: none;
  opacity: 0;
}

.top-apartment-movie.active .visual-base {
  -webkit-animation: baseFadePc 2s ease forwards;
          animation: baseFadePc 2s ease forwards;
  opacity: 1;
}

.top-apartment-movie.active .visual-base img {
  -webkit-animation: none;
          animation: none;
  -webkit-transform: scale(1);
          transform: scale(1);
}

/* PC用フェード */
@-webkit-keyframes baseFadePc {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes baseFadePc {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.top-apartment-movie.active .apartment-img-title {
  -webkit-animation: titleFade 2s ease forwards;
          animation: titleFade 2s ease forwards;
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}

.top-apartment-movie.active .apartment-sub-title {
  -webkit-animation: titleFade 2s ease forwards;
          animation: titleFade 2s ease forwards;
  -webkit-animation-delay: 1.5s;
          animation-delay: 1.5s;
}

.top-apartment-movie.active .img-caption-bk {
  -webkit-animation: titleFade 2s ease forwards;
          animation: titleFade 2s ease forwards;
  -webkit-animation-delay: 3s;
          animation-delay: 3s;
}

/* =========================
ループバー
========================= */
.loop-bar {
  width: 100%;
  height: 100px;
  position: absolute;
  left: 0;
  overflow: hidden;
  z-index: 20;
}

.loop-bar-top {
  top: -1px;
}

.loop-bar-bottom {
  bottom: 0;
}

.loop-track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  height: 100%;
  -webkit-animation: loopBar 20s linear infinite;
          animation: loopBar 20s linear infinite;
}

.loop-track.reverse {
  animation-direction: reverse;
}

.loop-track img {
  height: 100%;
  width: auto;
  display: block;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

@-webkit-keyframes loopBar {
  0% {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes loopBar {
  0% {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/* =========================
メインビジュアル
========================= */
.apartment-visual {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

/* 共通 */
.visual-item {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  overflow: hidden;
}

.visual-item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

/* =========================
FLAG
========================= */
.visual-flag {
  opacity: 0;
  z-index: 3;
  overflow: hidden;
}

.visual-flag img {
  width: auto;
  height: 100%;
  display: block;
  min-width: 200%;
}

/* フェード */
@-webkit-keyframes flagFade {
  0% {
    opacity: 0;
  }
  8% {
    opacity: 1;
  }
  42% {
    opacity: 1;
  }
  55% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes flagFade {
  0% {
    opacity: 0;
  }
  8% {
    opacity: 1;
  }
  42% {
    opacity: 1;
  }
  55% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
/* =========================
BASE
========================= */
.visual-base {
  opacity: 0;
  z-index: 2;
}

.visual-base img {
  -webkit-transform: scale(1);
          transform: scale(1);
}
.visual-base .sp-view {
  display: none;
}
.visual-base .pc-view {
  display: block;
}

@-webkit-keyframes baseFade {
  0%, 50% {
    opacity: 0;
  }
  62% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}

@keyframes baseFade {
  0%, 50% {
    opacity: 0;
  }
  62% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes baseZoom {
  0% {
    -webkit-transform: scale(1.25);
            transform: scale(1.25);
  }
  50% {
    -webkit-transform: scale(1.25);
            transform: scale(1.25);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes baseZoom {
  0% {
    -webkit-transform: scale(1.25);
            transform: scale(1.25);
  }
  50% {
    -webkit-transform: scale(1.25);
            transform: scale(1.25);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
/* =========================
タイトル類
========================= */
.apartment-img-title {
  width: 100%;
  position: absolute;
  left: 0;
  top: 15%;
  z-index: 10;
  text-align: center;
  opacity: 0;
}

.apartment-sub-title {
  font-family: "Noto Serif JP", serif;
  font-size: 2.4rem;
  line-height: 1.6;
  color: #222;
  position: absolute;
  left: 0;
  bottom: 15%;
  text-align: center;
  width: 100%;
  z-index: 10;
  opacity: 0;
  -webkit-animation: titleFade 2s ease forwards;
          animation: titleFade 2s ease forwards;
  -webkit-animation-delay: 11.5s;
          animation-delay: 11.5s;
}

.img-caption-bk {
  padding: 5px 10px;
  font-family: "Noto Serif JP", serif;
  font-size: 1rem;
  color: #333;
  position: absolute;
  right: 0;
  bottom: 28%;
  z-index: 10;
  opacity: 0;
  text-shadow: 0 0 1px #FFF, 0 0 3px #FFF, 0 0 5px #FFF, 0 0 7px #FFF;
}

@-webkit-keyframes titleFade {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes titleFade {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.flag-bottom {
  display: block;
  width: 100%;
  height: auto;
  position: absolute;
  left: 0;
  bottom: 0;
}
.flag-bottom img {
  width: 100%;
  height: 100%;
}

/*■■■■■■　#4 各カテゴリーへの　リンク　■■■■■■■*/
.top-cate-img-block {
  margin: -1px auto 0;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #eee;
  position: relative;
}
.top-cate-img-block img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}

.top-cate-btn-text-block {
  position: absolute;
  width: 100%;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  text-align: center;
  color: #FFF;
}

a.top-img-link-btn {
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  max-width: 160px;
  height: 30px;
  background: -webkit-gradient(linear, left top, left bottom, from(#003663), color-stop(#58799c), to(#003663));
  background: linear-gradient(to bottom, #003663, #58799c, #003663);
  background-size: 200% 100%;
  background-position: left center;
  border: 1px solid #FFF;
  font-family: "Cormorant", serif;
  letter-spacing: 2px;
  font-size: 1.6rem;
  gap: 5px;
  -webkit-transition: background-position 0.8s ease, -webkit-box-shadow 0.4s ease, -webkit-transform 0.4s ease;
  transition: background-position 0.8s ease, -webkit-box-shadow 0.4s ease, -webkit-transform 0.4s ease;
  transition: background-position 0.8s ease, box-shadow 0.4s ease, transform 0.4s ease;
  transition: background-position 0.8s ease, box-shadow 0.4s ease, transform 0.4s ease, -webkit-box-shadow 0.4s ease, -webkit-transform 0.4s ease;
}
a.top-img-link-btn img {
  width: 10px;
  height: auto;
  -webkit-transition: -webkit-transform 0.4s ease;
  transition: -webkit-transform 0.4s ease;
  transition: transform 0.4s ease;
  transition: transform 0.4s ease, -webkit-transform 0.4s ease;
}
a.top-img-link-btn:link, a.top-img-link-btn:visited, a.top-img-link-btn:hover, a.top-img-link-btn:active {
  color: #FFF;
}

a.top-img-link-btn:hover {
  background-position: right center;
  -webkit-box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
          box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15);
}
a.top-img-link-btn:hover img {
  -webkit-transform: translateX(3px);
          transform: translateX(3px);
}

.bg-gra-btn-block {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  background: -webkit-gradient(linear, left top, left bottom, from(#b2cae3), to(#ffffff));
  background: linear-gradient(to bottom, #b2cae3, #ffffff);
  color: #333;
  text-align: center;
}

.top-cate-text-block {
  padding: 2em;
}

.top-read-m {
  margin-bottom: 6px;
  font-family: "Noto Serif JP", serif;
  font-size: 2.4rem;
  line-height: 1.6;
  font-weight: 500;
}

.top-cate-btn-block {
  margin: 2em 1em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2em;
}

.top-cate-btn-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1em;
}

.top-cate-img-box {
  width: 100%;
  max-width: 620px;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #eee;
  position: relative;
}
.top-cate-img-box img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}

.btn-img-caption {
  padding: 5px 10px;
  position: absolute;
  left: auto;
  right: 0;
  bottom: 0;
  color: #FFF;
  font-family: "Noto Serif JP", serif;
  font-size: 1rem;
}

/*サブリンクボタン*/
.top-cate-sub-btn-box {
  margin: 2em 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

a.top-cate-sub-img-box {
  width: 50%;
  max-width: 620px;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #eee;
  position: relative;
}
a.top-cate-sub-img-box img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
a.top-cate-sub-img-box:link, a.top-cate-sub-img-box:visited, a.top-cate-sub-img-box:hover, a.top-cate-sub-img-boxactive {
  color: #FFF;
}
a.top-cate-sub-img-box .top-text-mi-en {
  font-size: 2.4rem;
}
a.top-cate-sub-img-box .top-text-mi-en small {
  display: block;
  font-size: 1.4rem;
}

.top-info-block {
  margin: 4em auto 2em;
  width: 100%;
  max-width: 620px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border: 1px solid #003663;
  background-color: #FFF;
}

.top-info-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 42px;
  font-family: "Cormorant", serif;
  font-size: 1.8rem;
  color: #003663;
  line-height: 1.2;
  border-bottom: 1px solid #003663;
}

/*■■■■■■ NEWS LIST ■■■■■■■*/
.top-news-item {
  padding: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 10px;
  text-decoration: none;
  color: #222;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.top-news-item:hover {
  opacity: 0.7;
}

.top-news-date {
  width: 80px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: 1.4rem;
  line-height: 1.6;
  color: #888;
  text-align: left;
}

.top-news-text {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-size: 1.4rem;
  line-height: 1.8;
  text-align: left;
}

/*■■■■■■ ベクター調整 ■■■■■■■*/
.background-decoration {
  width: 100%;
  height: atuo;
  overflow: hidden;
  position: relative;
}

.background-decoration svg {
  width: 100%;
  height: 100%;
  display: block;
}

.flag-wave-top {
  position: relative;
  z-index: 0;
}
.flag-wave-top svg {
  position: absolute;
  top: -1px;
}

/*■■■■■■ ベクター調整 ■■■■■■■*/
.background-decoration {
  width: 100%;
  height: 24vw;
  overflow: hidden;
  position: relative;
}

.background-decoration svg {
  width: 100%;
  height: auto;
  display: block;
}

.radius-top {
  position: relative;
  z-index: 0;
}
.radius-top svg {
  position: absolute;
  top: -1px;
}

/*===============================
■■　スマホ用　■■
===============================*/
/*------------(XS)------------*/
@media (min-width: 320px) and (max-width: 767px) {
  .top-fv {
    margin-top: 0;
    width: 100%;
    aspect-ratio: 9/16;
    overflow: hidden;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    position: relative;
  }
  .top-fv img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
  }
  /*■■■■■■　#1 ウェルカム(XS)　■■■■■■■*/
  .bg-top-flag {
    padding: 4em 0;
    background: -webkit-gradient(linear, left bottom, left top, from(#003663), to(#58799c));
    background: linear-gradient(to top, #003663, #58799c);
    background: url(../images/top/bg-flag-drape_sp.webp) top center no-repeat;
    background-size: 100% auto;
    color: #FFF;
  }
  .top-text-mi-en {
    margin-bottom: 20px;
    font-family: "Cormorant", serif;
    font-size: 4rem;
    line-height: 1.2;
    font-weight: 300;
  }
  .top-text-mi-en strong {
    font-size: 6.2rem;
    line-height: 1;
    font-weight: 200;
  }
  .top-data-block {
    margin: 4em 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    border: 0;
  }
  .top-point-box {
    margin: 0;
    border: 0;
    border-bottom: 1px solid #FFF;
    padding: 20px 0 25px;
    width: 100%;
    max-width: 390px;
  }
  .top-point-box:first-child {
    border-left: 0;
    border-top: 1px solid #FFF;
  }
  .top-point-text {
    font-family: "Noto Serif JP", serif;
    font-size: 1.4rem;
    line-height: 1.4;
    font-weight: 400;
  }
  .top-point-text span {
    font-size: 2rem;
  }
  .top-point-text strong {
    font-family: "Cormorant", serif;
    font-size: 3.6rem;
    font-weight: 300;
  }
  .top-point-text small {
    font-size: 1rem;
  }
  /*■　リンクボタン　■*/
  .top-btn-box {
    margin: 180px 0 40px;
  }
  a.link-btn-gra {
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 5px;
    width: 320px;
    height: 52px;
    border-radius: 26px;
    background: -webkit-gradient(linear, left top, right top, from(#4d8cbe), to(#54b77f));
    background: linear-gradient(to right, #4d8cbe, #54b77f);
    color: #FFF;
    font-size: 1.5rem;
    font-weight: 500;
  }
  a.link-btn-gra:after {
    content: "";
    display: block;
    width: 26px;
    height: 16px;
    background: url(../images/top/btn-arrow.svg) center center no-repeat;
    background-size: cover;
  }
  a.link-btn-gra:link, a.link-btn-gra:visited, a.link-btn-gra:hover, a.link-btn-gra:active {
    color: #FFF;
  }
  .text-foot-note {
    margin: 0 auto;
    display: inline-block;
    font-size: 1rem;
    text-align: left;
  }
  /*■■■■■■　#2 伏見稲荷FLAGイメージ(XS)　■■■■■■■*/
  .apartment-img-block {
    margin-top: -8em;
    width: 100%;
    aspect-ratio: 9/16;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  .apartment-img-block img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
  }
  .crip-flag-wave {
    position: relative;
    -webkit-mask-image: url("../images/crip-flag-wave-top_9-16.svg");
    mask-image: url("../images/crip-flag-wave-top_9-16.svg");
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: top;
    mask-position: top;
  }
  .apartment-img-title {
    width: 100%;
    position: absolute;
    left: 0;
    top: 20%;
  }
  .apartment-sub-title {
    font-family: "Noto Serif JP", serif;
    font-size: 1.3rem;
    line-height: 1.6;
    color: #222;
    position: absolute;
    left: 0;
    bottom: 10%;
    text-align: center;
    width: 100%;
  }
  .img-caption-bk {
    padding: 5px 10px;
    font-family: "Noto Serif JP", serif;
    font-size: 1rem;
    color: #333;
    position: absolute;
    right: 0;
    bottom: 95px;
    text-shadow: 0 0 1px #FFF, 0 0 3px #FFF, 0 0 5px #FFF, 0 0 7px #FFF;
  }
  /*■　スクリプトムービー(XS)　■*/
  /* ========================================
  APARTMENT MOVIE
  ======================================== */
  .top-apartment-movie {
    padding: 0;
    width: 100%;
    max-width: 500px;
    aspect-ratio: 9/16;
    position: relative;
    overflow: hidden;
    background: #FFF;
    margin: auto;
  }
  /* 初期状態では停止 */
  .visual-flag,
  .visual-flag img,
  .visual-base,
  .visual-base img,
  .white-flash,
  .apartment-img-title,
  .apartment-sub-title,
  .img-caption-bk {
    -webkit-animation: none;
            animation: none;
  }
  /* =========================
  アニメーション開始後
  ========================= */
  .top-apartment-movie.active .visual-flag {
    -webkit-animation: flagFade 13s ease forwards;
            animation: flagFade 13s ease forwards;
  }
  .top-apartment-movie.active .visual-flag img {
    -webkit-animation: flagPan 3.5s ease-in-out forwards;
            animation: flagPan 3.5s ease-in-out forwards;
    -webkit-animation-delay: 2s;
            animation-delay: 2s;
  }
  .top-apartment-movie.active .white-flash {
    -webkit-animation: whiteFlash 12s forwards;
            animation: whiteFlash 12s forwards;
  }
  .top-apartment-movie.active .visual-base {
    -webkit-animation: baseFade 12s forwards;
            animation: baseFade 12s forwards;
  }
  .top-apartment-movie.active .visual-base img {
    -webkit-animation: baseZoom 12s ease forwards;
            animation: baseZoom 12s ease forwards;
  }
  .top-apartment-movie.active .apartment-img-title {
    -webkit-animation: titleFade 2s ease forwards;
            animation: titleFade 2s ease forwards;
    -webkit-animation-delay: 9s;
            animation-delay: 9s;
  }
  .top-apartment-movie.active .apartment-sub-title {
    -webkit-animation: titleFade 2s ease forwards;
            animation: titleFade 2s ease forwards;
    -webkit-animation-delay: 9.5s;
            animation-delay: 9.5s;
  }
  .top-apartment-movie.active .img-caption-bk {
    -webkit-animation: titleFade 2s ease forwards;
            animation: titleFade 2s ease forwards;
    -webkit-animation-delay: 10s;
            animation-delay: 10s;
  }
  /* =========================
  ループバー
  ========================= */
  .loop-bar {
    width: 100%;
    height: 128px;
    position: absolute;
    left: 0;
    overflow: hidden;
    z-index: 20;
  }
  .loop-bar-top {
    top: -1px;
  }
  .loop-bar-bottom {
    width: 100%;
    height: auto;
    position: absolute;
    left: 0;
    overflow: hidden;
    z-index: 20;
    bottom: 0;
  }
  .loop-bar-bottom img {
    width: 100%;
    height: auto;
  }
  .loop-track {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    height: 100%;
    -webkit-animation: loopBar 12s linear infinite;
            animation: loopBar 12s linear infinite;
  }
  .loop-track.reverse {
    animation-direction: reverse;
  }
  .loop-track img {
    height: 100%;
    width: auto;
    display: block;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  @-webkit-keyframes loopBar {
    0% {
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
    }
    100% {
      -webkit-transform: translateX(0);
              transform: translateX(0);
    }
  }
  @keyframes loopBar {
    0% {
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
    }
    100% {
      -webkit-transform: translateX(0);
              transform: translateX(0);
    }
  }
  /* =========================
  メインビジュアル
  ========================= */
  .apartment-visual {
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
  }
  /* 共通 */
  .visual-item {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    overflow: hidden;
  }
  .visual-item img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    display: block;
  }
  /* =========================
  FLAG
  ========================= */
  .visual-flag {
    opacity: 0;
    z-index: 3;
    overflow: hidden;
  }
  .visual-flag img {
    width: auto;
    height: 100%;
    display: block;
    min-width: 200%;
  }
  /* フェード */
  @-webkit-keyframes flagFade {
    0% {
      opacity: 0;
    }
    8% {
      opacity: 1;
    }
    42% {
      opacity: 1;
    }
    55% {
      opacity: 0;
    }
    100% {
      opacity: 0;
    }
  }
  @keyframes flagFade {
    0% {
      opacity: 0;
    }
    8% {
      opacity: 1;
    }
    42% {
      opacity: 1;
    }
    55% {
      opacity: 0;
    }
    100% {
      opacity: 0;
    }
  }
  /* 左端 → 右端 */
  @-webkit-keyframes flagPan {
    0% {
      -webkit-transform: translateX(0);
              transform: translateX(0);
    }
    85% {
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
    }
    100% {
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
    }
  }
  @keyframes flagPan {
    0% {
      -webkit-transform: translateX(0);
              transform: translateX(0);
    }
    85% {
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
    }
    100% {
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
    }
  }
  /* =========================
  ホワイトフラッシュ
  ========================= */
  .white-flash {
    position: absolute;
    inset: 0;
    background: #FFF;
    opacity: 0;
    z-index: 5;
  }
  @-webkit-keyframes whiteFlash {
    0%, 45% {
      opacity: 0;
    }
    52% {
      opacity: 1;
    }
    60% {
      opacity: 0;
    }
    100% {
      opacity: 0;
    }
  }
  @keyframes whiteFlash {
    0%, 45% {
      opacity: 0;
    }
    52% {
      opacity: 1;
    }
    60% {
      opacity: 0;
    }
    100% {
      opacity: 0;
    }
  }
  /* =========================
  BASE
  ========================= */
  .visual-base {
    opacity: 0;
    z-index: 2;
  }
  .visual-base img {
    -webkit-transform: scale(1.25);
            transform: scale(1.25);
  }
  .visual-base .sp-view {
    display: block;
  }
  .visual-base .pc-view {
    display: none;
  }
  @-webkit-keyframes baseFade {
    0%, 50% {
      opacity: 0;
    }
    62% {
      opacity: 1;
    }
    100% {
      opacity: 1;
    }
  }
  @keyframes baseFade {
    0%, 50% {
      opacity: 0;
    }
    62% {
      opacity: 1;
    }
    100% {
      opacity: 1;
    }
  }
  @-webkit-keyframes baseZoom {
    0% {
      -webkit-transform: scale(1.25);
              transform: scale(1.25);
    }
    50% {
      -webkit-transform: scale(1.25);
              transform: scale(1.25);
    }
    100% {
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  @keyframes baseZoom {
    0% {
      -webkit-transform: scale(1.25);
              transform: scale(1.25);
    }
    50% {
      -webkit-transform: scale(1.25);
              transform: scale(1.25);
    }
    100% {
      -webkit-transform: scale(1);
              transform: scale(1);
    }
  }
  /* =========================
  タイトル類
  ========================= */
  .apartment-img-title {
    width: 100%;
    position: absolute;
    left: 0;
    top: 20%;
    z-index: 10;
    text-align: center;
    opacity: 0;
  }
  .apartment-sub-title {
    font-family: "Noto Serif JP", serif;
    font-size: 1.3rem;
    line-height: 1.6;
    color: #222;
    position: absolute;
    left: 0;
    bottom: 13%;
    text-align: center;
    width: 100%;
    z-index: 10;
    opacity: 0;
    -webkit-animation: titleFade 2s ease forwards;
            animation: titleFade 2s ease forwards;
    -webkit-animation-delay: 11.5s;
            animation-delay: 11.5s;
  }
  .img-caption-bk {
    padding: 5px 10px;
    font-family: "Noto Serif JP", serif;
    font-size: 1rem;
    color: #333;
    position: absolute;
    right: 0;
    bottom: 20%;
    z-index: 10;
    opacity: 0;
    text-shadow: 0 0 1px #FFF, 0 0 3px #FFF, 0 0 5px #FFF, 0 0 7px #FFF;
  }
  @-webkit-keyframes titleFade {
    0% {
      opacity: 0;
      -webkit-transform: translateY(20px);
              transform: translateY(20px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes titleFade {
    0% {
      opacity: 0;
      -webkit-transform: translateY(20px);
              transform: translateY(20px);
    }
    100% {
      opacity: 1;
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  /* =========================
  SP
  ========================= */
}
@media screen and (min-width: 320px) and (max-width: 767px) and (max-width: 768px) {
  .apartment-sub-title {
    font-size: 1.3rem;
    padding: 0 20px;
  }
  .img-caption-bk {
    font-size: 0.8rem;
    bottom: 27%;
  }
  .loop-bar {
    height: 60px;
  }
}
@media (min-width: 320px) and (max-width: 767px) {
  /*■■■■■■　#4 各カテゴリーへの　リンク　■■■■■■■*/
  .top-cate-img-block {
    margin: -1px 0 0;
    width: 100%;
    aspect-ratio: 1/1;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  .top-cate-img-block img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
    display: block;
  }
  .top-cate-btn-text-block {
    position: absolute;
    width: 100%;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    text-align: center;
    color: #FFF;
  }
  a.top-img-link-btn {
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    max-width: 160px;
    height: 30px;
    background: -webkit-gradient(linear, left top, left bottom, from(#003663), color-stop(#58799c), to(#003663));
    background: linear-gradient(to bottom, #003663, #58799c, #003663);
    border: 1px solid #FFF;
    font-family: "Cormorant", serif;
    letter-spacing: 2px;
    font-size: 1.6rem;
    gap: 5px;
  }
  a.top-img-link-btn img {
    width: 10px;
    height: auto;
  }
  a.top-img-link-btn:link, a.top-img-link-btn:visited, a.top-img-link-btn:hover, a.top-img-link-btnactive {
    color: #FFF;
  }
  .bg-gra-btn-block {
    margin: 0;
    padding: 0 0 4em;
    background: -webkit-gradient(linear, left top, left bottom, from(#b2cae3), to(#ffffff));
    background: linear-gradient(to bottom, #b2cae3, #ffffff);
    color: #333;
    text-align: center;
  }
  .top-cate-text-block {
    padding: 2em;
  }
  .top-read-m {
    margin-bottom: 6px;
    font-family: "Noto Serif JP", serif;
    font-size: 1.4rem;
    line-height: 1.6;
    font-weight: 500;
  }
  .top-cate-btn-block {
    margin: 2em 1em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2em;
  }
  .top-cate-btn-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1em;
  }
  .top-cate-img-box {
    width: 100%;
    aspect-ratio: 1/1;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  .top-cate-img-box img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
    display: block;
  }
  .btn-img-caption {
    padding: 5px 10px;
    position: absolute;
    left: auto;
    right: 0;
    bottom: 0;
    color: #FFF;
    font-family: "Noto Serif JP", serif;
    font-size: 1rem;
  }
  /*サブリンクボタン*/
  .top-cate-sub-btn-box {
    margin: 2em 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  a.top-cate-sub-img-box {
    width: 50%;
    aspect-ratio: 1/1;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  a.top-cate-sub-img-box img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
    display: block;
  }
  a.top-cate-sub-img-box:link, a.top-cate-sub-img-box:visited, a.top-cate-sub-img-box:hover, a.top-cate-sub-img-boxactive {
    color: #FFF;
  }
  a.top-cate-sub-img-box .top-text-mi-en {
    font-size: 2.4rem;
  }
  a.top-cate-sub-img-box .top-text-mi-en small {
    display: block;
    font-size: 1.4rem;
  }
  .top-info-block {
    width: 100%;
    max-width: 350px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    border: 1px solid #003663;
    background-color: #FFF;
  }
  .top-info-title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    height: 36px;
    font-family: "Cormorant", serif;
    font-size: 1.5rem;
    color: #003663;
    line-height: 1.2;
    border-bottom: 1px solid #003663;
  }
  /*■■■■■■ ベクター調整 ■■■■■■■*/
  .background-decoration {
    width: 100%;
    height: atuo;
    overflow: hidden;
    position: relative;
  }
  .background-decoration svg {
    width: 100%;
    height: 100%;
    display: block;
  }
  .flag-wave-top {
    position: relative;
    z-index: 0;
  }
  .flag-wave-top svg {
    position: absolute;
    top: -1px;
  }
  /*■■■■■■ ベクター調整 ■■■■■■■*/
  .background-decoration {
    width: 100%;
    height: 24vw;
    overflow: hidden;
    position: relative;
  }
  .background-decoration svg {
    width: 100%;
    height: auto;
    display: block;
  }
  .radius-top {
    position: relative;
    z-index: 0;
  }
  .radius-top svg {
    position: absolute;
    top: -1px;
  }
} /*xs*/
/*------------(SM)------------*/
@media (min-width: 768px) and (max-width: 1023px) {
  .fv-movie-wrap {
    margin: 0;
    aspect-ratio: 16/9;
  }
  .fv-movie-wrap video.pc-view {
    display: block;
  }
  .fv-movie-wrap video.sp-view {
    display: none;
  }
  /*■■■■■■　#0 伏見稲荷　FLAG　俯瞰　■■■■■■■*/
  .top-fv {
    margin: 0;
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  .top-fv img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
    display: block;
  }
  .top-fv img.sp-view {
    display: none;
  }
  .swipe-guide {
    display: none;
  }
  /*タイトル*/
  .top-title {
    padding: 0 0 0 2.4rem;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    line-height: 1.6;
    letter-spacing: 4px;
    text-align: center;
    font-weight: 500;
    color: #FFF;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    position: absolute;
    z-index: 2;
    top: 10%;
    left: 0;
    -webkit-transform: translateX(0);
            transform: translateX(0);
    display: block;
    width: 100%;
    text-shadow: 0 0 6px #2b7cdd, 0 0 12px #2b7cdd, 0 0 18px #2b7cdd, 0 0 24px #2b7cdd;
  }
  .top-img-caption {
    padding: 5px 10px;
    font-family: "Noto Serif JP", serif;
    font-size: 1rem;
    color: #FFF;
    position: absolute;
    right: 0;
    bottom: 0;
    text-shadow: 0 0 1px #000, 0 0 3px #000, 0 0 5px #000, 0 0 7px #000;
  }
  /*■■■■■■　#1 ウェルカム(SM)　■■■■■■■*/
  .bg-top-flag {
    padding: 4em 0 10em;
    background: -webkit-gradient(linear, left bottom, left top, from(#003663), to(#58799c));
    background: linear-gradient(to top, #003663, #58799c);
    background: url(../images/top/bg-flag-drape_pc.webp) bottom center no-repeat;
    background-size: auto 100%;
    color: #FFF;
  }
  .top-data-block {
    margin: 2em 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .top-text-mi-en {
    margin-bottom: 20px;
    font-family: "Cormorant", serif;
    font-size: 4rem;
    line-height: 1.2;
    font-weight: 300;
  }
  .top-text-mi-en strong {
    font-size: 6.2rem;
    line-height: 1;
    font-weight: 200;
  }
  .top-point-box {
    margin: 0;
    border: 0;
    border-bottom: 1px solid #FFF;
    padding: 20px 0 25px;
    width: 100%;
    max-width: 390px;
  }
  .top-point-box:first-child {
    border-left: 0;
    border-top: 1px solid #FFF;
  }
  /*■　リンクボタン　■*/
  .top-btn-box {
    margin: 180px 0 40px;
  }
  a.link-btn-gra {
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 5px;
    width: 320px;
    height: 52px;
    border-radius: 26px;
    background: -webkit-gradient(linear, left top, right top, from(#4d8cbe), to(#54b77f));
    background: linear-gradient(to right, #4d8cbe, #54b77f);
    color: #FFF;
    font-size: 1.5rem;
    font-weight: 500;
  }
  a.link-btn-gra:after {
    content: "";
    display: block;
    width: 26px;
    height: 16px;
    background: url(../images/top/btn-arrow.svg) center center no-repeat;
    background-size: cover;
  }
  a.link-btn-gra:link, a.link-btn-gra:visited, a.link-btn-gra:hover, a.link-btn-gra:active {
    color: #FFF;
  }
  .text-foot-note {
    margin: 0 auto;
    display: inline-block;
    font-size: 1rem;
    text-align: left;
  }
  /*■■■■■■　#2 伏見稲荷FLAGイメージ(SM)　■■■■■■■*/
  .apartment-img-block {
    margin-top: -10em;
    width: 100%;
    aspect-ratio: 3/4;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  .apartment-img-block img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
  }
  .apartment-sub-title {
    font-size: 1.8rem;
    bottom: 0;
    text-align: center;
    width: 100%;
    z-index: 10;
    opacity: 0;
    -webkit-animation: titleFade 2s ease forwards;
            animation: titleFade 2s ease forwards;
    -webkit-animation-delay: 11.5s;
            animation-delay: 11.5s;
  }
  .img-caption-bk {
    padding: 5px 10px;
    font-family: "Noto Serif JP", serif;
    font-size: 1rem;
    color: #333;
    position: absolute;
    right: 0;
    bottom: 20%;
    text-shadow: 0 0 1px #FFF, 0 0 3px #FFF, 0 0 5px #FFF, 0 0 7px #FFF;
  }
  .top-apartment-movie {
    padding: 0 0 150px;
    width: 100%;
    aspect-ratio: 6/5;
    position: relative;
    overflow: hidden;
    background: #FFF;
    margin: auto;
  }
  /*■■■■■■　#4 各カテゴリーへの　リンク(SM)　■■■■■■■*/
  .top-cate-img-block {
    margin: -1px 0 0;
    width: 100%;
    aspect-ratio: 1/1;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  .top-cate-img-block img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
    display: block;
  }
  .top-cate-btn-text-block {
    position: absolute;
    width: 100%;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    text-align: center;
    color: #FFF;
  }
  a.top-img-link-btn {
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    max-width: 160px;
    height: 30px;
    background: -webkit-gradient(linear, left top, left bottom, from(#003663), color-stop(#58799c), to(#003663));
    background: linear-gradient(to bottom, #003663, #58799c, #003663);
    border: 1px solid #FFF;
    font-family: "Cormorant", serif;
    letter-spacing: 2px;
    font-size: 1.6rem;
    gap: 5px;
  }
  a.top-img-link-btn img {
    width: 10px;
    height: auto;
  }
  a.top-img-link-btn:link, a.top-img-link-btn:visited, a.top-img-link-btn:hover, a.top-img-link-btnactive {
    color: #FFF;
  }
  .bg-gra-btn-block {
    margin: 0;
    padding: 0 0 4em;
    background: -webkit-gradient(linear, left top, left bottom, from(#b2cae3), to(#ffffff));
    background: linear-gradient(to bottom, #b2cae3, #ffffff);
    color: #333;
    text-align: center;
  }
  .top-cate-text-block {
    padding: 2em;
  }
  .top-read-m {
    margin-bottom: 6px;
    font-family: "Noto Serif JP", serif;
    font-size: 1.8rem;
    line-height: 1.6;
    font-weight: 500;
  }
  .top-cate-btn-block {
    margin: 2em 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2em;
  }
  .top-cate-btn-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1em;
  }
  .top-cate-img-box {
    width: 100%;
    aspect-ratio: 1/1;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  .top-cate-img-box img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
    display: block;
  }
  .btn-img-caption {
    padding: 5px 10px;
    position: absolute;
    left: auto;
    right: 0;
    right: auto;
    bottom: 0;
    color: #FFF;
    font-family: "Noto Serif JP", serif;
    font-size: 1rem;
  }
  /*サブリンクボタン*/
  .top-cate-sub-btn-box {
    margin: 2em 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  a.top-cate-sub-img-box {
    width: 50%;
    aspect-ratio: 1/1;
    overflow: hidden;
    background: #eee;
    position: relative;
  }
  a.top-cate-sub-img-box img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
    display: block;
  }
  a.top-cate-sub-img-box:link, a.top-cate-sub-img-box:visited, a.top-cate-sub-img-box:hover, a.top-cate-sub-img-boxactive {
    color: #FFF;
  }
  a.top-cate-sub-img-box .top-text-mi-en {
    font-size: 2.4rem;
  }
  a.top-cate-sub-img-box .top-text-mi-en small {
    display: block;
    font-size: 1.4rem;
  }
  .top-info-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 10px;
    border: 1px solid #003663;
    background-color: #FFF;
  }
  .top-info-title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    height: 36px;
    font-family: "Cormorant", serif;
    font-size: 1.5rem;
    color: #003663;
    line-height: 1.2;
    border-bottom: 1px solid #003663;
  }
  /*■■■■■■ ベクター調整 ■■■■■■■*/
  .background-decoration {
    width: 100%;
    height: atuo;
    overflow: hidden;
    position: relative;
  }
  .background-decoration svg {
    width: 100%;
    height: 100%;
    display: block;
  }
  .flag-wave-top {
    position: relative;
    z-index: 0;
  }
  .flag-wave-top svg {
    position: absolute;
    top: -1px;
  }
  /*■■■■■■ ベクター調整 ■■■■■■■*/
  .background-decoration {
    width: 100%;
    height: 24vw;
    overflow: hidden;
    position: relative;
  }
  .background-decoration svg {
    width: 100%;
    height: auto;
    display: block;
  }
  .radius-top {
    position: relative;
    z-index: 0;
  }
  .radius-top svg {
    position: absolute;
    top: -1px;
  }
  /*■　#5 FLAG　エントリー　■*/
  .entry-block {
    padding: 0 0 3em;
    background: linear-gradient(20deg, #b2c9e2 -10%, #dbe3ee 100%);
  }
  .entry-img-title {
    display: block;
  }
  .entry-img-title img {
    margin: 2em auto 5px;
    width: 270px;
    height: auto;
  }
  .entry-text-mi {
    margin-bottom: 20px;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    line-height: 1.4;
    font-weight: 500;
    color: #003663;
  }
  a.entry-link-btn {
    margin: 2em auto;
    display: block;
    padding: 5px;
    max-width: 370px;
    height: 70px;
    color: #FFF;
    background: -webkit-gradient(linear, left top, right top, from(#0c6593), to(#003663));
    background: linear-gradient(to right, #0c6593, #003663);
    font-family: "Noto Serif JP", serif;
    font-size: 1.8rem;
    line-height: 1.2;
  }
  a.entry-link-btn span {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 10px;
    width: 100%;
    height: 100%;
    border: 1px solid #FFF;
  }
  a.entry-link-btn span img {
    width: 17px;
    height: auto;
  }
  a.entry-link-btn:link, a.entry-link-btn:visited, a.entry-link-btn:hover, a.entry-link-btnactive {
    color: #FFF;
  }
  .entry-text-read {
    font-family: "Noto Serif JP", serif;
    font-size: 1.4rem;
    line-height: 1.6;
    color: #003663;
  }
} /*SM*/
/*------------(MD)------------*/
/*------------(LG)------------*/
/*------------(XL)------------*/
/*------------(XXL)------------*/
/*(XXL)*/