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

    COMMON SETTINGS

   ************************************************************************
   ************************************************************************ */
/* ------------------------------
    RESPONSIVE SETTINGS
  ------------------------------ */
/* ------------------------------
    FONT
  ------------------------------ */
.t__min {
  font-family: serif !important;
}

/* ------------------------------
    COLOR SETTINGS
  ------------------------------ */
/* ------------------------------
    MIXIN
  ------------------------------ */
/* ------------------------------
    KEYFRAME
  ------------------------------ */
@-webkit-keyframes scrollDown {
  0% {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
    opacity: 1;
  }
  70% {
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
    opacity: 0;
  }
}
@keyframes scrollDown {
  0% {
    -webkit-transform: translateY(0px);
            transform: translateY(0px);
    opacity: 1;
  }
  70% {
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
    opacity: 0;
  }
}
@-webkit-keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes loopClY {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
@keyframes loopClY {
  from {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
@-webkit-keyframes loopClRv {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@keyframes loopClRv {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@-webkit-keyframes countDown {
  from {
    clip-path: inset(0 100% 0 0);
  }
  to {
    clip-path: inset(0 0% 0 0);
  }
}
@keyframes countDown {
  from {
    clip-path: inset(0 100% 0 0);
  }
  to {
    clip-path: inset(0 0% 0 0);
  }
}
@-webkit-keyframes rotateInf {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
    -webkit-transform-origin: center;
            transform-origin: center;
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
    -webkit-transform-origin: center;
            transform-origin: center;
  }
}
@keyframes rotateInf {
  from {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
    -webkit-transform-origin: center;
            transform-origin: center;
  }
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
    -webkit-transform-origin: center;
            transform-origin: center;
  }
}
@-webkit-keyframes zoomOut {
  0% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes zoomOut {
  0% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
#headerNav {
  mix-blend-mode: difference;
}

/* =========================
 * Contact-like Layout (beatfic taste)
 * ========================= */
.nwContactLike {
  --nw-ink: var(--color-text, #111);
  --nw-muted: var(--color-muted, rgba(17, 17, 17, .55));
  --nw-line: var(--color-line, rgba(0, 0, 0, .16));
  --nw-line-weak: var(--color-line-weak, rgba(0, 0, 0, .10));
  --nw-focus: var(--color-accent, #E85743);
  --color-bg: 255 255 255;
  --color-font: 82 82 82;
  color: var(--nw-ink);
  background: rgb(var(--color-bg));
  color: rgb(var(--color-font));
}
@media screen and (min-width: 320px) {
  .nwContactLike {
    padding: 24rem 2.5vw 12rem;
  }
}
@media screen and (min-width: 600px) {
  .nwContactLike {
    padding: 24rem 2.5vw 12rem;
  }
}
.nwContactLike__inner {
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (min-width: 320px) {
  .nwContactLike__head {
    width: 100%;
    margin-bottom: 32px;
    padding-top: 0;
  }
}
@media screen and (min-width: 600px) {
  .nwContactLike__head {
    width: 50%;
    margin-bottom: 0;
    padding-top: 3.2rem;
  }
}
.nwContactLike__headInner {
  position: sticky;
  top: 24rem;
}
.nwContactLike__title {
  margin: 0;
  letter-spacing: -0.03em;
  line-height: 0.92;
  font-family: acumin-pro, sans-serif;
  font-weight: 700;
  font-size: clamp(5.2rem, 7.2vw, 7.2rem);
}
@media screen and (min-width: 600px) {
  .nwContactLike__title {
    font-size: clamp(7.2rem, 6.4vw, 12rem);
  }
}
@media screen and (min-width: 1025px) {
  .nwContactLike__title {
    font-size: clamp(9rem, 6.2vw, 14rem);
  }
}
.nwContactLike__lead {
  margin: 2.2rem 0 0;
  color: var(--nw-muted);
  line-height: 1.9;
  font-size: 1rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike__lead {
    font-size: 1.6rem;
  }
}
.nwContactLike__form {
  padding-top: 1.2rem;
}
@media screen and (min-width: 320px) {
  .nwContactLike__form {
    width: 100%;
  }
}
@media screen and (min-width: 600px) {
  .nwContactLike__form {
    width: 50%;
    padding-top: 3.2rem;
  }
}

/* =========================
 * CF7 Base reset (clean)
 * ========================= */
.nwContactLike .wpcf7 {
  margin: 0;
}
.nwContactLike .wpcf7 form {
  margin: 0;
}
.nwContactLike .wpcf7-response-output {
  margin: 2rem 0 0;
  border: 0;
  padding: 1.2rem 0 0;
  border-top: 1px solid var(--nw-line-weak);
  color: var(--nw-muted);
  line-height: 1.7;
  font-size: 0.95rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike .wpcf7-response-output {
    font-size: 1.4rem;
  }
}
.nwContactLike .wpcf7-not-valid-tip {
  margin-top: 0.6rem;
  color: var(--nw-focus);
  font-size: 0.9rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike .wpcf7-not-valid-tip {
    font-size: 1.2rem;
  }
}

/* =========================
 * Field layout: label + underline input
 * ========================= */
.nwContactLike {
  /* inputs = underline */
  /* placeholderは薄く */
  /* focusは“気配だけ” */
  /* selectの矢印は控えめに（下線世界観） */
  /* acceptance */
  /* submit = “丸ボタンじゃなく、端正な矩形”に寄せる */
  /* 希望枠（第1/第2/第3）も囲いを消して、区切り線に */
}
.nwContactLike .nwInterview {
  /* “カード/囲い”感は無効化して、行のリズムだけ残す */
  background: transparent;
}
.nwContactLike .nwInterview__grid {
  display: grid;
  gap: 3.6rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwInterview__grid {
    gap: 4.2rem;
  }
}
.nwContactLike .nwInterview__block {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
}
.nwContactLike .nwInterview__blockTitle {
  margin: 0 0 1.8rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  opacity: 0.48;
  /* 見出しの線は薄く */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 1.2rem;
}
@media screen and (min-width: 320px) {
  .nwContactLike .nwInterview__blockTitle {
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwInterview__blockTitle {
    font-size: 2.8rem;
  }
}
.nwContactLike .nwFieldRow {
  display: grid;
  gap: 2.4rem;
  margin-bottom: 2.4rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwFieldRow {
    grid-template-columns: 1fr 1fr;
    gap: 3.2rem;
    margin-bottom: 3.2rem;
  }
}
.nwContactLike .nwField {
  display: grid;
  gap: 1.2rem;
}
.nwContactLike .nwLabel {
  font-weight: 800;
  letter-spacing: 0.02em;
  color: var(--nw-ink);
}
@media screen and (min-width: 320px) {
  .nwContactLike .nwLabel {
    font-size: 1.3rem;
  }
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwLabel {
    font-size: 1.6rem;
  }
}
.nwContactLike .nwReq {
  display: inline-block;
  margin-left: 0.6rem;
  color: var(--nw-muted);
  font-weight: 800;
  font-size: 0.85em;
  background: none;
  padding: 0;
  border-radius: 0;
}
.nwContactLike input[type=text],
.nwContactLike input[type=email],
.nwContactLike input[type=tel],
.nwContactLike input[type=number],
.nwContactLike input[type=date],
.nwContactLike select,
.nwContactLike textarea {
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--nw-line);
  background: transparent;
  border-radius: 0;
  padding: 1.1rem 0.2rem 1.1rem;
  outline: none;
  font-size: 1rem;
  -webkit-transition: border-color 0.18s ease, -webkit-box-shadow 0.18s ease, -webkit-transform 0.18s ease;
  transition: border-color 0.18s ease, -webkit-box-shadow 0.18s ease, -webkit-transform 0.18s ease;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease, -webkit-box-shadow 0.18s ease, -webkit-transform 0.18s ease;
}
@media screen and (min-width: 600px) {
  .nwContactLike input[type=text],
  .nwContactLike input[type=email],
  .nwContactLike input[type=tel],
  .nwContactLike input[type=number],
  .nwContactLike input[type=date],
  .nwContactLike select,
  .nwContactLike textarea {
    font-size: 1.6rem;
  }
}
.nwContactLike textarea {
  min-height: 160px;
  resize: vertical;
  padding-top: 1.2rem;
}
.nwContactLike input::-webkit-input-placeholder, .nwContactLike textarea::-webkit-input-placeholder {
  color: rgba(0, 0, 0, 0.28);
}
.nwContactLike input::-moz-placeholder, .nwContactLike textarea::-moz-placeholder {
  color: rgba(0, 0, 0, 0.28);
}
.nwContactLike input:-ms-input-placeholder, .nwContactLike textarea:-ms-input-placeholder {
  color: rgba(0, 0, 0, 0.28);
}
.nwContactLike input::-ms-input-placeholder, .nwContactLike textarea::-ms-input-placeholder {
  color: rgba(0, 0, 0, 0.28);
}
.nwContactLike input::placeholder,
.nwContactLike textarea::placeholder {
  color: rgba(0, 0, 0, 0.28);
}
.nwContactLike input:focus,
.nwContactLike select:focus,
.nwContactLike textarea:focus {
  border-bottom-color: rgba(0, 0, 0, 0.4);
  -webkit-box-shadow: 0 10px 0 -9px rgba(232, 87, 67, 0.35);
          box-shadow: 0 10px 0 -9px rgba(232, 87, 67, 0.35);
}
.nwContactLike select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, rgba(0, 0, 0, 0.55) 50%), linear-gradient(135deg, rgba(0, 0, 0, 0.55) 50%, transparent 50%);
  background-position: calc(100% - 10px) calc(50% + 2px), calc(100% - 4px) calc(50% + 2px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 2.2rem;
}
.nwContactLike .wpcf7-form-control-wrap {
  display: block;
}
.nwContactLike .nwConsent {
  margin-top: 0.6rem;
}
.nwContactLike .nwConsent label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 1.2rem;
  line-height: 1.7;
  color: var(--nw-muted);
  font-size: 0.95rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwConsent label {
    font-size: 1.4rem;
  }
}
.nwContactLike .nwConsent input[type=checkbox] {
  margin-top: 0.35rem;
  width: 18px;
  height: 18px;
  accent-color: var(--nw-focus);
}
.nwContactLike .nwActions {
  margin-top: 3.2rem;
}
.nwContactLike .nwActions input[type=submit] {
  background: transparent;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 700;
  letter-spacing: 0.04em;
  width: 100%;
  background: rgb(var(--color-font));
  color: rgb(var(--color-bg));
  -webkit-transition: background-color 0.16s ease, border-color 0.16s ease, -webkit-transform 0.16s ease;
  transition: background-color 0.16s ease, border-color 0.16s ease, -webkit-transform 0.16s ease;
  transition: transform 0.16s ease, background-color 0.16s ease, border-color 0.16s ease;
  transition: transform 0.16s ease, background-color 0.16s ease, border-color 0.16s ease, -webkit-transform 0.16s ease;
}
@media screen and (min-width: 320px) {
  .nwContactLike .nwActions input[type=submit] {
    font-size: 1.4rem;
    padding: 16px 0;
  }
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwActions input[type=submit] {
    font-size: 1.8rem;
    padding: 24px 0;
  }
}
.nwContactLike .nwActions input[type=submit]:hover {
  -webkit-transform: translateY(-3px);
          transform: translateY(-3px);
}
.nwContactLike .nwActions input[type=submit]:active {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.nwContactLike .nwMeta {
  margin-top: 2.6rem;
  padding-top: 1.8rem;
  border-top: 1px solid var(--nw-line-weak);
  color: rgba(0, 0, 0, 0.38);
  font-size: 0.85rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwMeta {
    font-size: 1.2rem;
  }
}
.nwContactLike .nwSlot {
  border: 0;
  border-radius: 0;
  padding: 0;
  margin: 0 0 2.4rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwSlot {
    margin: 0 0 3rem;
  }
}
.nwContactLike .nwSlot__title {
  margin: 0 0 1.2rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  font-size: 0.98rem;
  color: var(--nw-ink);
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwSlot__title {
    font-size: 1.4rem;
  }
}
.nwContactLike .nwHelp {
  margin-top: 1.2rem;
  color: var(--nw-muted);
  line-height: 1.8;
  font-size: 0.95rem;
}
@media screen and (min-width: 600px) {
  .nwContactLike .nwHelp {
    font-size: 1.4rem;
  }
}

/* spinner */
.nwContactLike .wpcf7 .wpcf7-spinner {
  margin-left: 1rem;
}/*# sourceMappingURL=contact.css.map */