@charset "UTF-8";
/*
Theme Name: viviane-template-child
Template: viviane-template
*/

:root {
  /* Colors */
  --color-primary: #3a9a9f;
  --color-secondary: #997037;
  --color-text-title: #333;
  --color-text-body: #555;
  --color-text-light: #777;
  --color-text-lighter: #c2c2c2;
  --color-white: #ffffff;
  --color-bg-base: #ffffff;
  --color-bg-gray: #f7f8f8; 
  --color-bg-dark: #1f3637; 
  --color-border-base: #e2e4e4; 
  --color-border-light: #d5d8d8;
  --color-border-dark: #526060;
  --color-btn: #1f3637;
  --color-accent: #C66762; 
  --color-overlay: rgba(0, 0, 0, 0.3);
  --color-anchor: #376099;

  /* Spacing */
  --sp-xs: 0.25rem; /* 4px */
  --sp-sm: 0.5rem; /* 8px */
  --sp-md: 1rem; /* 16px */
  --sp-lg: 1.5rem; /* 24px */
  --sp-xl: 3rem; /* 48px */
  --sp-section: 5rem;

  /* Typography */
  --font-base: "YuGothic", "Hiragino Sans", Meiryo, sans-serif;
  --font-accent: "EB Garamond", serif;
  --font-name: "EB Garamond", serif;
  --font-size-base: 1rem;
  --font-size-sm: 0.875rem;
  --font-size-lg: 1.25rem;
  --font-size-xl: 1.5rem;
  --font-size-2xl: 1.875rem;

  --radius-base: 0.25rem;
  --radius-sm: 0.125rem;
  --radius-lg: 0.25rem;
  --radius-full: 9999px;
}

.l-header__typo {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

@media (min-width: 768px) {
  .l-header__inner {
    height: 72px;
  }
  .l-header__typo { 
    gap: 0.5rem;
  }
}

.l-header__typo-a {
  display: block;
  font-family: var(--font-name);
  font-size: 1.1rem;
  line-height: 1;
}

.l-header__typo-b {
  font-size: 0.75rem;
  line-height: 1;
  letter-spacing: 0;
}

@media (min-width: 768px) {
  .l-header__typo-a {
    font-size: 1.5rem;
  }
  .l-header__typo-b {
    font-size: 1rem;
  }
}

.p-mv__title {
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  line-height: 1.7;
}

.p-mv__lead {
  font-size: 1rem;
}

@media (min-width: 768px) {
  .p-mv__title {
    font-size: 2.5rem;
  }
  .p-mv__lead {
    font-size: 1.25rem;
  }
}

/*
.p-page-header__bg {
  filter: blur(2px);
}*/

.c-section-header__en {
  font-family: var(--font-accent);
  font-size: var(--font-size-base);
  text-transform: none;
}

#concept .c-section-header__jp {
  font-size: 1.125rem;
  line-height: 1.8;
}

@media (min-width: 768px) {
  .c-section-header__en {
    font-size: var(--font-size-lg);
  }
  #concept .c-section-header__jp {
    font-size: 1.5rem;
  }
}

.p-loop-slider__item {
  margin: 0 0.5rem;
}

.p-para__num:before, .p-room-item__title::before {
    width: 1rem;
    height: 2px;
    border-radius: 0;
    vertical-align: middle;
}

.p-para__num {
    font-size: 2rem;
  }

.p-room-item__main-img {
  aspect-ratio: 3/2;
}