@charset "UTF-8";
/*========================================


	*スタイルリセット（sanitize.css）


========================================*/
/*! sanitize.css | CC0 Public Domain | github.com/jonathantneal/sanitize.css */
/*
 * Normalization
 */
:root {
  -ms-overflow-style: -ms-autohiding-scrollbar;
  overflow-y: scroll;
  text-size-adjust: 100%; }

audio:not([controls]) {
  display: none; }

details {
  display: block; }

input[type="number"] {
  width: auto; }
input[type="search"] {
  -webkit-appearance: textfield; }
  input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none; }

main {
  display: block; }

summary {
  display: block; }

pre {
  overflow: auto; }

progress {
  display: inline-block; }

small {
  font-size: 75%; }

template {
  display: none; }

textarea {
  overflow: auto; }

[hidden] {
  display: none; }

[unselectable] {
  user-select: none; }

/*
 * Universal inheritance
 */
*,
::before,
::after {
  box-sizing: inherit; }

* {
  font-size: inherit;
  line-height: inherit; }

::before,
::after {
  text-decoration: inherit;
  vertical-align: inherit; }

/*
 * Opinionated defaults
 */
*,
::before,
::after {
  border-style: solid;
  border-width: 0; }

* {
  margin: 0;
  padding: 0; }

:root {
  box-sizing: border-box;
  cursor: default;
  font: 14px/1 sans-serif; }

html {
  background-color: #FFFFFF; }

a {
  text-decoration: none; }

img {
  border: none; }

audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle; }

button,
input,
select,
textarea {
  background-color: transparent; }

button,
input,
select,
textarea {
  color: inherit;
  font-family: inherit;
  font-style: inherit;
  font-weight: inherit;
  -moz-appearance: none;
  -webkit-appearance: none;
  -webkit-border-radius: 0;
  border-radius: 0; }

button,
[type="button"],
[type="date"],
[type="datetime"],
[type="datetime-local"],
[type="email"],
[type="month"],
[type="number"],
[type="password"],
[type="reset"],
[type="search"],
[type="submit"],
[type="tel"],
[type="text"],
[type="time"],
[type="url"],
[type="week"],
select,
textarea {
  min-height: 1em; }

code,
kbd,
pre,
samp {
  font-family: monospace, monospace; }

ol,
ul {
  list-style: none; }

