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

Title : single-fc.scss
For   : FLOWER COLLECT 詳細ページ

Created       : 2026-04-14
Last Modified : 2026-04-14

////////////////////////////////////////////////// */
/**
 * layout
 */
.p-fc-single .c-page-header {
  max-width: var(--container-middle);
  width: 95%;
  margin-inline: auto;
}
.p-fc-single__shell {
  max-width: var(--container-middle);
  width: 95%;
  margin-inline: auto;
}

/**
 * header
 */
.p-fc-single__header {
  display: flex;
  flex-direction: column;
  /* --- for small viewport --- */
  /* --- for large viewport --- */
}
.p-fc-single__header .c-global-heading--tertiary {
  --fs-heading-main: 2em;
}
.p-fc-single__header .c-global-heading__main span {
  font-size: 0.75em;
}
.p-fc-single__header + * {
  -webkit-margin-before: var(--space-y-header-variant, var(--space-y-header));
          margin-block-start: var(--space-y-header-variant, var(--space-y-header));
}
@media (max-width: 767px) {
  .p-fc-single__header {
    gap: 30px;
  }
  .p-fc-single__header + * {
    --space-y-header: 30px;
  }
}
@media (min-width: 768px) {
  .p-fc-single__header {
    gap: 60px;
  }
  .p-fc-single__header + * {
    --space-y-header: 60px;
  }
}

/**
 * cat
 */
.p-fc-single__cta {
  -webkit-margin-before: 3.5em;
          margin-block-start: 3.5em;
}

/**
 * tabs
 */
.p-fc-single__tabs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5em;
}
.p-fc-single__tab {
  padding-block: 1.4285714286em;
  border-radius: var(--rounded-full);
  background-color: var(--bg-tab-state, var(--color-white-subtle));
  color: var(--color-tab-state);
  font-size: var(--text-sm);
  text-align: center;
  letter-spacing: 0.04em;
  transition: all var(--transition-default);
}
.p-fc-single__tab.is-active {
  --bg-tab-state: var(--color-primary);
  --color-tab-state: var(--color-white);
}
.p-fc-single__tab.is-disabled, .p-fc-single__tab:disabled {
  color: var(--color-gray);
  cursor: not-allowed;
  opacity: 0.5;
}

/**
 * タブパネル
 */
.p-fc-single__panel {
  display: none;
  padding-block: 3em 0;
}
.p-fc-single__panel.is-active {
  display: block;
}

/**
 * section
 */
.p-fc-single__section {
  padding-block: var(--py-section-variant, var(--py-section));
  line-height: var(--leading-relaxed);
  /* --- for small viewport --- */
  /* --- for large viewport --- */
}
@media (max-width: 767px) {
  .p-fc-single__section {
    --py-section: 40px;
  }
  .p-fc-single__section:first-of-type {
    --py-section-variant: 0 40px;
  }
}
@media (min-width: 768px) {
  .p-fc-single__section {
    --py-section: 80px;
  }
  .p-fc-single__section:first-of-type {
    --py-section-variant: 0 80px;
  }
}
.p-fc-single__section--fill {
  background-color: var(--color-white-subtle);
}

/**
 * 1. hero
 */
.p-fc-hero__container {
  display: grid;
  gap: 3em;
  /* --- for small viewport --- */
  /* --- for large viewport --- */
}
@media (max-width: 767px) {
  .p-fc-hero__container {
    grid-template-columns: 100%;
  }
}
@media (min-width: 768px) {
  .p-fc-hero__container {
    grid-template-columns: auto 1fr;
    align-items: center;
  }
}
.p-fc-hero__image {
  /* --- for small viewport --- */
  /* --- for large viewport --- */
}
@media (max-width: 767px) {
  .p-fc-hero__image {
    max-width: 500px;
    margin-inline: auto;
  }
}
@media (min-width: 768px) {
  .p-fc-hero__image {
    width: clamp(300px, 40vw, 472px);
  }
}
.p-fc-hero__detail-summary {
  display: grid;
  grid-template-columns: 14.7058823529% 1fr;
  align-items: center;
  gap: 1.5em;
}
.p-fc-hero__detail-image {
  grid-column: 1;
  grid-row: 1/span 2;
  border-radius: 100%;
  overflow: hidden;
  aspect-ratio: 97/115;
}
.p-fc-hero__detail-image img {
  display: block;
  width: 100%;
  height: 100%;
  margin-inline: auto;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom center;
     object-position: bottom center;
}
.p-fc-hero__detail-image .c-noimage-placeholder {
  aspect-ratio: 4/3;
}
.p-fc-hero__company {
  grid-column: 2;
  grid-row: 1;
  align-self: end;
  font-size: var(--text-xl);
  line-height: var(--leading-tight);
}
.p-fc-hero__position {
  grid-column: 2;
  grid-row: 2;
  align-self: start;
  line-height: var(--leading-normal);
}
.p-fc-hero__comment {
  -webkit-margin-before: 2em;
          margin-block-start: 2em;
}

