@charset "UTF-8";

html {
  scroll-behavior: smooth;
  font-size: 100%;
}
@media screen and (width >= 768px) {
  html {
    font-size: clamp(13px, 1.1vw, 16px);
  }
}

a[href^=tel] {
  text-decoration: none;
}

a {
  color: inherit;
  -webkit-tap-highlight-color: transparent;
  /* 強調をなくす */
}

a:hover {
  text-decoration: none;
}

img,
svg {
  vertical-align: middle;
}

img {
  width: 100%;
  object-fit: cover;
}

:where(:any-link, button, [type=button], [type=reset], [type=submit], label[for], select, summary, [role=tab], [role=button]) {
  cursor: pointer;
}

:where(button, [type=button], [type=reset], [type=submit]) {
  touch-action: manipulation;
}

:focus:not(:focus-visible) {
  outline: none;
}

input[type=text] {
  font-size: 1rem;
  /* = 16px */
}

textarea {
  field-sizing: content;
}

body {
  font-family: var(--base-font-family);
  font-weight: var(--fw-regular);
  color: var(--color-text);
}

@media screen and (width >= 768px) {
  .u-br-sp {
    display: none;
  }
}

html {
  box-sizing: border-box;
  /* Prevent adjustments of font size after orientation changes in iOS */
  word-break: normal;
  tab-size: 4;
  text-size-adjust: 100%;
}

*,
::before,
::after {
  /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  box-sizing: inherit;
  box-sizing: border-box;
  background-repeat: no-repeat;
}

::before,
::after {
  text-decoration: inherit;
  /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}

* {
  padding: 0;
  /* Reset `padding` and `margin` of all elements */
  margin: 0;
}

/* # =================================================================
     # General elements
     # ================================================================= */
hr {
  /* Show the overflow in Edge and IE */
  height: 0;
  overflow: visible;
  /* Add the correct box sizing in Firefox */
  color: inherit;
  /* Correct border color in Firefox. */
}

details,
main {
  display: block;
  /* Render the `main` element consistently in IE. */
}

summary {
  display: list-item;
  /* Add the correct display in all browsers */
}

small {
  font-size: 80%;
  /* Set font-size to 80% in `small` elements */
}

[hidden] {
  display: none;
  /* Add the correct display in IE */
}

abbr[title] {
  /* Remove the bottom border in Chrome 57 */
  /* Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari */
  text-decoration: underline;
  text-decoration: underline dotted;
  border-bottom: none;
}

a {
  background-color: transparent;
  /* Remove the gray background on active links in IE 10 */
}

a:active,
a:hover {
  outline-width: 0;
  /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* Specify the font family of code elements */
}

pre {
  font-size: 1em;
  /* Correct the odd `em` font sizing in all browsers */
}