select {
  -moz-appearance: none;
  -webkit-appearance: none; }
  select::-ms-expand {
    display: none; }
  select::-ms-value {
    color: currentColor; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

textarea {
  resize: vertical; }

::selection {
  background-color: #B3D4FC;
  text-shadow: none; }

@media screen {
  [hidden~="screen"] {
    display: inherit; }

  [hidden~="screen"]:not(:active):not(:focus):not(:target) {
    clip: rect(0 0 0 0) !important;
    position: absolute !important; } }
html {
  position: relative; }
  html::before {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100vw;
    height: 100dvh;
    background: url("../img/bg-sp.png") center/cover no-repeat;
    content: ''; }

@media screen and (min-width: 769px) {
  html::before {
    background-image: url("../img/bg-pc.png"); } }
body {
  color: #000000;
  font-family: "Shippori Mincho", serif;
  line-height: 1.5;
  letter-spacing: 0;
  overflow: hidden; }
  body img {
    display: block;
    width: 100%;
    vertical-align: middle; }
  body .br-pc {
    display: none; }

@media screen and (min-width: 769px) {
  body .br-sp {
    display: none; }
  body .br-pc {
    display: initial; } }
.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  width: 100%;
  height: 85px;
  display: flex;
  align-items: flex-start; }
  .header .header-logo {
    position: relative;
    display: block;
    align-self: center;
    width: 108px;
    aspect-ratio: 108/40;
    margin: 0 20px;
    box-sizing: border-box;
    filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.15)); }
    .header .header-logo a {
      display: block;
      position: relative; }
      .header .header-logo a::before, .header .header-logo a::after {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        transition: .3s;
        content: ''; }
      .header .header-logo a::before {
        z-index: 2;
        background: url("../img/logo.svg") center/cover no-repeat; }
      .header .header-logo a::after {
        z-index: 1;
        opacity: 0;
        background: url("../img/logo-blk.svg") center/cover no-repeat; }
    .header .header-logo img {
      opacity: 0; }
  .header .header-reserve {
    display: block;
    margin: 12px 0 12px auto;
    padding: 12px 20px;
    background: linear-gradient(135deg, #FFECBF, #C99B34);
    box-sizing: border-box;
    color: #000000;
    font-weight: 600;
    font-size: clamp(16px, 1.8vw, 18px);
    line-height: 1;
    letter-spacing: .1em;
    text-align: center; }
  .header .header-menu {
    position: relative;
    z-index: 2; }
    .header .header-menu .menu-btn {
      position: relative;
      z-index: 2;
      display: grid;
      place-content: center;
      gap: 6px;
      width: 56px;
      aspect-ratio: 1;
      margin-left: 12px;
      background: #000000; }
      .header .header-menu .menu-btn .btn-line {
        position: relative;
        width: 33px;
        height: 6px; }
        .header .header-menu .menu-btn .btn-line::before, .header .header-menu .menu-btn .btn-line::after {
          position: absolute;
          left: 50%;
          transform: translate(-50%, 0);
          display: block;
          width: 100%;
          height: 1px;
          background: #FFF;
          transition: .3s;
          content: ''; }
        .header .header-menu .menu-btn .btn-line::before {
          top: 0;
          transform: translate(-50%, -50%); }
        .header .header-menu .menu-btn .btn-line::after {
          bottom: 0;
          transform: translate(-50%, 50%); }
      .header .header-menu .menu-btn .btn-txt {
        color: #FFF;
        font-family: "Cormorant Garamond", serif;
        font-weight: 600;
        font-size: 11px;
        letter-spacing: .05em;
        line-height: 1;
        transition: .3s;
        text-align: center; }
    .header .header-menu .menu-nav {
      display: none;
      position: absolute;
      top: 0;
      right: 0;
      width: 100vw;
      height: 100%;
      min-height: 100dvh;
      background: rgba(255, 255, 255, 0.95);
      padding: 120px 20px 60px;
      overflow-y: scroll; }
      .header .header-menu .menu-nav .nav-logo {
        position: absolute;
        top: 0;
        left: 0;
        display: flex;
        align-items: center;
        width: clamp(108px, 13vw, 130px);
        height: 85px;
        margin: 0 20px;
        box-sizing: border-box; }
      .header .header-menu .menu-nav .nav-list {
        display: grid;
        gap: 25px; }
        .header .header-menu .menu-nav .nav-list .item-link {
          display: block;
          width: 100%;
          padding: 0 15px 15px;
          border-bottom: 1px solid #727272;
          box-sizing: border-box;
          color: #000000;
          font-weight: 600;
          font-size: 18px;
          letter-spacing: .1em;
          line-height: 1.5;
          text-align: center; }
      .header .header-menu .menu-nav .nav-reserve {
        display: block;
        width: 80%;
        margin: 30px auto 0;
        padding: 20px;
        background: linear-gradient(135deg, #FFECBF, #C99B34);
        box-sizing: border-box;
        color: #000000;
        font-weight: 600;
        font-size: 18px;
        letter-spacing: .1em;
        line-height: 1.5;
        text-align: center; }
  .header.active .header-menu .menu-btn .btn-line::before {
    top: 50%;
    transform: translate(-50%, -50%) rotate(30deg); }
  .header.active .header-menu .menu-btn .btn-line::after {
    bottom: 50%;
    transform: translate(-50%, 50%) rotate(-30deg); }
  .header.active .header-menu .menu-btn .btn-txt {
    display: none; }
  .header.is-scrolled {
    height: 56px;
    background: #FFF;
    animation: headerFixed .8s ease 0s 1 alternate; }
    .header.is-scrolled .header-logo {
      width: 85px;
      filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.5)); }
      .header.is-scrolled .header-logo a::before {
        opacity: 0; }
      .header.is-scrolled .header-logo a::after {
        opacity: 1; }
    .header.is-scrolled .header-reserve {
      margin: auto 0 auto auto; }
  .header .header,
  .header .header-logo,
  .header .header-menu,
  .header .nav-list .item-link,
  .header .nav-reserve {
    transition: .3s ease-in-out; }

@keyframes headerFixed {
  0% {
    transform: translateY(-100%);
    opacity: 0; }
  100% {
    transform: translateY(0);
    opacity: 1; } }
@media screen and (min-width: 961px) {
  .header {
    justify-content: space-between;
    gap: 20px;
    height: 130px;
    padding: 0 50px; }
    .header .header-logo {
      width: 130px;
      margin: 0; }
    .header .header-reserve {
      display: none; }
    .header .header-menu .menu-btn {
      display: none; }
    .header .header-menu .menu-nav {
      display: flex !important;
      align-items: center;
      justify-content: flex-end;
      position: initial;
      width: 100%;
      min-height: 100%;
      margin-top: 30px;
      background: none;
      padding: 0;
      overflow-y: visible; }
      .header .header-menu .menu-nav .nav-logo {
        display: none; }
      .header .header-menu .menu-nav .nav-list {
        display: flex;
        align-items: center;
        gap: 35px; }
        .header .header-menu .menu-nav .nav-list .item-link {
          padding: 0;
          border-bottom: none;
          font-size: 14px;
          color: #FFF; }
      .header .header-menu .menu-nav .nav-reserve {
        width: auto;
        margin: 0 0 0 45px;
        padding: 20px 60px;
        box-sizing: border-box; }
    .header.is-scrolled {
      height: 75px;
      padding-right: 0; }
      .header.is-scrolled .header-logo {
        width: 103px; }
      .header.is-scrolled .header-menu {
        height: 100%; }
        .header.is-scrolled .header-menu .menu-nav {
          margin-top: 0; }
          .header.is-scrolled .header-menu .menu-nav .nav-list .item-link {
            color: #000000; }
          .header.is-scrolled .header-menu .menu-nav .nav-reserve {
            display: grid;
            place-content: center;
            padding: 24px 60px; } }
.inner {
  width: 89.33%;
  margin: 0 auto; }

.sec-title {
  text-align: center; }
  .sec-title .title-en {
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
    padding: 0 clamp(22px, 5vw, 30px);
    border-right: 2px solid #CC0F13;
    border-left: 2px solid #CC0F13;
    font-family: "Cormorant Garamond", serif;
    font-weight: 500;
    font-size: clamp(34px, 5vw, 50px);
    letter-spacing: .05em;
    line-height: 1; }
  .sec-title .title-jp {
    margin-top: clamp(5px, 1vw, 10px);
    color: #727272;
    font-size: 14px; }

.sec-subttl {
  position: relative;
  padding-bottom: 10px;
  font-size: 16px;
  letter-spacing: .2em;
  line-height: 1.5; }
  .sec-subttl::after {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: linear-gradient(to right, #CC0F13 0, #CC0F13 84px, #D6D6D6 84px);
    content: ''; }

.mv {
  position: relative; }
  .mv .mv-badge {
    position: absolute;
    bottom: 6.3%;
    right: 5.33%;
    width: 42.133%; }
  .mv .mv-down {
    position: absolute;
    top: calc(100% - 35px);
    left: 50%;
    transform: translate(-50%, 0);
    padding-bottom: 40px;
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    font-size: 1.4rem;
    letter-spacing: .05em;
    line-height: 1;
    text-align: center; }
    .mv .mv-down .down-bar {
      width: 1px;
      height: 32px;
      background: rgba(255, 255, 255, 0.36);
      position: absolute;
      left: 50%;
      bottom: 0;
      transform: translate(-50%, 0);
      overflow: hidden; }
      .mv .mv-down .down-bar::after {
        content: "";
        width: 100%;
        height: 10px;
        background: #000;
        position: absolute;
        top: 0;
        left: 0;
        animation: scrollLine 2s linear infinite; }

@keyframes scrollLine {
  0% {
    top: 0%;
    opacity: 0; }
  15% {
    opacity: 1; }
  50% {
    opacity: 1; }
  90% {
    opacity: 1; }
  100% {
    top: 100%;
    opacity: 0; } }
@media screen and (min-width: 768px) {
  .mv .mv-badge {
    bottom: 3.9%;
    right: 3.66%;
    width: 20.35%; }
  .mv .mv-down {
    color: #727272; } }
@media screen and (min-width: 961px) {
  .mv .mv-down {
    top: calc(100% - clamp(30px,4vw,50px));
    padding-bottom: 80px; }
    .mv .mv-down .down-bar {
      height: 68px; }
      .mv .mv-down .down-bar::after {
        height: 20px; } }
.brand {
  margin-top: clamp(60px, 9vw, 90px); }
  .brand .brand-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: clamp(25px, 5vw, 50px) 0;
    margin-top: clamp(35px, 6.5vw, 65px);
    padding: 0 15px; }
    .brand .brand-list .list-item {
      mix-blend-mode: multiply; }
      .brand .brand-list .list-item:nth-of-type(1) {
        width: 30.8%; }
      .brand .brand-list .list-item:nth-of-type(2) {
        width: 26.8%; }
      .brand .brand-list .list-item:nth-of-type(3) {
        width: 27.6%; }
      .brand .brand-list .list-item:nth-of-type(4) {
        width: 26.3%; }
      .brand .brand-list .list-item:nth-of-type(5) {
        width: 26.3%; }
      .brand .brand-list .list-item:nth-of-type(6) {
        width: 36.7%; }
      .brand .brand-list .list-item:nth-of-type(7) {
        width: 27.2%; }
      .brand .brand-list .list-item:nth-of-type(8) {
        width: 25%; }
      .brand .brand-list .list-item:nth-of-type(9) {
        width: 28.5%; }

@media screen and (min-width: 961px) {
  .brand .inner {
    max-width: 960px; }
  .brand .brand-list {
    justify-content: center; }
    .brand .brand-list .list-item:nth-of-type(1) {
      width: 19.375%;
      margin-right: 7.7%; }
    .brand .brand-list .list-item:nth-of-type(2) {
      width: 16.6%;
      margin-right: 7.7%; }
    .brand .brand-list .list-item:nth-of-type(3) {
      width: 17%;
      margin-right: 7.7%; }
    .brand .brand-list .list-item:nth-of-type(4) {
      width: 11.56%; }
    .brand .brand-list .list-item:nth-of-type(5) {
      width: 16.4%;
      margin-right: 6.25%; }
    .brand .brand-list .list-item:nth-of-type(6) {
      width: 18.3%;
      margin-right: 6.25%; }
    .brand .brand-list .list-item:nth-of-type(7) {
      width: 12.5%;
      margin-right: 6.25%; }
    .brand .brand-list .list-item:nth-of-type(8) {
      width: 13.5%;
      margin-right: 6.25%; }
    .brand .brand-list .list-item:nth-of-type(9) {
      width: 14.2%; } }
.floor {
  margin-top: clamp(70px, 16vw, 160px); }
  .floor .inner {
    max-width: 960px; }
  .floor .floor-wrap {
    display: flex;
    flex-direction: column;
    margin-top: clamp(35px, 4.5vw, 45px); }
    .floor .floor-wrap .floor-cont {
      display: contents; }
      .floor .floor-wrap .floor-cont > * {
        margin: 0 15px; }
      .floor .floor-wrap .floor-cont .cont-subttl {
        margin-top: 25px;
        font-weight: 600;
        font-size: 20px;
        line-height: 1.5; }
      .floor .floor-wrap .floor-cont .cont-txt {
        margin-top: 15px;
        color: #727272;
        font-weight: 600;
        font-size: 13px;
        left: 1.77; }
      .floor .floor-wrap .floor-cont .cont-link {
        display: flex;
        align-items: center;
        gap: 8px;
        padding-right: 6px;
        margin: 25px 0 0 auto;
        color: #000000;
        font-size: 16px;
        line-height: 1;
        text-decoration: underline; }
        .floor .floor-wrap .floor-cont .cont-link::after {
          display: block;
          width: 6px;
          aspect-ratio: 1;
          transform: translate(-50%, -25%) rotate(45deg);
          border-bottom: 1px solid;
          border-right: 1px solid;
          content: ''; }
      .floor .floor-wrap .floor-cont .cont-bland {
        order: 3;
        display: grid;
        grid-template-columns: 122fr 152fr;
        gap: 15px 20px;
        margin: clamp(20px, 3vw, 30px) 0 0;
        padding: 25px 20px 25px 25px;
        background: #F5F4EE; }
        .floor .floor-wrap .floor-cont .cont-bland .bland-txt {
          font-weight: 600;
          font-size: 15px;
          line-height: 1.5; }
          .floor .floor-wrap .floor-cont .cont-bland .bland-txt .num {
            color: #CC0F13; }
    .floor .floor-wrap .floor-map {
      order: 2;
      margin-top: 20px; }

@media screen and (min-width: 760px) {
  .floor .floor-wrap .floor-cont .cont-bland {
    grid-template-columns: 94fr  117fr 112fr; } }
@media screen and (min-width: 961px) {
  .floor .floor-wrap {
    display: grid;
    grid-template-columns: 403fr 495fr;
    gap: 6.45%;
    flex-direction: row; }
    .floor .floor-wrap .floor-cont {
      display: block; }
      .floor .floor-wrap .floor-cont > * {
        margin: 0; }
      .floor .floor-wrap .floor-cont .cont-link {
        margin-left: 0; }
    .floor .floor-wrap .floor-map {
      order: 2;
      margin-top: 0; } }
.special {
  background: url("../img/special-bg-sp.jpg") center/cover no-repeat;
  margin-top: clamp(90px, 10vw, 100px);
  padding: clamp(50px, 70vw, 70px) 0 clamp(45px, 9.5vw, 95px); }
  .special .inner {
    max-width: 1110px; }
  .special .sec-title {
    color: #FFF; }
    .special .sec-title .title-jp {
      color: #FFF; }
  .special .special-list {
    display: grid;
    gap: clamp(10px, 1.5vw, 15px);
    margin-top: clamp(30px, 5vw, 50px); }
    .special .special-list .list-item {
      position: relative;
      background: #FFF;
      padding: 20px;
      box-sizing: border-box;
      text-align: center; }
      .special .special-list .list-item .item-num {
        position: absolute;
        top: 0;
        left: 0;
        display: grid;
        place-content: center;
        width: clamp(28px, 3.4vw, 34px);
        aspect-ratio: 1;
        background: #CC0F13;
        color: #FFF;
        font-size: clamp(16px, 2vw, 20px);
        letter-spacing: .05em;
        line-height: 1; }
      .special .special-list .list-item .item-ttl {
        font-size: 16px;
        letter-spacing: .04em;
        line-height: 2;
        text-align: center; }
        .special .special-list .list-item .item-ttl .ttl-s {
          font-size: clamp(13px, 1.4vw, 14px);
          line-height: 1; }
        .special .special-list .list-item .item-ttl .ttl-l {
          font-size: clamp(22px, 2.4vw, 24px);
          line-height: 1; }
        .special .special-list .list-item .item-ttl .ttl-red {
          color: #CC0F13; }
      .special .special-list .list-item .item-cap {
        font-weight: 400;
        font-size: 12px;
        line-height: 1.5; }
  .special .special-bnr {
    display: block;
    max-width: 680px;
    margin: clamp(30px, 4vw, 40px) auto 0; }

@media screen and (min-width: 768px) {
  .special {
    background: url("../img/special-bg-pc.jpg") center/cover no-repeat; }
    .special .special-list {
      display: grid;
      grid-template-columns: 1fr 1fr; }
      .special .special-list .list-item {
        display: grid;
        place-content: center; }
        .special .special-list .list-item::after {
          position: absolute;
          bottom: 0;
          right: 0;
          width: 25px;
          aspect-ratio: 1;
          border-bottom: 3px solid #CC0F13;
          border-right: 3px solid #CC0F13;
          box-sizing: border-box;
          content: ''; } }
@media screen and (min-width: 1111px) {
  .special .special-list {
    grid-template-columns: 1fr 1fr 1fr; } }
.reserve {
  padding: clamp(80px, 15vw, 150px) 0 clamp(65px, 15vw, 150px); }
  .reserve .inner {
    max-width: 1050px; }
  .reserve .reserve-cont {
    padding: clamp(40px, 5vw, 50px) 15px clamp(50px, 8vw, 80px);
    border-top: clamp(3px, 0.4vw, 4px) solid #AC9142;
    border-bottom: clamp(3px, 0.4vw, 4px) solid #AC9142;
    box-sizing: border-box;
    background: #FFF; }
    .reserve .reserve-cont .cont-ttl {
      position: relative;
      width: -moz-fit-content;
      width: fit-content;
      margin: 0 auto;
      font-size: clamp(19px, 2.4vw, 24px);
      letter-spacing: 0.05em;
      line-height: 1.5;
      text-align: center; }
      .reserve .reserve-cont .cont-ttl .red {
        color: #CC0F13; }
      .reserve .reserve-cont .cont-ttl::before, .reserve .reserve-cont .cont-ttl::after {
        position: absolute;
        top: 50%;
        width: clamp(37px, 25.2vw, 52px);
        aspect-ratio: 37/14;
        content: ''; }
      .reserve .reserve-cont .cont-ttl::before {
        left: clamp(-26px, -2.6vw, 7px);
        transform: translate(-100%, -50%);
        background: url("../img/reserve-deco-left.svg") center/cover no-repeat; }
      .reserve .reserve-cont .cont-ttl::after {
        right: clamp(-26px, -2.6vw, 7px);
        transform: translate(100%, -50%);
        background: url("../img/reserve-deco-right.svg") center/cover no-repeat; }
    .reserve .reserve-cont .cont-btn {
      position: relative;
      z-index: 2;
      display: block;
      width: 100%;
      max-width: 620px;
      margin: clamp(15px, 4vw, 4px) auto 0;
      padding: clamp(20px, 4vw, 40px);
      font-weight: 600;
      font-size: clamp(24px, 3vw, 30px);
      color: #000000;
      line-height: 1.375;
      letter-spacing: .05em;
      text-align: center;
      transition: .3s; }
      .reserve .reserve-cont .cont-btn::before, .reserve .reserve-cont .cont-btn::after {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: #D8D8D8;
        transition: .3s;
        content: ''; }
      .reserve .reserve-cont .cont-btn::before {
        z-index: -1;
        background: linear-gradient(135deg, #FFECBF, #C99B34); }
      .reserve .reserve-cont .cont-btn::after {
        z-index: -2;
        transform: translateY(5px);
        background: #D8D8D8; }
      .reserve .reserve-cont .cont-btn:hover {
        transform: translateY(5px); }
        .reserve .reserve-cont .cont-btn:hover::before {
          transform: translateY(0px); }
        .reserve .reserve-cont .cont-btn:hover::after {
          transform: translateY(0px); }

@media screen and (min-width: 768px) {
  .reserve .reserve-cont {
    border: clamp(3px, 0.4vw, 4px) solid #AC9142; } }
.about .about-ttl {
  color: #CC0F13;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(44px, 10vw, 120px);
  letter-spacing: .05em;
  font-weight: 500;
  line-height: 1;
  text-align: center; }
.about .about-link {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 15px 10px;
  margin-top: clamp(20px, 3.5vw, 35px); }
  .about .about-link .link-item {
    mix-blend-mode: multiply; }
    .about .about-link .link-item:nth-of-type(1) {
      width: 22.68%; }
    .about .about-link .link-item:nth-of-type(2) {
      width: 18.5%;
      margin: 0 10px; }
    .about .about-link .link-item:nth-of-type(3) {
      width: 18.5%; }
    .about .about-link .link-item:nth-of-type(4) {
      width: 13.43%;
      margin-left: 15px; }
    .about .about-link .link-item:nth-of-type(5) {
      width: 18.34%; }
    .about .about-link .link-item:nth-of-type(6) {
      width: 18.5%; }
    .about .about-link .link-item:nth-of-type(7) {
      width: 15%; }
    .about .about-link .link-item:nth-of-type(8) {
      width: 15.8%;
      margin-left: 15px; }
    .about .about-link .link-item:nth-of-type(9) {
      width: 15.8%; }
.about .about-list {
  display: grid;
  gap: clamp(36px, 6vw, 57px);
  margin-top: clamp(40px, 6vw, 60px); }
  .about .about-list .list-item {
    width: 100%;
    border-top: 8px solid #AC9142;
    padding: clamp(50px, 8vw, 80px) clamp(20px, 5vw, 78px);
    box-sizing: border-box;
    background: #F5F4EF; }
    .about .about-list .list-item .item-ttl {
      margin-bottom: 25px;
      font-weight: 400;
      font-size: clamp(22px, 2.8vw, 28px);
      line-height: 1.5;
      text-align: center; }
    .about .about-list .list-item .item-logo {
      margin: 0 auto;
      mix-blend-mode: multiply; }
    .about .about-list .list-item .item-txt {
      margin-top: 25px;
      font-weight: 400;
      font-size: clamp(16px, 1.8vw, 18px);
      line-height: 1.44; }
    .about .about-list .list-item .item-country {
      display: flex;
      justify-content: flex-end;
      align-items: center;
      gap: 14px;
      margin-top: 20px; }
      .about .about-list .list-item .item-country .country-img {
        width: clamp(52px, 10vw, 100px);
        filter: drop-shadow(0 3px 10px rgba(0, 0, 0, 0.27)); }
      .about .about-list .list-item .item-country .country-txt {
        font-weight: 600;
        font-size: clamp(13px, 1.6vw, 16px); }
    .about .about-list .list-item .item-design {
      margin-top: 40px; }
    .about .about-list .list-item .col-2 {
      display: grid;
      grid-template-columns: 1fr;
      gap: clamp(16px, 4.8vw, 48px); }
      .about .about-list .list-item .col-2 + .col-4 {
        margin-top: clamp(16px, 2.4vw, 24px); }
    .about .about-list .list-item .col-4 {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: clamp(21px, 3.7vw, 37px); }
    .about .about-list .list-item:nth-of-type(1) .item-logo {
      width: 73%;
      max-width: 348px; }
    .about .about-list .list-item:nth-of-type(2) .item-logo {
      width: 49.55%;
      max-width: 290px; }
    .about .about-list .list-item:nth-of-type(3) .item-logo {
      width: 55.8%;
      max-width: 360px; }
    .about .about-list .list-item:nth-of-type(4) .item-logo {
      width: 38%;
      max-width: 180px; }
    .about .about-list .list-item:nth-of-type(5) .item-logo {
      width: 53.73%;
      max-width: 270px; }
    .about .about-list .list-item:nth-of-type(6) .item-logo {
      width: 76.7%;
      max-width: 350px; }
    .about .about-list .list-item:nth-of-type(7) .item-logo {
      width: 56.7%;
      max-width: 240px; }
    .about .about-list .list-item:nth-of-type(8) .item-logo {
      width: 65.67%;
      max-width: 290px; }
    .about .about-list .list-item:nth-of-type(9) .item-logo {
      width: 60%;
      max-width: 260px; }
.about .about-cap {
  margin-top: clamp(40px, 7vw, 70px);
  font-size: clamp(11px, 1.5vw, 15px); }
.about + .reserve {
  padding: clamp(60px, 11vw, 110px) 0 clamp(90px, 12vw, 120px); }

@media screen and (min-width: 768px) {
  .about .about-list .list-item .col-2 {
    grid-template-columns: 1fr 1fr; }
  .about .about-list .list-item .col-4 {
    grid-template-columns: 1fr 1fr 1fr 1fr; } }
@media screen and (min-width: 961px) {
  .about .about-inner, .about .inner {
    max-width: 1266px;
    margin: 0 auto; }
  .about .about-link {
    justify-content: space-between;
    gap: 0;
    padding: 0 2%; }
    .about .about-link .link-item {
      margin-left: 0 !important; }
      .about .about-link .link-item:nth-of-type(1) {
        width: 9.16%; }
      .about .about-link .link-item:nth-of-type(2) {
        width: 7.9%; }
      .about .about-link .link-item:nth-of-type(3) {
        width: 8.13%; }
      .about .about-link .link-item:nth-of-type(4) {
        width: 5.6%; }
      .about .about-link .link-item:nth-of-type(5) {
        width: 7.1%; }
      .about .about-link .link-item:nth-of-type(6) {
        width: 8.6%; }
      .about .about-link .link-item:nth-of-type(7) {
        width: 6%; }
      .about .about-link .link-item:nth-of-type(8) {
        width: 6.4%; }
      .about .about-link .link-item:nth-of-type(9) {
        width: 6.7%; }
  .about .about-list .list-item {
    position: relative; }
    .about .about-list .list-item .item-txt {
      margin-top: 35px;
      line-height: 1.5;
      text-align: center; }
    .about .about-list .list-item .item-country {
      position: absolute;
      top: clamp(40px, 5vw, 60px);
      right: clamp(20px, 7.8vw, 78px);
      display: block; }
      .about .about-list .list-item .item-country .country-ttl {
        margin-top: 10px;
        text-align: center; }
    .about .about-list .list-item:nth-of-type(3), .about .about-list .list-item:nth-of-type(4), .about .about-list .list-item:nth-of-type(6), .about .about-list .list-item:nth-of-type(7), .about .about-list .list-item:nth-of-type(8), .about .about-list .list-item:nth-of-type(9) {
      padding-top: clamp(50px, 95vw, 95px); } }
.access .inner {
  max-width: 1110px; }
.access .access-ttl {
  margin-top: clamp(25px, 7vw, 70px);
  font-weight: 600;
  font-size: clamp(20px, 2.8vw, 28px);
  line-height: 1.5;
  text-align: center; }
.access .access-subttl {
  margin-top: 25px;
  color: #CC0F13;
  font-weight: 600;
  font-size: clamp(18px, 2.2vw, 22px);
  line-height: 1.66;
  text-align: center; }
.access .access-wrap {
  display: grid;
  gap: 45px;
  margin-top: clamp(25px, 5.5vw, 55px); }
  .access .access-wrap .wrap-cont {
    padding: 0 15px;
    box-sizing: border-box; }
    .access .access-wrap .wrap-cont .cont-item + .cont-item {
      margin-top: clamp(35px, 5.5vw, 55px); }
    .access .access-wrap .wrap-cont .sec-subttl {
      letter-spacing: 0; }
    .access .access-wrap .wrap-cont .item-txt {
      margin-top: clamp(18px, 2.2vw, 22px);
      font-size: clamp(16px, 2vw, 20px);
      line-height: 1.5; }
    .access .access-wrap .wrap-cont .item-link {
      display: block;
      margin-top: clamp(15px, 2.5vw, 25px);
      color: #000000;
      font-weight: 600;
      font-size: clamp(16px, 1.8vw, 18px);
      text-decoration: underline; }
    .access .access-wrap .wrap-cont .item-sta {
      margin-top: clamp(12px, 3.5vw, 35px);
      font-weight: 600;
      font-size: clamp(14px, 1.8vw, 20px);
      line-height: 1.6; }
      .access .access-wrap .wrap-cont .item-sta .red {
        color: #CC0F13; }
.access .access-map {
  width: 100%;
  aspect-ratio: 375/249;
  margin-top: clamp(30px, 12vw, 120px); }
  .access .access-map > * {
    width: 100%;
    height: 100%; }

@media screen and (min-width: 768px) {
  .access .access-wrap {
    grid-template-columns: 1fr 1fr; }
    .access .access-wrap .wrap-cont {
      padding: 0; }
    .access .access-wrap .wrap-img {
      order: 2; }
  .access .access-map {
    max-width: 1110px;
    aspect-ratio: 1110/439;
    margin-left: auto;
    margin-right: auto; } }
.company {
  margin-top: clamp(65px, 12vw, 120px);
  margin-bottom: clamp(80px, 124vw, 140px); }
  .company .inner {
    max-width: 1110px; }
  .company .company-wrap {
    display: grid;
    gap: clamp(30px, 6vw, 60px);
    margin-top: clamp(35px, 4.5vw, 45px); }
    .company .company-wrap .wrap-cont {
      padding: 0 15px;
      box-sizing: border-box; }
      .company .company-wrap .wrap-cont .sec-subttl {
        letter-spacing: 0; }
      .company .company-wrap .wrap-cont .cont-subttl {
        margin-top: clamp(25px, 4vw, 40px);
        font-weight: 600;
        font-size: clamp(22px, 2.4vw, 24px); }
      .company .company-wrap .wrap-cont .cont-list {
        margin-top: clamp(20px, 3vw, 30px);
        display: grid;
        gap: clamp(18px, 2.2vw, 22px); }
        .company .company-wrap .wrap-cont .cont-list .list-item {
          display: grid;
          grid-template-columns: 4em 1fr;
          gap: clamp(10px, 3vw, 30px);
          font-size: clamp(16px, 1.8vw, 18px);
          font-weight: 600;
          line-height: 1.45; }
          .company .company-wrap .wrap-cont .cont-list .list-item .item-ttl {
            color: #CC0F13; }
          .company .company-wrap .wrap-cont .cont-list .list-item a {
            color: #CC0F13;
            text-decoration: underline; }

@media screen and (min-width: 768px) {
  .company .company-wrap {
    grid-template-columns: 1fr 1fr; } }
.footer {
  padding: clamp(40px, 7vw, 70px) 0 clamp(10px, 3vw, 30px);
  background: #000000; }
  .footer .footer-logo {
    display: block;
    width: 140px;
    margin: 0 auto; }
  .footer .footer-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: clamp(20px, 3.5vw, 35px);
    margin-top: 3rem; }
    .footer .footer-list .list-item {
      color: #FFF;
      font-weight: 600;
      font-size: clamp(14px, 1.6vw, 16px);
      letter-spacing: .05em;
      line-height: 1.5;
      text-align: center;
      text-decoration: underline; }
      .footer .footer-list .list-item:nth-of-type(3) {
        width: 100%; }
  .footer .footer-cr {
    margin-top: 30px;
    font-size: 12px;
    color: #FFF;
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    letter-spacing: .05em;
    text-align: center; }
  .footer .footer-shop {
    margin-top: 3rem;
    color: #FFF;
    font-weight: 600;
    font-size: clamp(14px, 1.6vw, 16px);
    letter-spacing: .05em;
    line-height: 1.5;
    text-align: center; }
    .footer .footer-shop a {
      color: #FFF;
      text-decoration: underline; }

@media screen and (min-width: 768px) {
  .footer .inner {
    max-width: 1110px; }
  .footer .footer-logo {
    margin-left: 0; }
  .footer .footer-list {
    justify-content: flex-end; }
    .footer .footer-list .list-item:nth-of-type(3) {
      width: auto; }
  .footer .footer-cr {
    text-align: right; } }