/**
 * 2. information
 */
.p-fc-delivery__list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  -moz-column-gap: 10%;
       column-gap: 10%;
  row-gap: 60px;
  text-align: center;
}
.p-fc-delivery__col {
  display: flex;
  flex-direction: column;
  gap: 2em;
  max-width: 320px;
  width: 100%;
}
.p-fc-delivery__col[data-delivery-info=application_deadline] {
  --bg-term: var(--icon-edit-path);
}
.p-fc-delivery__col[data-delivery-info=delivery_date] {
  --bg-term: var(--icon-calendar-path);
}
.p-fc-delivery__col[data-delivery-info=delivery_location] {
  --bg-term: var(--icon-pin-path);
}
.p-fc-delivery__term {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6666666667em;
  font-size: var(--text-2xl);
  font-weight: 700;
  line-height: var(--leading-none);
}
.p-fc-delivery__term::before {
  content: "";
  width: 2.6666666667em;
  height: 2.6666666667em;
  background-image: var(--bg-term);
  background-size: 100%;
  background-repeat: no-repeat;
}
.p-fc-delivery__desc {
  -webkit-margin-before: auto;
          margin-block-start: auto;
}
.p-fc-delivery__label {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  -webkit-margin-after: 1.5em;
          margin-block-end: 1.5em;
  padding-block: 0.5em;
  padding-inline: 1em;
  border: 1px solid var(--color-white-subtle);
  border-radius: var(--rounded-full);
  color: var(--color-white-subtle);
  line-height: var(--leading-none);
}
.p-fc-delivery__detail {
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: var(--leading-relaxed);
  letter-spacing: -0.04em;
}
.p-fc-delivery__detail span {
  font-size: 1.4em;
}

/**
 * 3. product
 */
.p-fc-product-lead {
  display: flex;
  flex-direction: column;
  gap: 3em;
}
.p-fc-product-lead__image img {
  max-width: 100%;
  height: auto;
  display: block;
}

.p-fc-product-cta {
  -webkit-margin-before: var(--py-section);
          margin-block-start: var(--py-section);
}
.p-fc-product-cta__prices {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 3.5em;
}
.p-fc-product-cta__price {
  display: flex;
  align-items: center;
  gap: 1.5em;
}
.p-fc-product-cta__price-label {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 1.6em;
  height: 1.6em;
  background-color: var(--color-primary);
  font-size: var(--text-xl);
  color: var(--color-white);
}
.p-fc-product-cta__price-amount {
  font-size: var(--text-2xl);
  font-weight: 700;
}
.p-fc-product-cta__price-amount span {
  font-size: 0.6666666667em;
}

/**
 * 4. celebration sign
 */
/**
 * 5. billing
 */
.p-fc-billing__subtitle {
  font-size: var(--text-2xl);
  line-height: var(--leading-none);
}
.p-fc-billing__body {
  display: grid;
  gap: 3.5em;
  /* --- for small viewport --- */
  /* --- for large viewport --- */
}
@media (max-width: 767px) {
  .p-fc-billing__body {
    grid-template-columns: 100%;
  }
}
@media (min-width: 768px) {
  .p-fc-billing__body {
    grid-template-columns: auto 1fr;
    align-items: center;
  }
}
.p-fc-billing__bank {
  display: flex;
  flex-direction: column;
  gap: 1.5em;
  max-width: 450px;
  width: 100%;
  padding: 2em;
  border: 1px solid var(--color-white-subtle);
}
.p-fc-billing__bank-label {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.5714285714em;
  background-color: var(--color-white-subtle);
  font-size: var(--text-sm);
  color: var(--color-primary);
  font-weight: 700;
  line-height: var(--leading-none);
}
.p-fc-billing__bank-table {
  display: grid;
  grid-template-columns: auto 1fr;
}
.p-fc-billing__bank-note {
  font-size: var(--text-xs);
}
.p-fc-billing__note {
  letter-spacing: 0.04em;
}

/**
 * 6. report
 */
/**
 * 7. flow
 */