b,
strong {
  font-weight: bolder;
  /* Add the correct font weight in Chrome, Edge, and Safari */
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

table {
  /* Correct border color in all Chrome, Edge, and Safari. */
  text-indent: 0;
  border-color: inherit;
  /* Remove text indentation in Chrome, Edge, and Safari */
}

iframe {
  border-style: none;
}

/* # =================================================================
     # Forms
     # ================================================================= */
input {
  border-radius: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
  /* Correct the cursor style of increment and decrement buttons in Chrome */
}

[type=search] {
  appearance: textfield;
  appearance: none;
  /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px;
  /* Correct the outline style in Safari */
}

[type=search]::-webkit-search-decoration {
  appearance: none;
  /* Remove the inner padding in Chrome and Safari on macOS */
}

textarea {
  overflow: auto;
  resize: vertical;
}

button,
input,
optgroup,
select,
textarea {
  font: inherit;
  /* Specify font inheritance of form elements */
}

optgroup {
  font-weight: bold;
  /* Restore the font weight unset by the previous rule */
}

button {
  overflow: visible;
  /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

button,
select {
  text-transform: none;
  /* Firefox 40+, Internet Explorer 11- */
}

/* Apply cursor pointer to button elements */
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  appearance: button;
  /* Correct the inability to style clickable types in iOS */
}

button,
input,
select,
textarea {
  appearance: none;
  background-color: transparent;
  border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
  outline-width: 0;
}

/* Style select like a standard input */
select {
  appearance: none;
}

select::-ms-expand {
  display: none;
  /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentcolor;
  /* Internet Explorer 11+ */
}

legend {
  /* Correct the color inheritance from `fieldset` elements in IE */
  display: table;
  /* Correct the text wrapping in Edge and IE */
  /* Correct the text wrapping in Edge and IE */
  max-width: 100%;
  /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit;
  /* Correct the text wrapping in Edge and IE */
  white-space: normal;
  border: 0;
  /* Correct the text wrapping in Edge 18- and IE */
}

::-webkit-file-upload-button {
  font: inherit;
  color: inherit;
  /* Correct the inability to style clickable types in iOS and Safari */
  appearance: button;
  /* Change font properties to `inherit` in Chrome and Safari */
}

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

/* # =================================================================
     # Specify media element style
     # ================================================================= */
img {
  border-style: none;
  /* Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline;
}

/* # =================================================================
     # Accessibility
     # ================================================================= */
/* Specify the progress cursor of updating elements */
[aria-busy=true] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled=true] {
  cursor: default;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Remove default padding */
ul,
ol {
  padding: 0;
  list-style: "";
}

a {
  color: inherit;
  text-decoration: none;
  transition: opacity 0.3s;
}

@property --root-font-size {
  syntax: "<length>";
  inherits: false;
  initial-value: 16px;
}
@font-face {
  font-family: "Local Noto Sans JP";
  src: local("Noto Sans JP");
}
:root {
  /* inner */
  --inner: 1250px;
  --inner-sp: min(500px, 100%);
  --padding-inner: 20px;
  --padding-inner-pc: calc(25 * var(--to-rem));
  /* z-index */
  --z-index-header: 900;
  /* color */
  --color-white: #fff;
  --color-text: #0d2936;
  --color-black: #000;
  --color-gray: #f0f0f0;
  --color-border-gray: #aaaaaf;
  --color-accent: #408f95;
  --color-primary: #234f5e;
  --color-secondary: #00f;
  --color-orange: #de8430;
  /* font-weight */
  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-bold: 700;
  /* font-family */
  --base-font-family: "Local Noto Sans JP", "Noto Sans JP", sans-serif;
  --title-font-family: "Lato", sans-serif;
  --roboto-font-family: "Roboto Condensed", sans-serif;
  --dm-mono-font-family: "DM Mono", monospace;
  --to-rem: calc(tan(atan2(1px, var(--root-font-size))) * 1rem);
  /* transition duration */
  --duration: 0.3s;
  /* header height */
  --header-height: 64px;
}
@media screen and (width >= 768px) {
  :root {
    --header-height: 80px;
  }
}

.l-contact {
  margin-top: var(--header-height);
}

.l-cta {
  position: relative;
  z-index: 1;
  margin-top: calc(-245 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .l-cta {
    margin-top: calc(-170 * var(--to-rem));
  }
}

.l-header {
  position: fixed;
  inset: 0;
  z-index: var(--z-index-header);
}

.l-inner {
  max-width: calc(var(--inner-sp) + var(--padding-inner) * 2);
  padding-inline: var(--padding-inner);
  margin-inline: auto;
}
@media screen and (min-width: 1024px) {
  .l-inner {
    max-width: calc(var(--inner) + var(--padding-inner-pc) * 2);
    padding-inline: var(--padding-inner-pc);
  }
}

.l-top__about {
  margin-block-start: calc(40 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .l-top__about {
    margin-block-start: calc(124 * var(--to-rem));
  }
}

.l-about {
  margin-top: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .l-about {
    margin-top: calc(0 * var(--to-rem));
    margin-bottom: calc(0 * var(--to-rem));
  }
}

.c-accordion {
  --_text-color: var(--color-text);
  --_background-default: var(--color-white);
  --_background-interactive: var(--color-gray);
  --_background-opened: var(--color-accent);
  --_text-color-opened: var(--color-white);
  --_duration: 0.2s;
}
.c-accordion::details-content {
  content-visibility: unset;
  display: block grid;
}
@media (prefers-reduced-motion: no-preference) {
  .c-accordion::details-content {
    transition-duration: 300ms;
    transition-property: grid-template-rows;
  }
}
.c-accordion:not([open])::details-content {
  grid-template-rows: 0fr;
}
.c-accordion[open]::details-content {
  grid-template-rows: 1fr;
}

.c-accordion__summary {
  display: block grid;
  grid-template: ". icon"/1fr max-content;
  gap: calc(16 * var(--to-rem));
  align-items: center;
  padding-block: calc(16 * var(--to-rem));
  padding-inline: calc(24 * var(--to-rem));
  color: var(--_text-color);
  background-color: var(--_background-default);
  transition: background-color var(--_duration) ease, color var(--_duration) ease;
}
.c-accordion__summary::before {
  display: inline-block;
  grid-area: icon;
  width: calc(18 * var(--to-rem));
  height: calc(2 * var(--to-rem));
  content: "";
  background-color: currentcolor;
}
.c-accordion__summary::after {
  display: inline-block;
  grid-area: icon;
  width: calc(18 * var(--to-rem));
  height: calc(2 * var(--to-rem));
  content: "";
  background-color: currentcolor;
  transition: rotate var(--_duration) ease;
  rotate: 90deg;
}
.c-accordion__summary:focus-visible {
  background-color: var(--_background-interactive);
  outline: 2px solid currentcolor;
  outline-offset: -2px;
}
@media (any-hover: hover) {
  .c-accordion__summary:hover {
    background-color: var(--_background-interactive);
  }
}

.c-accordion[open] .c-accordion__summary {
  color: var(--_text-color-opened);
  background-color: var(--_background-opened);
}
.c-accordion[open] .c-accordion__summary::after {
  rotate: 0deg;
}

.c-accordion__contents {
  padding-block: calc(16 * var(--to-rem));
  padding-inline: calc(24 * var(--to-rem));
}

.c-button {
  position: relative;
  display: inline-block;
  padding: calc(14 * var(--to-rem)) calc(60 * var(--to-rem));
  font-size: calc(15 * var(--to-rem));
  line-height: 1.2;
  color: var(--color-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background-color: var(--color-white);
  border: 1px solid currentcolor;
}
.c-button::before {
  position: absolute;
  top: 50%;
  right: calc(20 * var(--to-rem));
  width: calc(8 * var(--to-rem));
  height: calc(8 * var(--to-rem));
  content: "";
  border-top: 2px solid var(--color-black);
  border-right: 2px solid var(--color-black);
  transition: rotate 0.3s, translate 0.3s;
  rotate: 45deg;
  translate: 0 -50%;
}
@media (any-hover: hover) {
  .c-button:hover::before {
    translate: 5px -50%;
  }
}

.c-button[data-color=black] {
  color: var(--color-white);
  background-color: var(--color-black);
  border-color: var(--color-black);
}
.c-button[data-color=black]::before {
  border-top: 2px solid currentcolor;
  border-right: 2px solid currentcolor;
}

.c-card {
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 12px;
  transition: scale 0.3s ease;
  container-type: inline-size;
  container-name: card;
}

.c-card__body {
  display: grid;
  grid-template-columns: minmax(min(400 * var(--to-rem), 100%), 1fr) auto;
}
@container card (inline-size <= 700px) {
  .c-card__body {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (any-hover: hover) {
  .c-card:has(.c-button:hover) .c-card__image img {
    scale: 1.1;
  }
}
.c-card__image {
  width: 100%;
  aspect-ratio: 3/2;
  overflow: hidden;
}

.c-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: scale 0.4s ease;
}

.c-card__content {
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: calc(16 * var(--to-rem));
  padding: calc(24 * var(--to-rem));
}

.c-card__title {
  margin: 0;
  font-size: calc(20 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.4;
  color: var(--color-text);
}

@media screen and (min-width: 768px) {
  .c-card__title {
    font-size: calc(24 * var(--to-rem));
  }
}
.c-card__text {
  margin: 0;
  font-size: calc(14 * var(--to-rem));
  line-height: 1.8;
  color: var(--color-text-secondary);
}

@media screen and (min-width: 768px) {
  .c-card__text {
    font-size: calc(16 * var(--to-rem));
  }
}
.c-card__button {
  align-self: end;
}

.c-image-text {
  display: grid;
  grid-template: "image" auto "text" auto/1fr;
  row-gap: calc(24 * var(--to-rem));
  align-items: center;
}
@media screen and (min-width: 768px) {
  .c-image-text {
    grid-template: "image gutter text margin" auto/41.6666666667% calc(16 * var(--to-rem)) 1fr max((100% - var(--inner)) / 2, 32 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .c-image-text.c-image-text--reverse {
    grid-template: "margin text gutter image" auto/max((100% - var(--inner)) / 2, 32 * var(--to-rem)) 1fr calc(16 * var(--to-rem)) 41.6666666667%;
  }
}

@media screen and (min-width: 768px) {
  .c-image-text.c-image-text--overlap {
    grid-template: "image text margin" auto/41.6666666667% 1fr max((100% - var(--inner)) / 2, 32 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .c-image-text.c-image-text--overlap.c-image-text--reverse {
    grid-template: "margin text image" auto/max((100% - var(--inner)) / 2, 32 * var(--to-rem)) 1fr 41.6666666667%;
  }
}

.c-image-text__image {
  grid-area: image;
}

.c-image-text__image img {
  width: 100%;
  height: calc(300 * var(--to-rem));
  object-fit: cover;
}

.c-image-text__text {
  grid-area: text;
  max-width: var(--inner-sp);
  padding: var(--padding-inner);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .c-image-text__text {
    max-width: none;
    padding-inline: revert;
    margin-inline: 0;
  }
}

.c-image-text.c-image-text--overlap .c-image-text__text {
  padding: var(--padding-inner);
  background: var(--color-white);
}
@media screen and (min-width: 768px) {
  .c-image-text.c-image-text--overlap .c-image-text__text {
    padding: calc(20 * var(--to-rem)) 0 calc(20 * var(--to-rem)) calc(20 * var(--to-rem));
    margin-left: calc(-100 * var(--to-rem));
  }
}

@media screen and (min-width: 768px) {
  .c-image-text.c-image-text--overlap.c-image-text--reverse .c-image-text__text {
    padding: calc(20 * var(--to-rem)) calc(20 * var(--to-rem)) calc(20 * var(--to-rem)) 0;
    margin-right: calc(-100 * var(--to-rem));
    margin-left: auto;
  }
}

.c-section-title {
  position: relative;
  font-family: var(--title-font-family);
  font-size: calc(40 * var(--to-rem));
  line-height: 1;
  text-transform: uppercase;
}
@media screen and (min-width: 768px) {
  .c-section-title {
    font-size: calc(60 * var(--to-rem));
  }
}

.c-section-title[data-position=center] {
  text-align: center;
}

.c-section-title[data-position=left] {
  text-align: left;
}

.c-section-title[data-position=right] {
  text-align: right;
}

.c-section-title::before {
  position: absolute;
  top: 50%;
  z-index: -1;
  font-size: calc(60 * var(--to-rem));
  color: var(--color-gray);
  content: attr(data-title);
}
@media screen and (min-width: 768px) {
  .c-section-title::before {
    font-size: calc(120 * var(--to-rem));
  }
}

.c-section-title[data-position=center]::before {
  left: 50%;
  translate: -50% -50%;
}

.c-section-title[data-position=left]::before {
  left: 0;
  translate: 0 -50%;
}

.c-section-title[data-position=right]::before {
  right: 0;
  translate: 0 -50%;
}

.c-triangle {
  display: inline-block;
  width: calc(64 * var(--to-rem));
  aspect-ratio: 1/1;
  background-color: var(--color-black);
}

.c-triangle[data-direction=top] {
  clip-path: var(--clip-triangle-top);
}

.c-triangle[data-direction=bottom] {
  clip-path: var(--clip-triangle-bottom);
}

.c-triangle[data-direction=left] {
  clip-path: var(--clip-triangle-left);
}

.c-triangle[data-direction=right] {
  clip-path: var(--clip-triangle-right);
}

.c-triangle[data-direction=lower-left] {
  clip-path: var(--clip-triangle-lower-left);
}

.c-triangle[data-direction=upper-left] {
  clip-path: var(--clip-triangle-upper-left);
}

.c-triangle[data-direction=lower-right] {
  clip-path: var(--clip-triangle-lower-right);
}

.c-triangle[data-direction=upper-right] {
  clip-path: var(--clip-triangle-upper-right);
}

.p-about {
  position: relative;
  width: 100%;
  overflow: hidden;
  background-color: var(--color-white);
}
@media screen and (min-width: 1024px) {
  .p-about {
    display: grid;
    grid-template-columns: 1fr clamp(400px, 50vw, 720px);
    align-items: center;
    max-width: calc(1970 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-about__inner {
  padding-inline: calc(20 * var(--to-rem));
}
@media screen and (min-width: 1024px) {
  .p-about__inner {
    max-width: calc(550 * var(--to-rem));
    padding-inline: calc(25 * var(--to-rem)) calc(43 * var(--to-rem));
    margin-inline-start: auto;
  }
}

.p-about__image {
  width: 100%;
  margin-top: calc(40 * var(--to-rem));
  overflow: hidden;
}
@media screen and (min-width: 1024px) {
  .p-about__image {
    width: clamp(400px, 50vw, 720px);
    margin-top: 0;
  }
}

.p-about__image-inner {
  display: block;
  width: 100%;
  height: 180px;
  overflow: hidden;
}
.p-about__image-inner img {
  width: 100% !important;
  height: 420px !important;
  margin-top: -120px;
  object-fit: cover;
  will-change: transform;
}
@media screen and (min-width: 1024px) {
  .p-about__image-inner {
    height: clamp(395px, 49.5vw, 713px);
  }
  .p-about__image-inner img {
    height: calc(clamp(395px, 49.5vw, 713px) + 120px) !important;
    margin-top: -60px;
  }
}

.p-about__image img {
  display: block;
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 0;
}
@media screen and (min-width: 1024px) {
  .p-about__image img {
    width: clamp(400px, 50vw, 720px);
    height: clamp(395px, 49.5vw, 713px);
    border-radius: calc(8 * var(--to-rem)) 0 0 calc(8 * var(--to-rem));
  }
}

.p-about__content {
  display: flex;
  flex-direction: column;
  gap: calc(25 * var(--to-rem));
}
@media screen and (min-width: 1024px) {
  .p-about__content {
    gap: calc(36 * var(--to-rem));
  }
}

.p-about__header {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--to-rem));
}

.js-wipe-text {
  position: relative;
  visibility: hidden;
}
.js-wipe-text::after {
  position: absolute;
  top: -2px;
  left: -4px;
  z-index: 1;
  width: calc(100% + 8px);
  height: calc(100% + 4px);
  content: "";
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  transform: scaleX(0);
  transform-origin: left center;
}
.js-wipe-text[data-wipe-white]::after {
  background: #fff;
}
.js-wipe-text.is-wiping {
  animation: wipe-text-reveal 0s 0.45s forwards;
}
.js-wipe-text.is-wiping::after {
  animation: wipe-in-out 0.9s cubic-bezier(0.77, 0, 0.18, 1) forwards;
}

@keyframes wipe-text-reveal {
  to {
    visibility: visible;
  }
}
@keyframes wipe-in-out {
  0% {
    transform: scaleX(0);
    transform-origin: left center;
  }
  50% {
    transform: scaleX(1);
    transform-origin: left center;
  }
  51% {
    transform: scaleX(1);
    transform-origin: right center;
  }
  100% {
    transform: scaleX(0);
    transform-origin: right center;
  }
}
.p-about__label {
  font-family: "DM Mono", monospace;
  font-size: 14px;
  font-weight: var(--fw-light);
  line-height: calc(17 * var(--to-rem));
  color: transparent;
  text-transform: uppercase;
  letter-spacing: 3px;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 768px) {
  .p-about__label {
    font-size: calc(14 * var(--to-rem));
    letter-spacing: 0.214em;
  }
}

.p-about__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(32 * var(--to-rem));
  font-weight: var(--fw-bold);
  font-feature-settings: "palt", "pwid";
  line-height: 1.3;
  color: transparent;
  letter-spacing: -0.008em;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 768px) {
  .p-about__title {
    font-size: calc(48 * var(--to-rem));
  }
}

.p-about__question {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(20 * var(--to-rem));
  font-weight: var(--fw-bold);
  font-feature-settings: "palt", "pwid";
  line-height: 1.5;
  color: #333;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-about__question {
    font-size: calc(24 * var(--to-rem));
  }
}

.p-about__text {
  display: flex;
  flex-direction: column;
  gap: calc(12 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-about__text {
    gap: calc(20 * var(--to-rem));
  }
}

.p-about__text p {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-weight: var(--fw-regular);
  font-feature-settings: "palt", "pwid";
  line-height: 1.8;
  color: #333;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-about__text p {
    font-size: calc(15 * var(--to-rem));
    line-height: calc(30 * var(--to-rem));
  }
}

.p-about__text-highlight {
  font-weight: var(--fw-regular);
  color: #ff9200;
}

.p-about__text-highlight-strong {
  font-weight: var(--fw-medium);
}

.p-benefits {
  position: relative;
  width: 100%;
  padding-top: calc(60 * var(--to-rem));
  padding-bottom: calc(60 * var(--to-rem));
  background-color: #f9f9f9;
}
@media screen and (min-width: 768px) {
  .p-benefits {
    padding-top: calc(92 * var(--to-rem));
    padding-bottom: calc(92 * var(--to-rem));
  }
}

.p-benefits__inner {
  display: flex;
  flex-direction: column;
  gap: calc(40 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-benefits__inner {
    gap: calc(56 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-benefits__inner {
    max-width: calc(1250 * var(--to-rem));
    padding-inline: calc(25 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-benefits__header {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--to-rem));
  align-items: center;
  text-align: center;
}

.p-benefits__label {
  font-family: var(--dm-mono-font-family);
  font-size: 14px;
  font-weight: var(--fw-light);
  line-height: calc(17 * var(--to-rem));
  color: transparent;
  text-transform: uppercase;
  letter-spacing: 3px;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 768px) {
  .p-benefits__label {
    font-size: calc(14 * var(--to-rem));
    letter-spacing: 0.214em;
  }
}

.p-benefits__title {
  font-family: var(--base-font-family);
  font-size: calc(32 * var(--to-rem));
  font-weight: var(--fw-bold);
  font-feature-settings: "palt", "pwid";
  line-height: 1.5;
  color: #333;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .p-benefits__title {
    font-size: calc(40 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-benefits__title {
    font-size: calc(44 * var(--to-rem));
  }
}
@media screen and (width <= 375px) {
  .p-benefits__title {
    letter-spacing: 0;
  }
}

.p-benefits__title-highlight {
  color: transparent;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.p-benefits__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: calc(12 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-benefits__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: calc(16 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-benefits__grid {
    grid-template-columns: repeat(4, 1fr);
    gap: calc(16 * var(--to-rem));
  }
}

.p-benefits__card {
  display: flex;
  flex-direction: column;
  gap: calc(4 * var(--to-rem));
  padding-block: calc(7 * var(--to-rem)) calc(20 * var(--to-rem));
  padding-inline: calc(21 * var(--to-rem));
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: calc(12 * var(--to-rem));
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
  transform: translateY(40px);
}
.p-benefits__card.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media screen and (min-width: 768px) {
  .p-benefits__card {
    padding-block: calc(20 * var(--to-rem)) calc(40 * var(--to-rem));
    padding-inline: calc(32 * var(--to-rem));
  }
}

.p-benefits__card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.p-benefits__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(56 * var(--to-rem));
  height: calc(56 * var(--to-rem));
  background-color: rgba(255, 98, 0, 0.05);
  border-radius: calc(100 * var(--to-rem));
}

.p-benefits__icon img {
  width: calc(32 * var(--to-rem));
  height: calc(32 * var(--to-rem));
}

.p-benefits__card-number {
  font-family: var(--roboto-font-family);
  font-size: calc(64 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: calc(80 * var(--to-rem));
  color: transparent;
  text-align: right;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  opacity: 0.1;
  -webkit-text-fill-color: transparent;
}

.p-benefits__card-content {
  display: flex;
  flex-direction: column;
  gap: calc(12 * var(--to-rem));
  margin-top: calc(-12 * var(--to-rem));
  color: #333;
}
@media screen and (min-width: 768px) {
  .p-benefits__card-content {
    margin-top: calc(0 * var(--to-rem));
  }
}

.p-benefits__card-title {
  font-family: var(--base-font-family);
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-bold);
  font-feature-settings: "palt";
  line-height: calc(24 * var(--to-rem));
  color: #333;
  letter-spacing: 0;
}

.p-benefits__card-text {
  font-family: var(--base-font-family);
  font-size: 13px;
  font-weight: var(--fw-regular);
  font-feature-settings: "palt", "pwid";
  line-height: 1.9;
  color: #333;
  letter-spacing: 0.09em;
}
@media screen and (min-width: 768px) {
  .p-benefits__card-text {
    font-size: calc(13 * var(--to-rem));
    line-height: calc(24.7 * var(--to-rem));
    letter-spacing: 0;
  }
}

.p-bg-sample {
  position: relative;
  padding-block: calc(80 * var(--to-rem));
  color: var(--color-white);
  background-image: url("/static/lp/developer-festival/20260420/images/image_mv_01.C2hes_sL.webp");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

.p-bg-sample::before {
  position: absolute;
  inset: 0;
  z-index: 1;
  content: "";
  background-color: oklch(from var(--color-black) l c h/40%);
}

.p-bg-sample__inner {
  position: relative;
  z-index: 2;
}

.p-bg-sample__title {
  font-size: calc(32 * var(--to-rem));
  font-weight: var(--fw-bold);
  text-align: center;
}

.p-bg-sample__text {
  max-width: calc(800 * var(--to-rem));
  margin-block-start: calc(24 * var(--to-rem));
  margin-inline: auto;
  font-size: calc(16 * var(--to-rem));
  line-height: 1.8;
}

.p-card-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(calc(280 * var(--to-rem)), 1fr));
  gap: calc(32 * var(--to-rem));
  margin-top: calc(24 * var(--to-rem));
}

.p-companies {
  position: relative;
  width: 100%;
  padding-block: calc(60 * var(--to-rem));
  background-color: #f9f9f9;
}
@media screen and (min-width: 768px) {
  .p-companies {
    padding-block: calc(80 * var(--to-rem));
  }
}

.p-companies__inner {
  display: flex;
  flex-direction: column;
  gap: calc(30 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-companies__inner {
    gap: calc(56 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-companies__inner {
    max-width: calc(1250 * var(--to-rem));
    padding-inline: calc(25 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-companies__header {
  display: flex;
  flex-direction: column;
  gap: calc(5 * var(--to-rem));
  align-items: center;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-companies__header {
    gap: calc(16 * var(--to-rem));
  }
}

.p-companies__label {
  font-family: var(--dm-mono-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-light);
  line-height: calc(17 * var(--to-rem));
  color: transparent;
  text-transform: uppercase;
  letter-spacing: 0.36em;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 768px) {
  .p-companies__label {
    font-size: calc(14 * var(--to-rem));
    letter-spacing: 0.214em;
  }
}

.p-companies__title {
  font-family: var(--base-font-family);
  font-size: 32px;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  color: #333;
  text-align: center;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-companies__title {
    font-size: calc(40 * var(--to-rem));
    line-height: 1.5;
    text-align: left;
  }
}
@media screen and (min-width: 1024px) {
  .p-companies__title {
    font-size: calc(44 * var(--to-rem));
  }
}

.p-companies__content {
  display: flex;
  flex-direction: column;
  gap: calc(8 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-companies__content {
    gap: calc(47 * var(--to-rem));
  }
}

.p-companies__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: calc(4 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-companies__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: calc(16 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-companies__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: calc(16 * var(--to-rem));
  }
}

.p-companies__card {
  display: flex;
  flex-direction: column;
  gap: calc(12 * var(--to-rem));
  padding: calc(20 * var(--to-rem));
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: calc(12 * var(--to-rem));
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
  transform: translateY(40px);
}
.p-companies__card.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media screen and (min-width: 768px) {
  .p-companies__card {
    padding: calc(32 * var(--to-rem));
  }
}

.p-companies__card-header {
  display: flex;
  gap: calc(12 * var(--to-rem));
  align-items: center;
}

.p-companies__card-logo {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: calc(95 * var(--to-rem));
  height: calc(56 * var(--to-rem));
  padding: calc(8 * var(--to-rem));
  background-color: var(--color-white);
  border: calc(0.8 * var(--to-rem)) solid rgba(0, 0, 0, 0.07);
  border-radius: calc(4 * var(--to-rem));
}

@media screen and (min-width: 768px) {
  .p-companies__card-logo {
    padding: calc(13 * var(--to-rem));
  }
}

.p-companies__card-logo img {
  width: auto !important;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.p-companies__card-company {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
  color: #333;
}

.p-companies__card-name {
  font-family: var(--base-font-family);
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-bold);
  font-feature-settings: "palt";
  line-height: calc(24 * var(--to-rem));
  color: #333;
  letter-spacing: 0;
}

.p-companies__card-description {
  font-family: var(--base-font-family);
  font-size: calc(13 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: calc(24.7 * var(--to-rem));
  color: #333;
  letter-spacing: 0;
}

.p-companies__more {
  display: flex;
  flex-direction: column;
  gap: calc(8 * var(--to-rem));
  align-items: center;
  width: 100%;
  max-width: calc(720 * var(--to-rem));
  padding: calc(32 * var(--to-rem));
  margin-inline: auto;
  color: #333;
  text-align: center;
  background-color: var(--color-white);
  border-radius: calc(12 * var(--to-rem));
}

.p-companies__more-title {
  font-family: var(--base-font-family);
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.3;
  color: #333;
  letter-spacing: 0;
}

.p-companies__more-list {
  font-family: var(--base-font-family);
  font-size: calc(13 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: #333;
  letter-spacing: 0;
}

.p-company-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  background-color: var(--color-white);
  opacity: 0;
  transition: opacity 1s ease, transform 1s ease;
  transform: translateY(40px);
}
.p-company-slider.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.p-company-slider__marquee {
  padding-inline: 20px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-company-slider__marquee {
    padding-inline: 0;
  }
}

.p-company-slider__marquee--pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-company-slider__marquee--pc {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .p-company-slider__marquee--sp {
    display: none;
  }
}

.p-company-slider__marquee-track {
  display: flex;
  width: max-content;
  animation: marquee 12s linear infinite;
}
@media screen and (min-width: 768px) {
  .p-company-slider__marquee-track {
    animation-duration: 20s;
  }
}

.p-company-slider__marquee-list {
  display: flex;
  flex-shrink: 0;
  align-items: center;
}

.p-company-slider__marquee-list .p-company-slider__logo-item {
  margin-right: 22px;
}
@media screen and (min-width: 768px) {
  .p-company-slider__marquee-list .p-company-slider__logo-item {
    margin-right: 30px;
  }
}

@keyframes marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
.p-company-slider__logo-item {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 76px;
  height: 76px;
  overflow: hidden;
  background-color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .p-company-slider__logo-item {
    width: calc(100 * var(--to-rem));
    height: calc(100 * var(--to-rem));
  }
}
.p-company-slider__logo-item--wide {
  width: 145px;
}
@media screen and (min-width: 768px) {
  .p-company-slider__logo-item--wide {
    width: calc(190 * var(--to-rem));
  }
}

.p-company-slider__logo-item img {
  max-width: 76px;
  max-height: 76px;
  object-fit: contain;
}
@media screen and (min-width: 768px) {
  .p-company-slider__logo-item img {
    max-width: 100px;
    max-height: 100px;
  }
}

.p-company-slider__logo-item.p-company-slider__logo-item--wide img {
  max-width: 145px;
}
@media screen and (min-width: 768px) {
  .p-company-slider__logo-item.p-company-slider__logo-item--wide img {
    max-width: 190px;
  }
}

/* 横長バナー（例: UR都市機構）1696×595 相当 — --wide より幅を確保 */
.p-company-slider__logo-item--banner {
  width: 232px;
}
@media screen and (min-width: 768px) {
  .p-company-slider__logo-item--banner {
    width: calc(296 * var(--to-rem));
  }
}

.p-company-slider__logo-item.p-company-slider__logo-item--banner img {
  max-width: 232px;
}
@media screen and (min-width: 768px) {
  .p-company-slider__logo-item.p-company-slider__logo-item--banner img {
    max-width: calc(296 * var(--to-rem));
  }
}

.p-contact__complete {
  padding-block: calc(80 * var(--to-rem));
  text-align: center;
}

.p-contact__complete-title {
  font-size: calc(32 * var(--to-rem));
  font-weight: var(--fw-bold);
}
@media screen and (min-width: 768px) {
  .p-contact__complete-title {
    font-size: calc(40 * var(--to-rem));
  }
}

.p-contact__complete-text {
  margin-block-start: calc(30 * var(--to-rem));
  font-size: calc(16 * var(--to-rem));
  line-height: 1.8;
  color: var(--color-text);
}
@media screen and (min-width: 768px) {
  .p-contact__complete-text {
    font-size: calc(18 * var(--to-rem));
  }
}

.p-contact__complete-button {
  margin-block-start: calc(50 * var(--to-rem));
  margin-inline: auto;
}

.p-contact {
  padding-block: calc(72 * var(--to-rem));
}

.p-contact__form {
  margin-top: calc(64 * var(--to-rem));
}

.p-cta {
  padding-inline: calc(20 * var(--to-rem));
}

.p-cta__inner {
  display: flex;
  flex-direction: column;
  gap: calc(23 * var(--to-rem));
  max-width: calc(1198 * var(--to-rem));
  padding: calc(40 * var(--to-rem)) calc(20 * var(--to-rem));
  margin-inline: auto;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  border-radius: calc(12 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-cta__inner {
    flex-direction: row;
    gap: calc(16 * var(--to-rem));
    justify-content: space-between;
    padding: calc(78 * var(--to-rem)) calc(143 * var(--to-rem)) calc(53 * var(--to-rem));
  }
}

.p-cta__text {
  display: flex;
  flex-direction: column;
  gap: calc(15 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-cta__text {
    flex: 1;
  }
}

.p-cta__title {
  font-family: var(--base-font-family);
  font-size: 28px;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  color: #fff;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-cta__title {
    font-size: calc(48 * var(--to-rem));
    text-align: left;
  }
}

.p-cta__description {
  font-family: var(--base-font-family);
  font-size: 16px;
  font-weight: var(--fw-normal);
  line-height: 1.5;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-cta__description {
    font-size: calc(18 * var(--to-rem));
  }
}

.p-cta__right {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--to-rem));
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-cta__right {
    flex-shrink: 0;
    gap: calc(32 * var(--to-rem));
  }
}

.p-cta__stats {
  display: flex;
  gap: calc(16 * var(--to-rem));
  align-items: center;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-cta__stats {
    width: calc(327 * var(--to-rem));
  }
}

.p-cta__stat {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: calc(4 * var(--to-rem));
  align-items: center;
  justify-content: center;
  height: calc(94 * var(--to-rem));
  padding: calc(20 * var(--to-rem)) calc(8 * var(--to-rem));
  background: rgba(255, 255, 255, 0.2);
  border-radius: calc(12 * var(--to-rem));
}

.p-cta__stat-number {
  font-family: var(--base-font-family);
  font-size: calc(28 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.5;
  color: #fff;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-cta__stat-number {
    font-size: calc(36 * var(--to-rem));
    line-height: 1.1;
  }
}

.p-cta__stat-label {
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-normal);
  line-height: 1.5;
  color: #fff;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-cta__stat-label {
    font-size: calc(14 * var(--to-rem));
  }
}

.p-cta__action {
  display: flex;
  flex-direction: column;
  gap: calc(5 * var(--to-rem));
  align-items: center;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-cta__action {
    width: calc(327 * var(--to-rem));
  }
}

.p-cta__button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: calc(327 * var(--to-rem));
  height: calc(68 * var(--to-rem));
  padding: calc(14 * var(--to-rem)) calc(35 * var(--to-rem));
  text-decoration: none;
  background: #fff;
  border: 1px solid transparent;
  border-radius: calc(100 * var(--to-rem));
  transition: border-color 0.6s ease;
}
.p-cta__button:hover {
  border-color: #ffb200;
}

.p-cta__button-text {
  position: relative;
  font-family: var(--base-font-family);
  font-size: calc(18 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.3;
  color: transparent;
  background: linear-gradient(90deg, #333 0%, #333 50%, #ffb200 50.1%, #fa2942 100%);
  background-position: 0% 0%;
  background-clip: text;
  background-size: 200% 100%;
  transition: background-position 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: background-position;
  -webkit-font-smoothing: antialiased;
}
@media screen and (min-width: 768px) {
  .p-cta__button-text {
    font-size: calc(20 * var(--to-rem));
  }
}

@media (any-hover: hover) {
  .p-cta__button:hover .p-cta__button-text {
    background-position: 100% 0%;
  }
}
.p-cta__button-icon {
  position: absolute;
  top: calc(14 * var(--to-rem));
  right: calc(14 * var(--to-rem));
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: calc(40 * var(--to-rem));
  height: calc(40 * var(--to-rem));
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  border: 1px solid #fff;
  border-radius: 50%;
}
.p-cta__button-icon img {
  width: calc(20 * var(--to-rem));
  height: calc(20 * var(--to-rem));
}

.p-cta__note {
  margin-top: calc(8 * var(--to-rem));
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-normal);
  line-height: 1.3;
  color: #fff;
  text-align: center;
}

.p-faq {
  position: relative;
  width: 100%;
  padding-block: calc(60 * var(--to-rem));
  padding-bottom: calc(320 * var(--to-rem));
  background-color: #f9f9f9;
}
@media screen and (min-width: 768px) {
  .p-faq {
    padding-top: calc(90 * var(--to-rem));
    padding-bottom: calc(250 * var(--to-rem));
  }
}

.p-faq__inner {
  display: flex;
  flex-direction: column;
  gap: calc(32 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-faq__inner {
    gap: calc(56 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-faq__inner {
    max-width: calc(1250 * var(--to-rem));
    padding-inline: calc(25 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-faq__header {
  display: flex;
  flex-direction: column;
  gap: calc(4 * var(--to-rem));
  align-items: center;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-faq__header {
    gap: calc(16 * var(--to-rem));
  }
}

.p-faq__label {
  font-family: var(--dm-mono-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-light);
  line-height: calc(17 * var(--to-rem));
  color: transparent;
  text-transform: uppercase;
  letter-spacing: 0.214em;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 768px) {
  .p-faq__label {
    font-size: calc(14 * var(--to-rem));
  }
}

.p-faq__title {
  font-family: var(--base-font-family);
  font-size: calc(32 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.5;
  color: #333;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-faq__title {
    font-size: calc(40 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-faq__title {
    font-size: calc(44 * var(--to-rem));
  }
}

.p-faq__list {
  display: flex;
  flex-direction: column;
  gap: calc(12 * var(--to-rem));
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .p-faq__list {
    max-width: calc(720 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-faq__item {
  width: 100%;
  background-color: var(--color-white);
  border-radius: calc(12 * var(--to-rem));
}

.p-faq__question {
  display: flex;
  gap: calc(20 * var(--to-rem));
  align-items: center;
  padding: calc(20 * var(--to-rem));
  list-style: none;
  cursor: pointer;
  border-radius: calc(12 * var(--to-rem));
}

.p-faq__item[open] .p-faq__question {
  border-radius: calc(12 * var(--to-rem)) calc(12 * var(--to-rem)) 0 0;
}

.p-faq__question::-webkit-details-marker {
  display: none;
}

.p-faq__q-icon {
  position: relative;
  display: inline-grid;
  flex-shrink: 0;
  grid-template-rows: max-content;
  grid-template-columns: max-content;
  place-items: start;
  width: calc(40 * var(--to-rem));
  height: calc(40 * var(--to-rem));
  line-height: 0;
}

.p-faq__q-icon-bg {
  grid-row: 1;
  grid-column: 1;
  width: calc(40 * var(--to-rem));
  height: calc(40 * var(--to-rem));
  margin: 0;
}

.p-faq__q-text {
  grid-row: 1;
  grid-column: 1;
  margin-top: calc(2 * var(--to-rem));
  margin-left: calc(12 * var(--to-rem));
  font-family: Poppins, sans-serif;
  font-size: calc(20 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.8;
  color: var(--color-white);
  letter-spacing: 0;
  white-space: nowrap;
}

.p-faq__q-text-content {
  flex: 1;
  min-width: 0;
  font-family: var(--base-font-family);
  font-size: 16px;
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: #1e2a41;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-faq__q-text-content {
    font-size: calc(16 * var(--to-rem));
  }
}

.p-faq__toggle {
  position: relative;
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: calc(30 * var(--to-rem));
  height: calc(30 * var(--to-rem));
  font-family: "Space Mono", var(--base-font-family);
  font-weight: var(--fw-bold);
  line-height: 1.8;
  color: #1e2a41;
  text-align: center;
  letter-spacing: 0;
}

.p-faq__item[open] .p-faq__toggle::before {
  font-size: calc(16 * var(--to-rem));
  content: "ー";
}

.p-faq__item:not([open]) .p-faq__toggle::before {
  font-size: calc(20 * var(--to-rem));
  content: "＋";
}

.p-faq__answer {
  display: flex;
  align-items: center;
  padding-block: 0 calc(20 * var(--to-rem));
  padding-inline: calc(80 * var(--to-rem)) calc(20 * var(--to-rem));
  border-bottom: 1px solid #eaf0f6;
  border-radius: 0 0 calc(12 * var(--to-rem)) calc(12 * var(--to-rem));
}

.p-faq__answer p {
  flex: 1;
  min-width: 0;
  font-family: var(--base-font-family);
  font-size: 14px;
  font-weight: var(--fw-regular);
  line-height: 1.7;
  color: rgba(30, 42, 65, 0.6);
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-faq__answer p {
    font-size: calc(14 * var(--to-rem));
  }
}

.p-footer {
  padding-block: calc(32 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
  background-color: #fff;
}

.p-footer__inner {
  display: flex;
  flex-direction: column;
  gap: calc(2 * var(--to-rem));
  align-items: center;
  max-width: calc(1200 * var(--to-rem));
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-footer__inner {
    flex-direction: row;
    gap: calc(16 * var(--to-rem));
    align-items: center;
    justify-content: space-between;
  }
}

.p-footer__company {
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-normal);
  line-height: 1.5;
  color: rgba(51, 51, 51, 0.6);
  text-align: center;
}

.p-footer__contact {
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-normal);
  line-height: 1.5;
  color: #333;
  text-align: center;
}

.p-form {
  --_form-color-text: var(--color-text);
  --_form-color-bg: var(--color-white);
  --_form-color-badge-text: var(--color-white);
  --_form-color-badge-bg: var(--color-orange);
  --_form-color-accent: var(--color-accent);
  --_form-color-border: var(--color-border-gray);
  --_form-color-primary: var(--color-primary);
  max-width: calc(800 * var(--to-rem));
  margin-inline: auto;
}
.p-form > * {
  margin-block-start: calc(40 * var(--to-rem));
}
.p-form > *:nth-last-child(2) {
  margin-block-start: calc(20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-form > * {
    margin-block-start: calc(48 * var(--to-rem));
  }
  .p-form > *:nth-last-child(2) {
    margin-block-start: calc(24 * var(--to-rem));
  }
}

.p-form__item {
  display: grid;
  gap: calc(8 * var(--to-rem));
}

.p-form__label {
  display: block;
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-bold);
  color: var(--_form-color-text);
}

.p-form__label--required {
  position: relative;
  padding-inline-end: calc(50 * var(--to-rem));
}

.p-form__label--required::after {
  position: absolute;
  top: 50%;
  right: 0;
  padding-block: calc(8 * var(--to-rem));
  padding-inline: calc(16 * var(--to-rem));
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1;
  color: var(--_form-color-badge-text);
  content: "必須";
  background-color: var(--_form-color-badge-bg);
  border-radius: 4px;
  translate: 0 -50%;
}

.p-form__input,
.p-form__select,
.p-form__textarea {
  width: 100%;
  padding: calc(14 * var(--to-rem)) calc(16 * var(--to-rem));
  font-size: calc(16 * var(--to-rem));
  line-height: 1.5;
  color: var(--_form-color-text);
  background-color: var(--_form-color-bg);
  border: 1px solid var(--_form-color-border);
  border-radius: 8px;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.p-form__input::placeholder,
.p-form__select::placeholder,
.p-form__textarea::placeholder {
  color: oklch(from var(--_form-color-text) l c h/50%);
}

.p-form__input:focus,
.p-form__select:focus,
.p-form__textarea:focus {
  border-color: var(--_form-color-accent);
  outline: none;
  box-shadow: 0 0 0 3px oklch(from var(--_form-color-accent) l c h/10%);
}

.p-form__input:hover:not(:focus),
.p-form__select:hover:not(:focus),
.p-form__textarea:hover:not(:focus) {
  border-color: var(--_form-color-accent);
  opacity: 0.7;
}

.p-form__input.is-error,
.p-form__select.is-error,
.p-form__textarea.is-error {
  border-color: var(--_form-color-badge-bg);
}

@media screen and (min-width: 768px) {
  .p-form__input,
  .p-form__select,
  .p-form__textarea {
    padding: calc(16 * var(--to-rem)) calc(20 * var(--to-rem));
  }
}
.p-form__select {
  position: relative;
  padding-inline-end: calc(48 * var(--to-rem));
  appearance: none;
  cursor: pointer;
}

.p-form__select-wrap {
  position: relative;
}

.p-form__select-wrap::after {
  position: absolute;
  top: 50%;
  right: calc(16 * var(--to-rem));
  width: calc(12 * var(--to-rem));
  height: calc(8 * var(--to-rem));
  clip-path: var(--clip-triangle-bottom);
  pointer-events: none;
  content: "";
  background-color: var(--_form-color-primary);
  border: none;
  translate: 0 -50%;
}

.p-form__textarea {
  min-height: calc(160 * var(--to-rem));
}

.p-form__radio-group {
  display: flex;
  flex-direction: column;
  gap: calc(8 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-form__radio-group {
    flex-flow: row wrap;
    gap: calc(32 * var(--to-rem)) calc(40 * var(--to-rem));
  }
}

.p-form__radio {
  display: flex;
  align-items: center;
  cursor: pointer;
}

.p-form__radio input[type=radio] {
  position: relative;
  width: calc(20 * var(--to-rem));
  height: calc(20 * var(--to-rem));
  margin: 0;
  margin-inline-end: calc(16 * var(--to-rem));
  appearance: none;
  cursor: pointer;
  border: 2px solid var(--_form-color-border);
  border-radius: 50%;
  transition: border-color 0.2s ease;
}

.p-form__radio input[type=radio]:checked {
  background-color: var(--_form-color-accent);
  border-color: var(--_form-color-accent);
}

.p-form__radio input[type=radio]:checked::after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(8 * var(--to-rem));
  height: calc(8 * var(--to-rem));
  content: "";
  background-color: var(--_form-color-bg);
  border-radius: 50%;
  translate: -50% -50%;
}

.p-form__radio input[type=radio]:hover:not(:checked) {
  border-color: var(--_form-color-accent);
  opacity: 0.5;
}

.p-form__radio input[type=radio]:focus {
  outline: none;
  box-shadow: 0 0 0 3px oklch(from var(--_form-color-accent) l c h/10%);
}

.p-form__radio-text {
  font-size: calc(16 * var(--to-rem));
  color: var(--_form-color-text);
  user-select: none;
}

.p-form__checkbox {
  display: flex;
  align-items: center;
  cursor: pointer;
}

.p-form__checkbox input[type=checkbox] {
  position: relative;
  width: calc(20 * var(--to-rem));
  height: calc(20 * var(--to-rem));
  margin: 0;
  margin-inline-end: calc(8 * var(--to-rem));
  appearance: none;
  cursor: pointer;
  border: 2px solid var(--_form-color-border);
  border-radius: 4px;
  transition: border-color 0.2s ease;
}

.p-form__checkbox input[type=checkbox]:checked {
  background-color: var(--_form-color-accent);
  border-color: var(--_form-color-accent);
}

.p-form__checkbox input[type=checkbox]:checked::after {
  position: absolute;
  top: calc(2 * var(--to-rem));
  left: calc(5 * var(--to-rem));
  width: calc(6 * var(--to-rem));
  height: calc(10 * var(--to-rem));
  content: "";
  border: 2px solid var(--_form-color-bg);
  border-top: none;
  border-left: none;
  rotate: 45deg;
}

.p-form__checkbox input[type=checkbox]:hover:not(:checked) {
  border-color: var(--_form-color-accent);
  opacity: 0.5;
}

.p-form__checkbox input[type=checkbox]:focus {
  outline: none;
  box-shadow: 0 0 0 3px oklch(from var(--_form-color-accent) l c h/10%);
}

.p-form__checkbox-text {
  font-size: calc(16 * var(--to-rem));
  color: var(--_form-color-text);
  user-select: none;
}

.p-form__link {
  color: var(--_form-color-accent);
  text-decoration: underline;
  transition: opacity 0.2s ease;
}
@media (any-hover: hover) {
  .p-form__link:hover {
    opacity: 0.8;
  }
}

.p-form__button-wrap {
  text-align: center;
}

.p-form__error {
  display: block;
  font-size: calc(14 * var(--to-rem));
  color: var(--_form-color-badge-bg);
}

.p-form__success {
  padding: calc(24 * var(--to-rem));
  font-size: calc(16 * var(--to-rem));
  color: var(--_form-color-accent);
  text-align: center;
  background-color: rgba(64, 143, 149, 0.1);
  border: 1px solid var(--_form-color-accent);
  border-radius: calc(8 * var(--to-rem));
}

.p-header {
  position: fixed;
  top: calc(16 * var(--to-rem));
  left: 50%;
  z-index: var(--z-index-header);
  width: calc(100% - 32 * var(--to-rem));
  max-width: calc(1312 * var(--to-rem));
  height: calc(56 * var(--to-rem));
  background-color: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(4px);
  border-bottom: 0.8px solid rgba(255, 255, 255, 0.06);
  border-radius: calc(8 * var(--to-rem));
  box-shadow: 0 calc(12 * var(--to-rem)) calc(24 * var(--to-rem)) 0 rgba(200, 160, 74, 0.08);
  opacity: 0;
  transition: opacity 0.8s ease;
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .p-header {
    top: calc(24 * var(--to-rem));
    height: calc(64 * var(--to-rem));
    background-color: rgb(255, 255, 255);
    backdrop-filter: blur(10px);
  }
}
@media screen and (min-width: 1024px) {
  .p-header {
    width: calc(1312 * var(--to-rem));
  }
}

.p-header.is-visible {
  opacity: 1;
}

.p-header.is-scrolled {
  background-color: rgba(255, 255, 255, 0.85);
}

.p-header__inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: inherit;
  padding-inline: calc(12 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-header__inner {
    padding-right: calc(8 * var(--to-rem));
    padding-left: calc(32 * var(--to-rem));
  }
}

.p-header__logo {
  display: flex;
  gap: calc(8 * var(--to-rem));
  align-items: center;
  font-family: "Roboto Condensed", sans-serif;
  font-size: calc(20 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1.2;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-header__logo {
    font-size: calc(24 * var(--to-rem));
  }
}
@media screen and (width <= 375px) {
  .p-header__logo {
    font-size: calc(18 * var(--to-rem));
  }
}

.p-header__logo a {
  text-decoration: none;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.p-header__brand {
  position: relative;
  display: flex;
  flex-shrink: 0;
  align-items: center;
  width: calc(88 * var(--to-rem));
  height: calc(24 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-header__brand {
    gap: calc(6 * var(--to-rem));
    width: auto;
    height: auto;
    margin-left: calc(12 * var(--to-rem));
  }
}

.p-header__brand-text {
  position: absolute;
  top: calc(7.54 * var(--to-rem));
  left: 0;
  font-family: var(--base-font-family);
  font-size: calc(10 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.3;
  color: #666;
}
@media screen and (min-width: 768px) {
  .p-header__brand-text {
    position: static;
    top: auto;
    font-size: calc(12 * var(--to-rem));
  }
}

.p-header__brand-logo-wrap {
  display: block;
  flex-shrink: 0;
  width: calc(74 * var(--to-rem));
  height: calc(24 * var(--to-rem));
  margin-left: calc(14 * var(--to-rem));
  overflow: hidden;
  border-radius: calc(2.483 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-header__brand-logo-wrap {
    margin-left: 0;
    border-radius: 0;
  }
}
@media screen and (width <= 375px) {
  .p-header__brand-logo-wrap {
    width: calc(68 * var(--to-rem));
    height: calc(20 * var(--to-rem));
  }
}

.p-header__brand-logo {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-header__nav {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-header__nav {
    display: block;
    flex: 1;
    margin-left: calc(40 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-header__nav {
    margin-left: calc(80 * var(--to-rem));
  }
}

.p-header__nav-list {
  display: flex;
  gap: calc(20 * var(--to-rem));
  align-items: center;
  height: calc(27.2 * var(--to-rem));
}
@media screen and (min-width: 1024px) {
  .p-header__nav-list {
    gap: calc(36 * var(--to-rem));
  }
}

.p-header__nav-item a {
  position: relative;
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: calc(20.4 * var(--to-rem));
  color: transparent;
  text-decoration: none;
  letter-spacing: 0.05em;
  white-space: nowrap;
  background: linear-gradient(90deg, #666 0%, #666 50%, #ffb200 50.1%, #fa2942 100%);
  background-position: 0% 0%;
  background-clip: text;
  background-size: 200% 100%;
  transition: background-position 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: background-position;
  -webkit-font-smoothing: antialiased;
}

@media (any-hover: hover) {
  .p-header__nav-item a:hover {
    background-position: 100% 0%;
  }
}
.p-header__entry-button {
  position: relative;
  box-sizing: border-box;
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: calc(74 * var(--to-rem));
  height: calc(32 * var(--to-rem));
  padding-block: 0;
  padding-inline: calc(16 * var(--to-rem));
  font-family: "DM Mono", monospace;
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: calc(16 * var(--to-rem));
  color: var(--color-white);
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  border-radius: calc(4 * var(--to-rem));
}
.p-header__entry-button::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  content: "";
  background: linear-gradient(90deg, #fa2942 0%, #ffb200 100%);
  border-radius: calc(4 * var(--to-rem));
  opacity: 0;
  transition: opacity 0.6s ease;
}
.p-header__entry-button span {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .p-header__entry-button {
    width: calc(145 * var(--to-rem));
    height: calc(48 * var(--to-rem));
    padding: calc(9 * var(--to-rem)) calc(20 * var(--to-rem));
    font-size: calc(20 * var(--to-rem));
    line-height: 0.9;
    letter-spacing: 0.03em;
  }
}

@media (any-hover: hover) {
  .p-header__entry-button:hover::before {
    opacity: 1;
  }
}
.p-header__hamburger {
  position: relative;
  z-index: 999;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: calc(44 * var(--to-rem));
  height: calc(44 * var(--to-rem));
  padding: 0;
  margin: 0;
  cursor: pointer;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  border: none;
  border-radius: calc(4 * var(--to-rem));
  outline: none;
  transition: opacity var(--duration);
}

@media (any-hover: hover) {
  .p-header__hamburger:hover {
    opacity: 0.85;
  }
}
.p-header__hamburger span {
  position: relative;
  display: block;
  width: calc(20 * var(--to-rem));
  height: 2px;
  background-color: var(--color-white);
  transition: top calc(var(--duration) * 1.67), opacity calc(var(--duration) * 1.67), rotate calc(var(--duration) * 1.67);
}

.p-header__hamburger span:nth-of-type(1) {
  top: 0;
  margin-bottom: calc(4 * var(--to-rem));
}

.p-header__hamburger span:nth-of-type(2) {
  top: 0;
  margin-bottom: calc(4 * var(--to-rem));
}

.p-header__hamburger span:nth-of-type(3) {
  top: 0;
}

.p-header__hamburger.is-open span:nth-of-type(1) {
  top: calc(6 * var(--to-rem));
  rotate: 45deg;
}

.p-header__hamburger.is-open span:nth-of-type(2) {
  opacity: 0;
}

.p-header__hamburger.is-open span:nth-of-type(3) {
  top: calc(-6 * var(--to-rem));
  rotate: -45deg;
}

.p-header__drawer {
  position: fixed;
  top: var(--header-height);
  left: 0;
  z-index: 899;
  display: none;
  width: 100%;
  height: calc(100svh - var(--header-height));
  padding: calc(32 * var(--to-rem)) calc(16 * var(--to-rem));
  overflow-y: auto;
  background-color: rgba(255, 255, 255, 0.98);
  scrollbar-width: none;
}

.p-header__drawer::-webkit-scrollbar {
  display: none;
}

.p-header__drawer-list {
  display: flex;
  flex-direction: column;
  gap: calc(24 * var(--to-rem));
}

.p-header__drawer-item a {
  display: block;
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.7;
  color: #666;
  text-decoration: none;
  letter-spacing: 0.05em;
}

.p-header__drawer-item.p-header__drawer-item--entry {
  margin-top: calc(16 * var(--to-rem));
}

.p-header__drawer-item.p-header__drawer-item--entry a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: calc(200 * var(--to-rem));
  height: calc(48 * var(--to-rem));
  padding: calc(12 * var(--to-rem)) calc(20 * var(--to-rem));
  font-family: var(--dm-mono-font-family);
  font-size: calc(18 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1;
  color: var(--color-white);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  border-radius: calc(4 * var(--to-rem));
}

.p-mv {
  position: relative;
  width: 100%;
  height: calc(576 * var(--to-rem));
  overflow: hidden;
  background-color: #005eb8;
  isolation: isolate;
  mask-image: radial-gradient(white, black);
  transform: translate3d(0, 0, 0);
}
@media screen and (min-width: 768px) {
  .p-mv {
    height: calc(700 * var(--to-rem));
  }
}

.p-mv__inner {
  position: relative;
  width: 100%;
  height: 100%;
}

.p-mv__intro-overlay {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: calc(24 * var(--to-rem));
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100vh;
  pointer-events: none;
  opacity: 1;
}
.p-mv__intro-overlay::before {
  position: absolute;
  inset: 0;
  z-index: -1;
  content: "";
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 50%, #fa2942 100%);
  background-position: 100% 0%;
  background-size: 200% 100%;
  transition: transform 1s cubic-bezier(0.65, 0, 0.35, 1);
  transform: translate3d(0, 0, 0);
  animation: gradient-slide 1.5s ease forwards;
  will-change: transform;
  backface-visibility: hidden;
}
.p-mv__intro-overlay .p-mv__text-wrap--intro {
  visibility: hidden;
  opacity: 1;
  transition: opacity 0.8s ease, visibility 0s;
}
.p-mv__intro-overlay.is-fonts-ready .p-mv__text-wrap--intro {
  visibility: visible;
}
.p-mv__intro-overlay .p-mv__sub-title {
  background: none;
  -webkit-text-fill-color: #fff;
}

.p-mv__intro-overlay.is-hidden {
  pointer-events: none;
}
.p-mv__intro-overlay.is-hidden::before {
  transform: translateX(100%);
}
.p-mv__intro-overlay.is-hidden .p-mv__text-wrap--intro {
  opacity: 0;
}

.p-mv__text-wrap,
.p-mv__text-wrap--intro {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--to-rem));
  align-items: center;
  width: 100%;
  text-align: center;
}

.p-mv__text-wrap--intro {
  position: relative;
  flex-shrink: 0;
  width: calc(100% - 40px);
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-mv__text-wrap--intro {
    width: max-content;
    padding-inline: 0;
  }
}

.p-mv__intro-by {
  position: absolute;
  right: 0;
  bottom: calc(-40 * var(--to-rem));
  display: flex;
  gap: calc(8 * var(--to-rem));
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-mv__intro-by {
    right: 0;
    bottom: calc(-60 * var(--to-rem));
    gap: calc(11 * var(--to-rem));
  }
}

.p-mv__intro-by-text {
  font-family: var(--base-font-family);
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.3;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-mv__intro-by-text {
    font-size: calc(24 * var(--to-rem));
  }
}

.p-mv__intro-by-logo {
  width: calc(93 * var(--to-rem));
  height: calc(30 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-mv__intro-by-logo {
    width: calc(139.057 * var(--to-rem));
    height: calc(44.1 * var(--to-rem));
  }
}

.p-mv__bg-image {
  position: absolute;
  inset: -20px;
  z-index: 1;
  width: calc(100% + 40px);
  height: calc(100% + 40px);
  overflow: hidden;
  transition: filter 0.8s ease;
  transform: scale(1.1);
  backface-visibility: hidden;
}

.p-mv__bg-image.is-blurred {
  filter: blur(8px) brightness(0.8);
}

.p-mv__bg-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-mv__content {
  position: absolute;
  top: calc(127 * var(--to-rem));
  left: 50%;
  z-index: 2;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: calc(24 * var(--to-rem));
  align-items: center;
  width: 100%;
  padding-inline: calc(24 * var(--to-rem));
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .p-mv__content {
    gap: 0;
    width: 90%;
    max-width: calc(855 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-mv__content {
    top: calc(142 * var(--to-rem));
    left: 50%;
    width: calc(855 * var(--to-rem));
    max-width: calc(855 * var(--to-rem));
    margin-left: calc(-720 * var(--to-rem) + 292 * var(--to-rem));
    transform: none;
  }
}

.p-mv__content .p-mv__text-wrap {
  max-width: 100%;
  opacity: 0;
  transition: opacity 0.8s ease;
}
@media screen and (min-width: 768px) {
  .p-mv__content .p-mv__text-wrap {
    max-width: none;
  }
}

.p-mv__content .p-mv__text-wrap.is-visible {
  opacity: 1;
}

.p-mv__catchcopy {
  flex-shrink: 0;
  width: 100%;
  min-width: 0;
  margin: 0;
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: var(--color-white);
  text-transform: uppercase;
  letter-spacing: calc(1 * var(--to-rem));
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .p-mv__catchcopy {
    font-size: calc(20 * var(--to-rem));
    line-height: calc(30 * var(--to-rem));
    letter-spacing: 0.11em;
  }
}

.p-mv__title-group {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  gap: 0;
  align-items: center;
  width: 100%;
  line-height: 1;
}

.p-mv__main-title {
  margin: 0;
  font-family: var(--roboto-font-family);
  font-size: calc(50 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1;
  color: var(--color-white);
  letter-spacing: calc(-2.434 * var(--to-rem));
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .p-mv__main-title {
    font-size: calc(100 * var(--to-rem));
    line-height: calc(100 * var(--to-rem));
    letter-spacing: -0.0243em;
  }
}

.p-mv__sub-title {
  margin: 0;
  font-family: var(--roboto-font-family);
  font-size: calc(50 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1;
  letter-spacing: calc(-2.434 * var(--to-rem));
  white-space: nowrap;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 768px) {
  .p-mv__sub-title {
    font-size: calc(100 * var(--to-rem));
    line-height: calc(100 * var(--to-rem));
    letter-spacing: -0.0243em;
  }
}

.p-mv__description {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  gap: 0;
  align-items: center;
  width: 100%;
  min-width: 0;
  margin: 0;
  font-family: var(--base-font-family);
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: var(--color-white);
  text-transform: uppercase;
  letter-spacing: calc(1 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-mv__description {
    display: block;
    line-height: calc(21 * var(--to-rem));
    text-align: center;
    letter-spacing: 0.157em;
  }
}

.p-mv__description-line {
  margin: 0;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-mv__description-line {
    display: block;
  }
}

.p-mv__entry-button {
  position: relative;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: calc(327 * var(--to-rem));
  height: calc(64 * var(--to-rem));
  padding: calc(9 * var(--to-rem)) calc(20 * var(--to-rem));
  margin-top: 0;
  margin-right: auto;
  margin-left: auto;
  text-decoration: none;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  border-radius: calc(100 * var(--to-rem));
  opacity: 0;
  transition: opacity 0.8s ease;
}
@media screen and (min-width: 768px) {
  .p-mv__entry-button {
    gap: 0;
    width: calc(445 * var(--to-rem));
    max-width: calc(445 * var(--to-rem));
    height: calc(80 * var(--to-rem));
    margin-top: calc(32 * var(--to-rem));
  }
}

.p-mv__entry-button::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  background: linear-gradient(90deg, #fa2942 0%, #ffb200 100%);
  border-radius: calc(100 * var(--to-rem));
  opacity: 0;
  transition: opacity 0.6s ease;
}

.p-mv__entry-button.is-visible {
  opacity: 1;
}

@media (any-hover: hover) {
  .p-mv__entry-button.is-visible:hover::before {
    opacity: 1;
  }
}
.p-mv__entry-badge,
.p-mv__entry-text,
.p-mv__entry-icon {
  z-index: 1;
}

.p-mv__entry-badge {
  position: absolute;
  top: calc(4 * var(--to-rem));
  left: calc(4 * var(--to-rem));
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(56 * var(--to-rem));
  height: calc(56 * var(--to-rem));
  font-family: var(--base-font-family);
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.3;
  text-transform: uppercase;
  letter-spacing: 0;
  background: var(--color-white);
  border-radius: calc(100 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-mv__entry-badge {
    top: calc(2 * var(--to-rem));
    left: calc(2 * var(--to-rem));
    width: calc(76 * var(--to-rem));
    height: calc(76 * var(--to-rem));
    font-size: calc(19.666 * var(--to-rem));
  }
}

.p-mv__entry-badge::before {
  content: "先着順";
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.p-mv__entry-text {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  gap: calc(2 * var(--to-rem));
  align-items: center;
  justify-content: center;
  width: auto;
  max-width: calc(200 * var(--to-rem));
  height: auto;
  padding: 0;
  color: var(--color-white);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-mv__entry-text {
    position: absolute;
    top: calc(15.5 * var(--to-rem));
    left: calc(114.5 * var(--to-rem));
    width: calc(216 * var(--to-rem));
    max-width: none;
    height: calc(49 * var(--to-rem));
  }
}

.p-mv__entry-main {
  font-family: var(--base-font-family);
  font-size: calc(18 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.3;
  text-transform: uppercase;
  letter-spacing: 0;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .p-mv__entry-main {
    font-size: calc(24 * var(--to-rem));
    line-height: calc(31 * var(--to-rem));
  }
}

.p-mv__entry-sub {
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.3;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-mv__entry-sub {
    font-size: calc(12 * var(--to-rem));
    line-height: calc(16 * var(--to-rem));
  }
}

.p-mv__entry-icon {
  position: absolute;
  top: calc(12 * var(--to-rem));
  right: calc(12 * var(--to-rem));
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(40 * var(--to-rem));
  height: calc(40 * var(--to-rem));
  color: var(--color-white);
  border: 1px solid var(--color-white);
  border-radius: calc(24 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-mv__entry-icon {
    top: calc(20 * var(--to-rem));
    right: calc(20 * var(--to-rem));
    border-radius: 50%;
  }
}

.p-mv__entry-icon-img {
  display: block;
  flex-shrink: 0;
  width: calc(24 * var(--to-rem));
  height: calc(24 * var(--to-rem));
  object-fit: contain;
}

.p-mv__info-tags {
  display: flex;
  flex-wrap: wrap;
  gap: calc(8 * var(--to-rem));
  place-content: center center;
  align-items: center;
  width: 100%;
  margin-top: 0;
  opacity: 0;
  transition: opacity 0.8s ease;
}
@media screen and (min-width: 768px) {
  .p-mv__info-tags {
    align-content: flex-start;
    width: calc(560 * var(--to-rem));
    margin-top: calc(32 * var(--to-rem));
  }
}

.p-mv__info-tags.is-visible {
  opacity: 1;
}

.p-mv__info-tag {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  padding: calc(4 * var(--to-rem)) calc(8 * var(--to-rem));
  background-color: rgba(0, 0, 0, 0.2);
  border-radius: calc(4 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-mv__info-tag {
    justify-content: flex-start;
    height: calc(40 * var(--to-rem));
    padding: calc(8 * var(--to-rem)) calc(16 * var(--to-rem));
  }
}

.p-mv__info-tag p {
  margin: 0;
  font-family: var(--base-font-family);
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: 1.5;
  color: var(--color-white);
  letter-spacing: 0;
  white-space: nowrap;
}
@media screen and (min-width: 768px) {
  .p-mv__info-tag p {
    line-height: calc(23.8 * var(--to-rem));
  }
}

@keyframes gradient-slide {
  0% {
    background-position: 100% 0%;
  }
  100% {
    background-position: 0% 0%;
  }
}
.p-overview {
  position: relative;
  width: 100%;
  padding-block: calc(60 * var(--to-rem));
  background-color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .p-overview {
    padding-block: calc(80 * var(--to-rem));
  }
}

.p-overview__inner {
  padding-inline: calc(20 * var(--to-rem));
}
@media screen and (min-width: 1024px) {
  .p-overview__inner {
    max-width: calc(1120 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-overview__container {
  display: flex;
  flex-direction: column;
  gap: calc(32 * var(--to-rem));
}
@media screen and (min-width: 1024px) {
  .p-overview__container {
    flex-direction: row;
    gap: calc(81 * var(--to-rem));
  }
}

.p-overview__left {
  display: contents;
}
@media screen and (min-width: 1024px) {
  .p-overview__left {
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    gap: calc(52 * var(--to-rem));
    width: calc(378 * var(--to-rem));
  }
}

.p-overview__header {
  display: flex;
  flex-direction: column;
  gap: calc(9 * var(--to-rem));
  align-items: center;
  order: 0;
  text-align: center;
}
@media screen and (min-width: 1024px) {
  .p-overview__header {
    gap: calc(16 * var(--to-rem));
    align-items: flex-start;
    order: unset;
    text-align: left;
  }
}

.p-overview__label {
  font-family: var(--dm-mono-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-light);
  line-height: calc(17 * var(--to-rem));
  color: transparent;
  text-transform: uppercase;
  letter-spacing: 0.35em;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 768px) {
  .p-overview__label {
    font-size: calc(14 * var(--to-rem));
    letter-spacing: 0.214em;
  }
}

.p-overview__title {
  font-family: var(--base-font-family);
  font-size: calc(32 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.5;
  color: #333;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-overview__title {
    font-size: calc(40 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-overview__title {
    font-size: calc(44 * var(--to-rem));
  }
}

.p-overview__image {
  order: 2;
  width: 100%;
  overflow: hidden;
  border-radius: calc(12 * var(--to-rem));
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
  transform: translateY(40px);
}
.p-overview__image.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media screen and (min-width: 1024px) {
  .p-overview__image {
    order: unset;
    width: calc(378 * var(--to-rem));
    height: calc(281 * var(--to-rem));
  }
}

.p-overview__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-overview__right {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: calc(8 * var(--to-rem));
  order: 1;
}
@media screen and (min-width: 1024px) {
  .p-overview__right {
    order: unset;
  }
}

.p-overview__item {
  display: flex;
  gap: calc(12 * var(--to-rem));
  align-items: center;
  padding: calc(12 * var(--to-rem));
  background-color: #f9f9f9;
  border-radius: calc(12 * var(--to-rem));
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
  transform: translateY(40px);
}
.p-overview__item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.p-overview__item-icon {
  position: relative;
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: calc(56 * var(--to-rem));
  height: calc(56 * var(--to-rem));
  background-color: var(--color-white);
  border-radius: calc(8 * var(--to-rem));
}

.p-overview__item-icon img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(20 * var(--to-rem));
  height: calc(20 * var(--to-rem));
  transform: translate(-50%, calc(-50% - 9px));
}

.p-overview__item-icon-label {
  position: absolute;
  top: calc(39 * var(--to-rem));
  left: calc(15 * var(--to-rem));
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.3;
  color: #333;
  letter-spacing: 0;
  white-space: nowrap;
  transform: translateY(-50%);
}

.p-overview__item-content {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
}

.p-overview__item-main {
  font-family: var(--base-font-family);
  font-size: 16px;
  font-weight: var(--fw-regular);
  font-feature-settings: "palt" on;
  line-height: 1.5;
  color: #333;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-overview__item-main {
    font-size: calc(16 * var(--to-rem));
  }
}

.p-overview__item-sub {
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: #888;
  letter-spacing: 0;
}

.p-program {
  position: relative;
  width: 100%;
  padding-top: calc(60 * var(--to-rem));
  padding-bottom: calc(60 * var(--to-rem));
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
}
@media screen and (min-width: 768px) {
  .p-program {
    padding-top: calc(80 * var(--to-rem));
    padding-bottom: calc(88 * var(--to-rem));
  }
}

.p-program__inner {
  display: flex;
  flex-direction: column;
  gap: calc(28 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-program__inner {
    gap: calc(56 * var(--to-rem));
  }
}
@media screen and (min-width: 1024px) {
  .p-program__inner {
    max-width: calc(1250 * var(--to-rem));
    padding-inline: calc(25 * var(--to-rem));
    margin-inline: auto;
  }
}

.p-program__header {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--to-rem));
  align-items: center;
  text-align: center;
}

.p-program__label {
  font-family: var(--dm-mono-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-light);
  line-height: calc(17 * var(--to-rem));
  color: var(--color-white);
  text-transform: uppercase;
  letter-spacing: 0.3em;
}
@media screen and (min-width: 768px) {
  .p-program__label {
    font-size: calc(14 * var(--to-rem));
    letter-spacing: 0.214em;
  }
}

.p-program__title {
  font-family: var(--base-font-family);
  font-size: 32px;
  font-weight: var(--fw-bold);
  font-feature-settings: "palt", "pwid";
  line-height: 1.3;
  color: var(--color-white);
  text-align: center;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-program__title {
    font-size: calc(40 * var(--to-rem));
    line-height: 1.5;
    letter-spacing: 0.05em;
  }
}
@media screen and (min-width: 1024px) {
  .p-program__title {
    font-size: calc(44 * var(--to-rem));
  }
}

.p-program__content {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--to-rem));
  align-items: center;
}

.p-program__cards {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--to-rem));
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .p-program__cards {
    flex-direction: row;
    gap: calc(16 * var(--to-rem));
    justify-content: center;
  }
}

.p-program__card {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: calc(12 * var(--to-rem));
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
  transform: translateY(40px);
}
.p-program__card.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media screen and (min-width: 1024px) {
  .p-program__card {
    width: calc(592 * var(--to-rem));
  }
}

.p-program__card-header {
  position: relative;
  width: 100%;
  height: 116px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-program__card-header {
    height: calc(210 * var(--to-rem));
  }
}

.p-program__card-header-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-program__card-info {
  display: flex;
  gap: calc(12 * var(--to-rem));
  align-items: center;
  width: 100%;
  padding-block: calc(20 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
  background-color: #fdf6e9;
}
@media screen and (min-width: 768px) {
  .p-program__card-info {
    padding-block: calc(20 * var(--to-rem));
    padding-inline: calc(32 * var(--to-rem));
  }
}

.p-program__card-icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background-color: var(--color-white);
  border-radius: 50%;
}
@media screen and (min-width: 768px) {
  .p-program__card-icon {
    width: calc(64 * var(--to-rem));
    height: calc(64 * var(--to-rem));
  }
}

.p-program__card-icon img {
  width: 22px;
  height: 22px;
}
@media screen and (min-width: 768px) {
  .p-program__card-icon img {
    width: calc(32 * var(--to-rem));
    height: calc(32 * var(--to-rem));
  }
}

.p-program__card-date {
  display: flex;
  flex-direction: column;
  gap: calc(4 * var(--to-rem));
}

.p-program__card-day {
  font-family: var(--base-font-family);
  font-size: calc(20 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1;
  color: transparent;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.p-program__card-datetime {
  font-family: var(--base-font-family);
  font-weight: var(--fw-bold);
  font-feature-settings: "palt";
  line-height: 1;
  color: transparent;
  background: linear-gradient(90deg, #ffb200 0%, #fa2942 100%);
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.p-program__card-datetime-large {
  font-size: calc(24 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-program__card-datetime-large {
    font-size: calc(32 * var(--to-rem));
  }
}

.p-program__card-datetime-small {
  font-size: calc(18 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-program__card-datetime-small {
    font-size: calc(24 * var(--to-rem));
  }
}

.p-program__card-body {
  display: flex;
  flex-direction: column;
  gap: calc(12 * var(--to-rem));
  padding-block: calc(24 * var(--to-rem));
  padding-inline: calc(20 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-program__card-body {
    gap: calc(24 * var(--to-rem));
    padding-inline: calc(32 * var(--to-rem));
  }
}

.p-program__card-theme {
  display: flex;
  gap: calc(12 * var(--to-rem));
  align-items: center;
}

.p-program__card-badge {
  display: inline-flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  height: calc(28 * var(--to-rem));
  padding-inline: calc(17 * var(--to-rem));
  font-family: var(--dm-mono-font-family);
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: calc(20 * var(--to-rem));
  color: #fd7020;
  border: 1px solid #fd7020;
  border-radius: 9999px;
}

.p-program__card-theme-title {
  font-family: var(--base-font-family);
  font-size: calc(18 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.5;
  color: #333;
  letter-spacing: 0;
}

.p-program__card-description {
  font-family: var(--base-font-family);
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.7;
  color: #8f8f8f;
  letter-spacing: 0;
}

.p-program__card-schedule {
  display: flex;
  flex-direction: column;
  gap: calc(12 * var(--to-rem));
  list-style: none;
}

.p-program__card-schedule-item {
  display: flex;
  gap: calc(12 * var(--to-rem));
  align-items: center;
}

.p-program__card-schedule-number {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: calc(24 * var(--to-rem));
  height: calc(24 * var(--to-rem));
  font-family: var(--dm-mono-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-medium);
  line-height: calc(16 * var(--to-rem));
  color: var(--color-white);
  text-align: center;
  background-color: #fd7020;
  border-radius: 50%;
}

.p-program__card-schedule-content {
  display: flex;
  flex: 1;
  flex-flow: column wrap;
  min-width: 0;
}
@media screen and (min-width: 768px) {
  .p-program__card-schedule-content {
    flex-direction: row;
    gap: calc(8 * var(--to-rem));
    align-items: center;
  }
}

.p-program__card-schedule-title {
  flex-shrink: 0;
  font-family: var(--base-font-family);
  font-size: calc(16 * var(--to-rem));
  font-weight: var(--fw-bold);
  line-height: 1.5;
  color: #333;
  letter-spacing: 0;
  white-space: nowrap;
}

.p-program__card-schedule-detail {
  flex: 1;
  min-width: 0;
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: #8f8f8f;
  letter-spacing: 0;
}

.p-program__note {
  font-family: var(--base-font-family);
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.3;
  color: var(--color-white);
  text-align: center;
  letter-spacing: 0;
}

.p-program__card-companies {
  display: flex;
  flex-direction: column;
  gap: calc(12 * var(--to-rem));
  width: 100%;
  margin-top: calc(12 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-program__card-companies {
    margin-top: calc(0 * var(--to-rem));
  }
}

.p-program__card-companies-header {
  display: flex;
  gap: calc(8 * var(--to-rem));
  align-items: flex-start;
}

.p-program__card-companies-bar {
  flex-shrink: 0;
  align-self: stretch;
  width: calc(3 * var(--to-rem));
  height: 100%;
  min-height: calc(18 * var(--to-rem));
  background-color: #fd7020;
  border-radius: calc(100 * var(--to-rem));
}

.p-program__card-companies-label {
  font-family: var(--base-font-family);
  font-size: calc(14 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.3;
  color: #333;
  letter-spacing: 0;
  white-space: nowrap;
}

.p-program__card-companies-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, calc(89.333 * var(--to-rem)));
  gap: calc(12 * var(--to-rem));
  justify-content: center;
  width: 100%;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-program__card-companies-list {
    grid-template-columns: repeat(4, 1fr);
    gap: calc(13 * var(--to-rem));
    justify-content: start;
  }
}
@media screen and (width <= 375px) {
  .p-program__card-companies-list {
    gap: calc(6 * var(--to-rem));
  }
}

.p-program__card-company-item {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: calc(89.333 * var(--to-rem));
  height: calc(51 * var(--to-rem));
  padding: calc(2 * var(--to-rem));
  background-color: var(--color-white);
  border: calc(0.802 * var(--to-rem)) solid rgba(0, 0, 0, 0.07);
  border-radius: calc(4 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-program__card-company-item {
    width: calc(123 * var(--to-rem));
    height: calc(73 * var(--to-rem));
    padding: calc(4 * var(--to-rem));
  }
}
.p-program__card-company-item.is-horizontal {
  padding: calc(8 * var(--to-rem));
}
@media screen and (min-width: 768px) {
  .p-program__card-company-item.is-horizontal {
    padding: calc(13 * var(--to-rem));
  }
}

.p-program__card-company-item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.p-program__card-companies-more {
  grid-column: auto;
  place-self: end;
  margin-top: 0;
  margin-bottom: calc(5 * var(--to-rem));
  font-family: var(--base-font-family);
  font-size: calc(12 * var(--to-rem));
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: #8f8f8f;
  text-align: right;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .p-program__card-companies-more {
    margin-bottom: calc(5 * var(--to-rem));
  }
}

/* 下記サンプル 構築時は削除してください */
.p-sample {
  padding-block: calc(40 * var(--to-rem));
}

.p-sample__link {
  display: inline-block;
  margin-block-start: calc(40 * var(--to-rem));
  font-size: calc(24 * var(--to-rem));
  text-decoration: underline;
}

@media (any-hover: hover) {
  .p-sample__link:hover {
    text-decoration: none;
  }
}
.p-sample__bg {
  width: 300px;
  aspect-ratio: 1/1;
  background-image: image-set(url("/static/lp/developer-festival/20260420/images/bg_sample.webp") type("image/webp"), url("/static/lp/developer-festival/20260420/images/bg_sample.png") type("image/png"));
  background-size: contain;
}

.p-sample__image {
  width: 100%;
  max-width: 400px;
  aspect-ratio: 1/1;
}

.p-sample__image img {
  object-fit: cover;
  mask-image: linear-gradient(to bottom, rgb(255, 255, 255) 0%, rgba(255, 255, 255, 0.1) 100%);
}

.p-sample__text-block {
  margin-block: calc(40 * var(--to-rem));
}

.p-sample__head {
  font-size: 24px;
}
@media screen and (min-width: 768px) {
  .p-sample__head {
    font-size: 32px;
  }
}

.p-sample__text {
  height: 1.5;
  letter-spacing: 0.05em;
}

.p-sample__title2 {
  display: inline-block;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-sample__title2 {
    font-size: 24px;
  }
}

.p-sample__divider {
  margin-block: calc(16 * var(--to-rem)) calc(32 * var(--to-rem));
}

.p-sample__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(64px, 100%), 1fr));
  gap: calc(16 * var(--to-rem));
}

:root {
  --clip-triangle-top: polygon(50% 0, 100% 100%, 0 100%);
  --clip-triangle-bottom: polygon(0 0, 100% 0, 50% 100%);
  --clip-triangle-right: polygon(0 0, 100% 50%, 0 100%);
  --clip-triangle-left: polygon(0 50%, 100% 0, 100% 100%);
  --clip-triangle-lower-left: polygon(0 0, 100% 100%, 0 100%);
  --clip-triangle-upper-left: polygon(0 0, 100% 0, 0 100%);
  --clip-triangle-lower-right: polygon(100% 0, 100% 100%, 0 100%);
  --clip-triangle-upper-right: polygon(0 0, 100% 0, 100% 100%);
}

@media (width <= 767px) {
  [data-only-device=md] {
    display: none;
  }
}

@media (width >= 768px) {
  [data-only-device=sm] {
    display: none;
  }
}

.u-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  white-space: nowrap;
  border: 0;
}

.u-text__marker {
  background: linear-gradient(transparent 75%, var(--color-orange) 75%);
}

.u-text__inline-block {
  display: inline-block;
}

.u-text__indent {
  padding-inline-start: 1em;
  text-indent: -1em;
}