.p-fc-flow__steps {
  display: flex;
  flex-direction: column;
  counter-reset: fc-step;
}
.p-fc-flow__step {
  --w-step-number: calc(90 / 16 * 1em);
  position: relative;
  display: grid;
  grid-template-columns: var(--w-step-number) 1fr;
  gap: 10%;
  width: 100%;
  padding-block: var(--py-step-variant, 1.5em);
}
.p-fc-flow__step:first-child {
  --py-step-variant: 0 calc(24 / 16 * 1em);
}
.p-fc-flow__step:last-child {
  --py-step-variant: calc(24 / 16 * 1em) 0;
}
.p-fc-flow__step::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(var(--w-step-number) / 2);
  width: 1px;
  background-color: var(--color-white);
}
.p-fc-flow__step-number {
  align-self: start;
  padding-block: 1em;
  background-color: var(--color-white);
  color: var(--color-primary);
  text-align: center;
  line-height: 1;
  letter-spacing: 0.04em;
}
.p-fc-flow__step-number::after {
  content: attr(data-num);
}
.p-fc-flow__step-title {
  font-size: var(--text-xl);
  line-height: var(--leading-none);
  letter-spacing: 0.04em;
}
.p-fc-flow__step-desc {
  -webkit-margin-before: 2em;
          margin-block-start: 2em;
  line-height: var(--leading-relaxed);
}

/**
 * 8. faq
 */
/**
 * 9. contact
 */
.p-fc-contact__lead {
  font-size: var(--text-xl);
  line-height: var(--leading-normal);
  letter-spacing: 0.04em;
}
.p-fc-contact__tel {
  display: flex;
  align-items: center;
  gap: 0.5em;
  -webkit-margin-before: 1.2em;
          margin-block-start: 1.2em;
  font-size: var(--text-5xl);
  color: var(--color-primary);
  line-height: var(--leading-none);
}
.p-fc-contact__tel::before {
  content: "";
  flex-shrink: 0;
  width: 1.2em;
  height: 1.2em;
  background-color: var(--color-primary);
  -webkit-mask-image: var(--icon-tel-path);
          mask-image: var(--icon-tel-path);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: 100%;
          mask-size: 100%;
}
.p-fc-contact__info {
  display: flex;
  align-items: center;
  -moz-column-gap: 5em;
       column-gap: 5em;
  row-gap: 1.25em;
  flex-wrap: wrap;
  -webkit-margin-before: 2.5em;
          margin-block-start: 2.5em;
}
.p-fc-contact__info-term {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.5em;
}
.p-fc-contact__info-term dt {
  width: 14.5714285714em;
  padding-block: 0.5714285714em;
  background-color: var(--color-white);
  font-size: var(--text-sm);
  color: var(--color-primary);
  font-weight: 700;
  line-height: var(--leading-none);
  text-align: center;
}
.p-fc-contact__info-term dd {
  font-size: var(--text-xl);
}

/**
 * 10. closed visual
 */
.p-fc-closed-visual {
  --py-section-variant: 0 !important;
}
.p-fc-closed-visual__text {
  -webkit-margin-before: 2.5em;
          margin-block-start: 2.5em;
  line-height: var(--leading-relaxed);
  letter-spacing: 0.04em;
}

/**
 * 11. closed content
 */
.p-fc-closed-content__block {
  display: grid;
  gap: 3em;
  /* --- for small viewport --- */
  /* --- for large viewport --- */
}
@media (max-width: 767px) {
  .p-fc-closed-content__block {
    grid-template-columns: 100%;
  }
}
@media (min-width: 768px) {
  .p-fc-closed-content__block {
    grid-template-columns: auto 1fr;
  }
}
.p-fc-closed-content__image {
  /* --- for small viewport --- */
  /* --- for large viewport --- */
}
@media (max-width: 767px) {
  .p-fc-closed-content__image {
    max-width: 500px;
    margin-inline: auto;
  }
}
@media (min-width: 768px) {
  .p-fc-closed-content__image {
    width: clamp(300px, 40vw, 472px);
  }
}
.p-fc-closed-content__detail {
  -webkit-margin-before: 3.75em;
          margin-block-start: 3.75em;
  line-height: var(--leading-relaxed);
  letter-spacing: 0.04em;
}

/**
 * 12. closed contact
 */
.p-fc-closed-contact__heading {
  font-size: 2em;
  line-height: var(--leading-none);
  text-align: center;
}
.p-fc-closed-contact__lead {
  -webkit-margin-before: 1.7142857143em;
          margin-block-start: 1.7142857143em;
  font-size: var(--text-sm);
  line-height: var(--leading-none);
  text-align: center;
}
.p-fc-closed-contact__buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.5em;
  -webkit-margin-before: 3.75em;
          margin-block-start: 3.75em;
}
/*# sourceMappingURL=single-fc.css.map */