/* =============================================================

properties

============================================================= */
.dr_l-root {
  /* color
  ============================== */
  --base-color: #2c2c2c;
  --key-color: #ff5848;
  --key-color-dark: color-mix(in srgb, var(--key-color) 84.4%, black);
  --point-color: #ffb411;
  --color-graduates: #ff6161;
  --color-career: #617bff;
  --bg-color: #f2f2f2;
  --border-color: #d9d9d9;
  /* gradation */
  --gradation-03: linear-gradient(106deg, #fc6076 19.52%, #ff9a44 73.18%, #ffdc69 97.58%);
  --gradation-04: linear-gradient(106deg, #46aef7 19.52%, #16d9e3 73.18%, #a2f3f9 97.58%);
  /* layouts
  ============================== */
  --inner-width-px: 1220px;
  --header-height: 90px;
  --inner-padding: 20px;
  --outer-margin: calc(50 * var(--vw) - var(--inner-width-px) * .5);
  /* utility & fonts
  ============================== */
  --vw: 1vw;
  --vh: 1vh;
  --slope-1px: clamp(0px, -.95663px + .2551vw, 1px);
  --leading-trim: calc((1em - 1lh) / 2);
  --base-font-family: 'HondaGlobalFontJP-Regular', sans-serif;
  --en-font-family: Lato, sans-serif;
  /* icon
  ============================== */
  --icon-arrow: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="30" height="30" viewBox="0 0 30 30" fill="none"><path d="M16.435 15L13.2638 18.1712C13.1171 18.3108 13.0437 18.4857 13.0437 18.6957C13.0437 18.9058 13.1154 19.0784 13.2588 19.2135C13.3975 19.3769 13.5683 19.4548 13.7712 19.4471C13.9744 19.4397 14.1528 19.3618 14.3064 19.2135L17.777 15.7724C17.9879 15.5651 18.0933 15.3097 18.0933 15.0062C18.0933 14.7027 17.9879 14.4366 17.777 14.2079L14.3291 10.76C14.1796 10.6249 13.9985 10.5546 13.7857 10.5493C13.5731 10.544 13.3975 10.6165 13.2588 10.7668C13.1154 10.9151 13.0488 11.0975 13.0591 11.314C13.0691 11.5308 13.1449 11.7034 13.2865 11.8321L16.435 15ZM15.0038 26.25C13.4571 26.25 11.9963 25.9531 10.6213 25.3593C9.24632 24.7656 8.0512 23.9615 7.03593 22.9473C6.02087 21.933 5.2194 20.7438 4.63152 19.3799C4.04384 18.0161 3.75 16.5574 3.75 15.0038C3.75 13.4471 4.04423 11.9835 4.6327 10.6131C5.22097 9.24278 6.02382 8.04776 7.04124 7.02797C8.05867 6.00818 9.25271 5.20691 10.6234 4.62414C11.994 4.04138 13.4532 3.75 15.0009 3.75C16.5558 3.75 18.0143 4.04109 19.3763 4.62326C20.7385 5.20543 21.9294 6.00612 22.949 7.02531C23.9684 8.04451 24.7734 9.23983 25.3641 10.6113C25.9547 11.9827 26.25 13.4482 26.25 15.0077C26.25 16.5638 25.955 18.0203 25.3649 19.3772C24.7747 20.7339 23.9709 21.9208 22.9534 22.9378C21.9358 23.955 20.7457 24.7613 19.3831 25.3567C18.0205 25.9522 16.5608 26.25 15.0038 26.25Z" fill="white"/></svg>');
  --icon-down: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="30" height="30" viewBox="0 0 30 30" fill="none"><path d="M14.2547 17.6188L19.7757 12.1138C19.8757 12.0031 19.9972 11.9473 20.1404 11.9463C20.2835 11.9452 20.4076 12.0026 20.5129 12.1185C20.6287 12.2345 20.6866 12.3608 20.6866 12.4975C20.6866 12.6344 20.6287 12.7607 20.5129 12.8766L14.896 18.4938C14.8008 18.5888 14.7022 18.6601 14.6004 18.7078C14.4983 18.7557 14.3831 18.7797 14.2547 18.7797C14.1372 18.7797 14.0248 18.7557 13.9175 18.7078C13.8102 18.6601 13.709 18.5888 13.6138 18.4938L7.99192 12.8719C7.89212 12.7719 7.839 12.6503 7.83254 12.5072C7.82608 12.3641 7.88087 12.2345 7.99692 12.1185C8.11275 12.0026 8.2391 11.9447 8.37598 11.9447C8.51265 11.9447 8.6389 12.0026 8.75473 12.1185L14.2547 17.6188Z" fill="white"/></svg>');
  --icon-angle: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" fill="none"><path d="M11.2458 9.99687L7.57584 6.31624C7.50209 6.24958 7.46487 6.16854 7.46418 6.07312C7.46348 5.9777 7.50175 5.89493 7.57897 5.82479C7.65633 5.74756 7.74057 5.70895 7.83168 5.70895C7.92293 5.70895 8.00716 5.74756 8.08438 5.82479L11.8292 9.56937C11.8925 9.63284 11.9401 9.69854 11.9719 9.76645C12.0038 9.83451 12.0198 9.91131 12.0198 9.99687C12.0198 10.0752 12.0038 10.1501 11.9719 10.2217C11.9401 10.2932 11.8925 10.3607 11.8292 10.4242L8.08126 14.1721C8.01459 14.2386 7.93355 14.274 7.83813 14.2783C7.74272 14.2826 7.65633 14.2461 7.57897 14.1687C7.50175 14.0915 7.46313 14.0073 7.46313 13.916C7.46313 13.8249 7.50175 13.7408 7.57897 13.6635L11.2458 9.99687Z" fill="white"/></svg>');
  --icon-play: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="96" height="96" viewBox="0 0 96 96" fill="none"><path d="M43.2298 60.6304L59.824 49.9669C60.5493 49.5047 60.912 48.8519 60.912 48.0085C60.912 47.1644 60.5493 46.5059 59.824 46.033L43.2298 35.3696C42.4256 34.8263 41.6146 34.7836 40.7968 35.2416C39.979 35.6995 39.5701 36.3978 39.5701 37.3365V58.6634C39.5701 59.6021 39.979 60.3004 40.7968 60.7584C41.6146 61.2163 42.4256 61.1737 43.2298 60.6304ZM48.0138 86.4C42.7154 86.4 37.7376 85.3923 33.0805 83.3771C28.4242 81.3618 24.3552 78.6151 20.8736 75.137C17.392 71.6583 14.6428 67.5929 12.6261 62.9408C10.6087 58.2887 9.59998 53.313 9.59998 48.0138C9.59998 42.704 10.6076 37.7116 12.6229 33.0368C14.6382 28.3626 17.3849 24.2965 20.8629 20.8384C24.3417 17.3802 28.4071 14.6428 33.0592 12.6261C37.7113 10.6087 42.6869 9.59998 47.9861 9.59998C53.296 9.59998 58.2883 10.6076 62.9632 12.6229C67.6373 14.6382 71.7034 17.3731 75.1616 20.8277C78.6197 24.2823 81.3571 28.3449 83.3738 33.0154C85.3913 37.6853 86.4 42.6755 86.4 47.9861C86.4 53.2846 85.3923 58.2624 83.377 62.9194C81.3618 67.5758 78.6268 71.6448 75.1722 75.1264C71.7177 78.608 67.6551 81.3571 62.9845 83.3738C58.3146 85.3913 53.3244 86.4 48.0138 86.4ZM48 82.7893C57.6896 82.7893 65.9104 79.4108 72.6624 72.6538C79.4137 65.8962 82.7893 57.6782 82.7893 48C82.7893 38.3104 79.4137 30.0896 72.6624 23.3376C65.9104 16.5863 57.6896 13.2106 48 13.2106C38.3218 13.2106 30.1038 16.5863 23.3461 23.3376C16.5891 30.0896 13.2106 38.3104 13.2106 48C13.2106 57.6782 16.5891 65.8962 23.3461 72.6538C30.1038 79.4108 38.3218 82.7893 48 82.7893Z" fill="white"/></svg>');
}

@media screen and (max-width: 1260px) {
  .dr_l-root {
    --outer-margin: var(--inner-padding);
  }
}

@media screen and (max-width: 768px) {
  .dr_l-root {
    --header-height: 60px;
  }
}

/* =============================================================

root

============================================================= */
/* reset */
.dr_l-root :where(*, *:before, *:after) {
  box-sizing: border-box;
}

.dr_l-root :where(html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, em, img, small, strong, sub, sup, b, i, dl, dt, dd, ol, ul, li, table, caption, tbody, tfoot, thead, tr, th, td, article, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, video, a) {
  margin: 0;
  padding: 0;
  outline: 0;
  border: 0;
  vertical-align: baseline;
  font-size: 100%;
}

.dr_l-root :where(h1, h2, h3, h4, h5, h6) {
  font-weight: normal;
}

.dr_l-root :where(ul, li) {
  list-style: none;
}

.dr_l-root :where(th) {
  text-align: left;
}

.dr_l-root :where(em, strong, th) {
  font-weight: inherit;
  font-style: inherit;
}

.dr_l-root :where(a) {
  background: transparent;
  color: currentColor;
  text-decoration: underline;
}

.dr_l-root :where(img) {
  display: block;
  max-width: 100%;
  background: transparent;
  color: #fff;
}

/* Base Configuration */
body.is-dr-header-menu-open {
  overflow: hidden;
}

.dr_l-root :where(svg) {
  display: block;
  width: 100%;
}

.dr_l-root svg :where(path, text, circle):not([fill]) {
  fill: currentColor;
}

@media (any-hover: hover) {
  .dr_l-root :where(a):hover {
    text-decoration: none;
  }
}

.dr_l-root :where(button) {
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
}

.dr_l-root :where(sup, sub) {
  font-size: 70%;
}

.dr_l-root sup {
  vertical-align: super;
}

.dr_l-root sub {
  vertical-align: sub;
}

.dr_l-root :where(._en) {
  font-family: "Barlow Condensed";
  line-height: .8;
}

/* =============================================================

common animation

============================================================= */
*[data-intersection] {
  opacity: 0;
  transition: opacity .5s ease-out, translate .5s ease-out;

  translate: 0px 50px;
}

*[data-intersection][data-intersecting="true"] {
  opacity: 1;

  translate: 0px 0px;
}

@keyframes dr_textloop {
  0% {
    translate: 0 0;
  }
  100% {
    translate: calc(var(--text-length) * -1) 0;
  }
}

/* =============================================================

wrapper

* ============================================================= */
/* dr_l-wrapper
============================== */
.dr_l-wrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100%;
  margin: 0 auto;
  color: var(--base-color);
  letter-spacing: .03em;
  font-weight: 300;
  font-size: calc(14px + var(--slope-1px) * 2);
  font-family: var(--base-font-family);
  line-height: 1.8;
  opacity: 0;
  transition: opacity .4s ease-out;
  -webkit-text-size-adjust: 100%;
}

body.is-loaded .dr_l-wrapper {
  opacity: 1;
}

@media screen and (max-width: 768px) {
  .dr_l-wrapper {
    min-width: 0;
  }
}

/* =============================================================

header

* ============================================================= */
/* dr_l-header
============================== */
.dr_l-header {
  position: sticky;
  top: 0;
  z-index: 2;
  height: var(--header-height);
  border-bottom: 1px solid var(--border-color);
  background: #fff;

  --padding-inline: 0px;
}

@media screen and (max-width: 768px) {
  .dr_l-header {
    --padding-inline: 18px;
  }
}

.dr_l-header__inner {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr auto;
  height: 100%;
}

/* dr_l-header-logo
============================== */
.dr_l-header-logo a {
  display: block;
  padding-inline: 30px;
  background: #fff;
  transition: opacity .2s;
}

@media screen and (max-width: 768px) {
  .dr_l-header-logo a {
    padding-inline: var(--padding-inline);
  }
}

@media (any-hover: hover) {
  .dr_l-header-logo a:hover {
    opacity: .7;
  }
}

.dr_l-header-logo img {
  width: 190px;
}

@media screen and (max-width: 768px) {
  .dr_l-header-logo img {
    width: 154px;
  }
}

/* dr_l-header-nav
============================== */
.dr_l-header-nav {
  display: flex;
  align-items: center;
  gap: 5px;
}

.dr_l-header-nav__buttons {
  display: flex;
  gap: 10px;
}

@media screen and (max-width: 768px) {
  .dr_l-header-nav__buttons {
    display: none;
  }
}

/* dr_l-header-nav-button
============================== */
.dr_l-header-nav-button {
  display: grid;
  grid-template-columns: 1fr auto;
  width: 14.25em;
  height: 60px;
  padding: 15px 1em 15px 1.625em;
  border-radius: 10px;
  background: var(--theme-color);
  color: #fff;
  text-decoration: none;
  text-decoration: none;
  font-weight: 400;
  font-size: clamp(14px, 10.44444px + .46296vw, 16px);
  transition: opacity .2s;

  --theme-color: var(--base-color);
  --arrow-color: currentColor;
}

.dr_l-header-nav-button._graduates {
  --theme-color: var(--color-graduates);
}

.dr_l-header-nav-button._career {
  --theme-color: var(--color-career);
}

@media (any-hover: hover) {
  .dr_l-header-nav-button:hover {
    opacity: .7;
  }
}

.dr_l-header-nav-button:after {
  content: "";
  display: block;
  width: 1.875em;
  height: 1.875em;
  background: var(--arrow-color);
  mask: var(--icon-arrow) 50% 50%/contain no-repeat;
}

/* dr_l-header-toggle-button
============================== */
.dr_l-header-toggle-button {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 14px;
  width: var(--header-height);
  aspect-ratio: 1/1;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  transition: opacity .2s, color .2s;
  appearance: none;
}

body.is-dr-header-menu-open .dr_l-header-toggle-button {
  color: #fff;
}

@media screen and (max-width: 768px) {
  .dr_l-header-toggle-button {
    flex-direction: row;
    gap: 10px;
    width: 120px;
    aspect-ratio: 12/4;
    margin-right: var(--padding-inline);
    border: 1px solid var(--border-color);
    border-radius: 10px;
  }
  body.is-dr-header-menu-open .dr_l-header-toggle-button {
    border-color: currentColor;
  }
}

@media (any-hover: hover) {
  .dr_l-header-toggle-button:hover {
    opacity: .7;
  }
}

.dr_l-header-toggle-button__icon {
  position: relative;
  display: block;
  flex-shrink: 0;
  width: 36px;
  height: 1px;
  margin-block: var(--gap);
  border-radius: 2px;
  background: currentColor;
  transition: background .15s ease-out .15s;

  --gap: 7px;
}

@media screen and (max-width: 768px) {
  .dr_l-header-toggle-button__icon {
    width: 15px;

    --gap: 5px;
  }
}

.dr_l-header-toggle-button__icon:before, .dr_l-header-toggle-button__icon:after {
  content: "";
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background: currentColor;
  transition: translate .15s ease-out .15s, rotate .15s ease-out;
}

.dr_l-header-toggle-button__icon:before {
  translate: 0 calc(var(--gap) * -1);
}

.dr_l-header-toggle-button__icon:after {
  translate: 0 var(--gap);
}

body.is-dr-header-menu-open .dr_l-header-toggle-button__icon {
  background: transparent;
  transition: background .15s ease-out;
}

body.is-dr-header-menu-open .dr_l-header-toggle-button__icon:before, body.is-dr-header-menu-open .dr_l-header-toggle-button__icon:after {
  transition: translate .15s ease-out, rotate .15s ease-out .15s;

  translate: 0 0;
}

body.is-dr-header-menu-open .dr_l-header-toggle-button__icon:before {
  rotate: 24.37deg;
}

body.is-dr-header-menu-open .dr_l-header-toggle-button__icon:after {
  rotate: -24.37deg;
}

.dr_l-header-toggle-button__text {
  margin-block: var(--leading-trim);
  font-weight: 400;
  font-size: 12px;
  font-family: var(--en-font-family);
}

@media screen and (max-width: 768px) {
  .dr_l-header-toggle-button__text {
    font-size: 14px;
  }
}

/* dr_l-header-toggle-menu
============================== */
.dr_l-header-toggle-menu {
  position: fixed;
  inset: 0;
  z-index: 2;
  display: block;
  visibility: hidden;
  overflow-y: auto;
  width: 100%;
  height: 100%;
  padding-top: var(--header-height);
  background: linear-gradient(106deg, #fc6076 19.52%, #ff9a44 73.18%, #ffdc69 97.58%);
  color: #fff;
  opacity: 0;
  transition: all .3s;
  pointer-events: none;
}

body.is-dr-header-menu-open .dr_l-header-toggle-menu {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.dr_l-header-toggle-menu__body {
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  min-height: 100%;
  padding-inline: var(--inner-padding);
  padding-bottom: var(--header-height);
}

@media screen and (max-width: 768px) {
  .dr_l-header-toggle-menu__body {
    align-items: flex-start;
  }
}

.dr_l-header-toggle-menu__loop {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
  display: flex;
  overflow: hidden;
  white-space: nowrap;
  letter-spacing: 0;
  font-weight: 700;
  font-size: calc(64px + var(--slope-1px) * 56);
  font-family: var(--en-font-family);
  line-height: 1;
  opacity: .5;
  animation: dr_textloop 12s linear infinite;

  --text-length: 14em;
}

.dr_l-header-toggle-menu__loop span {
  flex-shrink: 0;
  width: var(--text-length);
}

.dr_l-header-toggle-menu__loop:before, .dr_l-header-toggle-menu__loop:after {
  content: attr(data-text);
  flex-shrink: 0;
  width: var(--text-length);
}

/* dr_l-header-sitemap
============================== */
.dr_l-header-sitemap {
  display: grid;
  grid-template-columns: 100%;
  gap: 100px;
  width: 1166px;
  max-width: 100%;
  margin-inline: auto;
}

@media screen and (max-width: 768px) {
  .dr_l-header-sitemap {
    gap: 48px;
  }
}

.dr_l-header-sitemap__buttons {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 20px;
  width: 744px;
  max-width: 100%;
  margin-inline: auto;
}

@media screen and (max-width: 768px) {
  .dr_l-header-sitemap__buttons {
    grid-template-columns: 100%;
  }
}

/* =============================================================

main

* ============================================================= */
/* main
=============================== */
.dr_l-main {
  position: relative;
  flex-grow: 1;
  overflow: hidden;
  width: 100%;
  max-height: 100%;
  padding: 0;
  padding-inline: var(--inner-padding);
}

.dr_l-main__body {
  width: var(--inner-width-px);
  max-width: 100%;
  margin-inline: auto;
}

/* dr_l-main-header
============================== */
.dr_l-main-header {
  position: relative;
  display: grid;
  align-content: flex-start;
  grid-template: "breadcrumb"  "title" "lead" "text";
  gap: var(--gap);
  width: var(--inner-width-px);
  min-height: var(--image-height);
  max-width: 100%;
  margin-inline: auto;
  margin-bottom: calc(40px + var(--slope-1px) * 24);
  padding-top: calc(20px + var(--slope-1px) * 20);

  --image-width: calc(100 * var(--vw) / 1366 * 760);
  --image-height: calc(220px + var(--slope-1px) * 260);
  --gap: calc(32px + var(--slope-1px) * 16);
  --image-margin: 0;
}

.dr_l-main-header:has(.dr_c-interview-lead) {
  --gap: calc(24px + var(--slope-1px) * 24);
}

@media screen and (max-width: 768px) {
  .dr_l-main-header {
    grid-template: "head"  "lead" "text";

    --image-width: calc(100 * var(--vw) / 375 * 275);
    --image-height: calc(220px + var(--slope-1px) * 140);
  }
  .dr_l-main-header:has(.dr_c-interview-lead) {
    --image-height: calc(215px + var(--slope-1px) * 265);
    --image-margin: calc(-10px - 24px - var(--slope-1px) * 24);
  }
}

.dr_l-main-header__head {
  display: contents;
  align-content: flex-start;
  grid-area: head;
  gap: inherit;
  min-height: calc(var(--image-height) - 20px - var(--slope-1px) * 20);
  margin-bottom: var(--image-margin);
}

@media screen and (max-width: 768px) {
  .dr_l-main-header__head {
    display: grid;
    grid-template: "breadcrumb"  "title";
  }
}

.dr_l-main-header__title {
  grid-area: title;
}

.dr_l-main-header__breadcrumb {
  grid-area: breadcrumb;
}

.dr_l-main-header__image {
  position: absolute;
  top: 0;
  right: calc(-1 * var(--outer-margin));
  z-index: -1;
  overflow: hidden;
  width: var(--image-width);
  height: var(--image-height);
  border-bottom-left-radius: 60px;
}

@media screen and (max-width: 768px) {
  .dr_l-main-header__image {
    border-bottom-left-radius: 30px;
  }
}

.dr_l-main-header__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dr_l-main-header__lead {
  grid-area: lead;
  opacity: 0;
  transition: opacity .6s ease-out .8s, translate .6s ease-out .8s;

  translate: 0 10px;
}

body.is-loaded .dr_l-main-header__lead {
  opacity: 1;

  translate: 0 0;
}

.dr_l-main-header__lead > p {
  margin-block: var(--leading-trim);
  font-weight: 300;
  font-size: calc(18px + var(--slope-1px) * 6);
  line-height: 1.8;
}

@media screen and (max-width: 768px) {
  .dr_l-main-header__lead > p {
    line-height: 1.7;
  }
}

.dr_l-main-header__text {
  grid-area: text;
  font-weight: 300;
  font-size: calc(14px + var(--slope-1px) * 2);
  line-height: 1.8;
  opacity: 0;
  transition: opacity .6s ease-out .8s, translate .6s ease-out .8s;

  translate: 0 10px;
}

body.is-loaded .dr_l-main-header__text {
  opacity: 1;

  translate: 0 0;
}

@media screen and (min-width: 769px) {
  .dr_l-main-header__text {
    margin-top: calc(var(--slope-1px) * -8);
    padding-right: calc(var(--image-width) - var(--outer-margin) + 1.5em);
    word-break: keep-all;
    overflow-wrap: anywhere;
  }
}

.dr_l-main-header__text > p {
  margin-block: var(--leading-trim);
}

.dr_l-main-header__text > p._no-wbr {
  word-break: break-all;
}

/* =============================================================

footer

* ============================================================= */
/* dr_l-footer
============================== */
/* dr_l-footer-contact
============================== */
.dr_l-footer-contact {
  padding: calc(40px + var(--slope-1px) * 40) var(--inner-padding);
}

.dr_l-footer-contact__inner {
  display: grid;
  grid-template-columns: 100%;
  gap: calc(36px + var(--slope-1px) * 28);
  width: 1220px;
  max-width: 100%;
  margin-inline: auto;
  padding: calc(40px + var(--slope-1px) * 40) calc(10px + var(--slope-1px) * 20);
  border-radius: 24px;
  background: linear-gradient(106deg, #fc6076 19.52%, #ff9a44 73.18%, #ffdc69 97.58%);
  color: #fff;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .dr_l-footer-contact__inner {
    max-width: calc(100% + var(--inner-padding));
    margin-inline: calc(var(--inner-padding) * -.5);
  }
}

.dr_l-footer-contact__head {
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  gap: calc(24px + var(--slope-1px) * 16);
}

.dr_l-footer-contact__title {
  margin-block: var(--leading-trim);
  padding-left: .5em;
  font-weight: 400;
  font-size: clamp(54px, -29.47826px + 10.86957vw, 64px);
}

@media screen and (max-width: 768px) {
  .dr_l-footer-contact__title {
    font-size: calc(26px + var(--slope-1px) * 28);
  }
}

.dr_l-footer-contact__subtitle {
  margin-block: var(--leading-trim);
  font-weight: 400;
  font-size: calc(14px + var(--slope-1px) * 10);
  font-family: var(--en-font-family);
}

.dr_l-footer-contact__body {
  margin-block: var(--leading-trim);
  word-break: keep-all;
  overflow-wrap: anywhere;
  letter-spacing: 0;
  font-weight: 400;
  font-size: calc(13px + var(--slope-1px) * 3);
}

.dr_l-footer-contact__foot {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 10px 20px;
  width: 744px;
  max-width: 100%;
  margin-inline: auto;
}

/* dr_l-footer-sitemap
============================== */
.dr_l-footer-sitemap {
  display: grid;
  grid-template-columns: 100%;
  gap: 60px;
  padding: 80px 20px 60px;
  background: var(--base-color);
  color: #fff;
}

@media screen and (max-width: 768px) {
  .dr_l-footer-sitemap {
    gap: 40px;
    padding-block: 16px 40px;
  }
}

.dr_l-footer-sitemap__body {
  width: 1034px;
  max-width: 100%;
  margin-inline: auto;
}

.dr_l-footer-sitemap__foot {
  text-align: center;
}

/* dr_l-footer-sitemap-guide
============================== */
.dr_l-footer-sitemap-guide {
  display: block;
  width: fit-content;
  margin-block: var(--leading-trim);
  margin-inline: auto;
}

/* =============================================================

interview

* ============================================================= */
/* c-interview-lead
============================== */
.dr_c-interview-lead {
  width: fit-content;
  font-weight: 400;
  font-size: calc(18px + var(--slope-1px) * 14);
  line-height: 1;
}

body[data-id="interview-graduates"] .dr_c-interview-lead {
  --border-color: #fc6076;
  --text-color: var(--gradation-03);
}

body[data-id="interview-career"] .dr_c-interview-lead {
  --border-color: #46aef7;
  --text-color: var(--gradation-04);
}

@media screen and (max-width: 768px) {
  .dr_c-interview-lead {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
}

.dr_c-interview-lead :where(._frame-pc, ._frame-sp) {
  padding: calc(12px + var(--slope-1px) * 8) calc(10px + var(--slope-1px) * 5);
  border: 1px solid;
  border-image: var(--text-color) 1;
  background: #fff;
}

.dr_c-interview-lead :where(._text-pc, ._text-sp) {
  display: inline;
  background: var(--text-color);
  -webkit-background-clip: text;
          background-clip: text;

  -webkit-text-fill-color: transparent;
}

@media screen and (max-width: 768px) {
  .dr_c-interview-lead :is(._frame-pc, ._text-pc) {
    display: contents;
  }
}

@media screen and (min-width: 769px) {
  .dr_c-interview-lead :is(._frame-sp, ._text-sp) {
    display: contents;
  }
}

/* c-interview-movie-container
============================== */
.dr_c-interview-movie-container {
  display: grid;
  grid-template-columns: 100%;
  gap: calc(24px + var(--slope-1px) * 8);
}

@media screen and (max-width: 768px) {
  .dr_c-interview-movie-container {
    width: calc(100% + var(--inner-padding));
    margin-inline: calc(var(--inner-padding) * -.5);
  }
}

/* c-interview-movie
============================== */
.dr_c-interview-movie {
  position: relative;
  display: grid;
  align-items: center;
  grid-template-columns: 1fr 56%;
  gap: calc(24px + var(--slope-1px) * 8) 40px;
  padding: calc(24px + var(--slope-1px) * 16);
  border-radius: 24px;
  background: #fff;
  color: var(--base-color);
  font-size: calc(14px + var(--slope-1px) * 2);
}

@media screen and (max-width: 768px) {
  .dr_c-interview-movie {
    grid-template-columns: 100%;
  }
}

.dr_c-interview-movie__number {
  position: absolute;
  top: 50px;
  left: 0;
  color: var(--color);
  font-weight: 700;
  font-size: 96px;
  line-height: .9;
  opacity: .2;
}

body[data-id="interview-graduates"] .dr_c-interview-movie__number {
  --color: var(--color-graduates);
}

body[data-id="interview-career"] .dr_c-interview-movie__number {
  --color: var(--color-career);
}

@media screen and (max-width: 768px) {
  .dr_c-interview-movie__number {
    top: 20px;
    right: 0;
    left: auto;
    font-size: 72px;
  }
}

.dr_c-interview-movie__image {
  position: relative;
  display: grid;
  align-content: center;
  grid-template-columns: 100%;
  overflow: hidden;
  aspect-ratio: 560/315;
  border-radius: 24px;
  background: var(--base-color);
  color: #fff;
  text-decoration: none;

  container-type: inline-size;
}

.dr_c-interview-movie__image:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
  width: calc(100cqi / 560 * 96);
  aspect-ratio: 1/1;
  margin: auto;
  background: currentColor;
  mask: var(--icon-play) 50% 50%/contain no-repeat;
}

.dr_c-interview-movie__image:after {
  content: "";
  display: block;
  grid-row: 2/3;
  height: calc(100cqi / 560 * 32);
}

.dr_c-interview-movie__lead {
  position: relative;
  z-index: 1;
  margin-block: var(--leading-trim);
  padding-left: calc(100cqi / 560 * 24);
  font-size: calc(100cqi / 560 * 20);
}

.dr_c-interview-movie__text {
  position: relative;
  z-index: 1;
  margin-block: var(--leading-trim);
  padding-left: calc(100cqi / 560 * 24);
  font-size: calc(100cqi / 560 * 14);
}

.dr_c-interview-movie__thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: filter .2s;
}

@media (any-hover: hover) {
  .dr_c-interview-movie__image:hover .dr_c-interview-movie__thumb {
    filter: brightness(.8);
  }
}

.dr_c-interview-movie__name {
  margin-block: var(--leading-trim);
  font-weight: 700;
  font-size: calc(21px + var(--slope-1px) * 3);
}

.dr_c-interview-movie__label {
  margin-block: var(--leading-trim);
  padding-top: calc(18px + var(--slope-1px) * 6);
}

.dr_c-interview-movie__label > p {
  display: inline;
}

.dr_c-interview-movie__label > p:not(:first-child):before {
  content: "\FF0F";
  margin-inline: .25em;
}

.dr_c-interview-movie__profile {
  margin-block: var(--leading-trim);
  padding-top: calc(24px + var(--slope-1px) * 8);
}

/* ============================================================= *

button

* ============================================================= */
/* c-entry-button
============================== */
.dr_c-entry-button {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr auto;
  height: calc(60px + var(--slope-1px) * 30);
  padding: 15px 20px 15px 25px;
  border: 1px solid #999;
  border-radius: calc(8px + var(--slope-1px) * 2);
  background: #fff;
  color: var(--base-color);
  text-align: left;
  text-decoration: none;
  font-weight: 300;
  font-size: calc(18px + var(--slope-1px) * 6);
  transition: opacity .2s;
}

@media (any-hover: hover) {
  .dr_c-entry-button:hover {
    opacity: .7;
  }
}

.dr_c-entry-button:after {
  content: "";
  display: block;
  width: calc(30px + var(--slope-1px) * 10);
  height: calc(30px + var(--slope-1px) * 10);
  background: var(--key-color);
  mask: var(--icon-arrow) 50% 50%/contain no-repeat;
}

/* ============================================================= *

sitemap

* ============================================================= */
/* c-sitemap
============================== */
.dr_c-sitemap {
  display: flex;
  justify-content: space-between;
  gap: 0 48px;
}

@media screen and (max-width: 768px) {
  .dr_c-sitemap {
    display: grid;
    grid-template-columns: 100%;
  }
}

/* c-sitemap-block
============================== */
.dr_c-sitemap-block {
  display: grid;
  align-self: self-start;
  grid-template-columns: 100%;

  --gap: 24px;
}

@media screen and (min-width: 769px) {
  .dr_l-header .dr_c-sitemap-block {
    --gap: 32px;
  }
}

@media screen and (max-width: 768px) {
  .dr_c-sitemap-block {
    border-bottom: 1px solid currentColor;
  }
}

.dr_c-sitemap-block__head {
  display: grid;
  align-items: center;
  gap: .5em;
  overflow: visible;
  width: 100%;
  margin: 0;
  padding: 0 0 8px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: currentColor;
  text-align: left;
  font-weight: 700;
  font-size: 18px;
  line-height: 1;
  pointer-events: none;
  appearance: none;
}

@media screen and (min-width: 769px) {
  .dr_l-header .dr_c-sitemap-block__head {
    padding-bottom: 24px;
    border-bottom: 1px solid currentColor;
    font-weight: 400;
    font-size: 24px;
  }
}

@media screen and (max-width: 768px) {
  .dr_c-sitemap-block__head {
    grid-template-columns: 1fr auto;
    padding-block: 24px 16px;
    font-weight: 500;
    font-size: 16px;
    pointer-events: auto;
  }
  .dr_c-sitemap-block__head:after {
    content: "";
    display: block;
    flex-shrink: 0;
    width: 30px;
    aspect-ratio: 1/1;
    background: currentColor;
    mask: var(--icon-down) 50% 50%/contain no-repeat;
    transition: rotate .2s linear;
  }
  .dr_c-sitemap-block__head.is-open:after {
    rotate: 180deg;
  }
}

.dr_c-sitemap-block__body {
  display: none;
  padding-top: var(--gap);
}

@media screen and (min-width: 769px) {
  .dr_c-sitemap-block__body {
    display: block !important;
  }
}

@media screen and (max-width: 768px) {
  .dr_c-sitemap-block__body {
    padding-top: 0;
    padding-bottom: 30px;
  }
}

@media screen and (min-width: 769px) {
  .dr_l-header .dr_c-sitemap-block__body {
    font-size: 20px;
  }
}

.dr_c-sitemap-block__list {
  display: grid;
  grid-template-columns: 100%;
  gap: var(--gap);
}

.dr_c-sitemap-block__item {
  margin-block: var(--leading-trim);
}

.dr_c-sitemap-block__item a {
  text-decoration: none;
}

@media (any-hover: hover) {
  .dr_c-sitemap-block__item a:hover {
    text-decoration: underline;
  }
}

@media screen and (max-width: 768px) {
  .dr_c-sitemap-block__item a {
    display: flex;
    align-items: center;
    gap: .5em;
    width: fit-content;
    max-width: 100%;
  }
  .dr_c-sitemap-block__item a:before {
    content: "";
    display: block;
    flex-shrink: 0;
    width: 1.25em;
    aspect-ratio: 1/1;
    background: currentColor;
    mask: var(--icon-arrow) 50% 50%/contain no-repeat;
  }
}

/* ============================================================= *

breadcrumbs

* ============================================================= */
/* c-breadcrumbs
============================== */
.dr_c-breadcrumbs {
  margin-block: var(--leading-trim);
  font-size: 0;
  line-height: calc(18px + var(--slope-1px) * 3);
}

.dr_c-breadcrumbs > li {
  display: inline;
  font-size: calc(10px + var(--slope-1px) * 3);
}

.dr_c-breadcrumbs > li:has(a) {
  color: #999;
}

.dr_c-breadcrumbs > li:has(a):after {
  content: "";
  position: relative;
  top: calc(6px - var(--slope-1px) * 1);
  display: inline-block;
  width: 20px;
  aspect-ratio: 1/1;
  background: currentColor;
  mask: var(--icon-angle) 50% 50%/contain no-repeat;
}

.dr_c-breadcrumbs > li:has(a) a {
  color: currentColor;
}

.dr_c-breadcrumbs > li a, .dr_c-breadcrumbs > li:not(:has(a)) {
  padding: 4px;
  background: #fff;
}

/* ============================================================= *

section

* ============================================================= */
/* c-section
============================== */
.dr_c-section._bg {
  position: relative;
  padding-block: calc(48px + var(--slope-1px) * 32);
  color: #fff;

  --bg-color: var(--color-graduates);
}

body[data-id="interview-career"] .dr_c-section._bg {
  --bg-color: var(--color-career);
}

.dr_c-section._bg:before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  z-index: -1;
  display: block;
  width: calc(var(--vw) * 100);
  height: 100%;
  background: var(--bg-color);
  transform: translateX(-50%);
}

.dr_c-section._bg:has(.dr_c-section__head) {
  padding-block: calc(48px + var(--slope-1px) * 52);
}

.dr_c-section__head {
  display: grid;
  gap: calc(40px + var(--slope-1px) * 8);
  margin-bottom: calc(48px + var(--slope-1px) * 8);
}

/* c-section-container
============================== */
.dr_c-section-container {
  position: relative;
  padding-block: calc(48px + var(--slope-1px) * 52);

  container-type: inline-size;
}

.dr_c-section-container:before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  z-index: -1;
  display: block;
  width: calc(var(--vw) * 100);
  height: 100%;
  background: var(--bg-color);
  transform: translateX(-50%);
}

.dr_c-section-container > * {
  max-width: 1080px;
  margin-inline: auto;
}

/* ============================================================= *

title

* ============================================================= */
/* c-page-title
============================== */
.dr_c-page-title {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: fit-content;
  font-weight: 300;
  font-size: calc(24px + var(--slope-1px) * 24);
  line-height: 1;

  --padding: calc(12px + var(--slope-1px) * 8) calc(10px + var(--slope-1px) * 5) calc(12px + var(--slope-1px) * 8) 0;
  --theme-color: var(--key-color);
}

body[data-id="interview-graduates"] .dr_c-page-title {
  --theme-color: var(--color-graduates);
}

body[data-id="interview-career"] .dr_c-page-title {
  --theme-color: var(--color-career);
}

.dr_c-page-title:before {
  content: attr(data-en);
  margin-bottom: calc(10px + var(--slope-1px) * 8);
  color: var(--theme-color);
  font-weight: 400;
  font-size: calc(16px + var(--slope-1px) * 8);
  font-family: var(--en-font-family);
  line-height: 1;
  opacity: 0;
  transition: opacity .6s ease-out .8s, translate .6s ease-out .8s;

  translate: 0 10px;
}

body.is-loaded .dr_c-page-title:before {
  opacity: 1;

  translate: 0 0;
}

@media screen and (min-width: 769px) {
  .dr_c-page-title__inner {
    position: relative;
    padding: var(--padding);
    background: #fff;
    transition: scale .35s ease-out calc(.2s * (var(--index) - 1));
    transform-origin: left center;

    --index: 1;
    scale: 0 1;
  }
  body.is-loaded .dr_c-page-title__inner {
    scale: 1 1;
  }
  .dr_c-page-title__inner:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--theme-color);
    transition: scale .35s ease-out calc(.45s + .2s * (var(--index) - 1));
    transform-origin: right top;
  }
  body.is-loaded .dr_c-page-title__inner:after {
    scale: 0 1;
  }
}

@media screen and (max-width: 768px) {
  .dr_c-page-title__inner {
    display: contents;
  }
  .dr_c-page-title__inner > span {
    position: relative;
    display: block;
    width: fit-content;
    padding: var(--padding);
    background: #fff;
    transition: scale .35s ease-out calc(.2s * (var(--index) - 1));
    transform-origin: left center;

    --index: 1;
    scale: 0 1;
  }
  body.is-loaded .dr_c-page-title__inner > span {
    scale: 1 1;
  }
  .dr_c-page-title__inner > span:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--theme-color);
    transition: scale .35s ease-out calc(.45s + .2s * (var(--index) - 1));
    transform-origin: right top;
  }
  body.is-loaded .dr_c-page-title__inner > span:after {
    scale: 0 1;
  }
  .dr_c-page-title__inner > span:nth-child(2) {
    --index: 2;
  }
}

/*! Lity - v2.4.1 - 2020-04-26
* http://sorgalla.com/lity/
* Copyright (c) 2015-2020 Jan Sorgalla; Licensed MIT
*/
.lity {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 9990;
  outline: none !important;
  background: #0b0b0b;
  background: rgba(0, 0, 0, .9);
  white-space: nowrap;
  opacity: 0;
  transition: opacity .3s ease;
}

.lity.lity-opened {
  opacity: 1;
}

.lity.lity-closed {
  opacity: 0;
}

.lity * {
  box-sizing: border-box;
}

.lity-wrap {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 9990;
  outline: none !important;
  text-align: center;
}

.lity-wrap:before {
  content: "";
  display: inline-block;
  height: 100%;
  margin-right: -.25em;
  vertical-align: middle;
}

.lity-loader {
  position: absolute;
  top: 50%;
  z-index: 9991;
  width: 100%;
  margin-top: -.8em;
  color: #fff;
  text-align: center;
  font-size: 14px;
  font-family: Arial,Helvetica,sans-serif;
  opacity: 0;
  transition: opacity .3s ease;
}

.lity-loading .lity-loader {
  opacity: 1;
}

.lity-container {
  position: relative;
  z-index: 9992;
  display: inline-block;
  max-width: 100%;
  max-height: 100%;
  outline: none !important;
  vertical-align: middle;
  text-align: left;
  white-space: normal;
}

.lity-content {
  z-index: 9993;
  width: 100%;
  transition: transform .3s ease;
  transform: scale(1);
}

.lity-closed .lity-content, .lity-loading .lity-content {
  transform: scale(.8);
}

.lity-content:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  display: block;
  width: auto;
  height: auto;
  box-shadow: 0 0 8px rgba(0, 0, 0, .6);
}

.lity-close {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 9994;
  width: 35px;
  height: 35px;
  padding: 0;
  outline: none;
  border: 0;
  background: none;
  box-shadow: none;
  color: #fff;
  text-align: center;
  text-decoration: none;
  text-shadow: 0 1px 2px rgba(0, 0, 0, .6);
  font-style: normal;
  font-size: 35px;
  font-family: Arial,Baskerville,monospace;
  line-height: 35px;
  cursor: pointer;
  -webkit-appearance: none;
}

.lity-close::-moz-focus-inner {
  padding: 0;
  border: 0;
}

.lity-close:active, .lity-close:focus, .lity-close:hover, .lity-close:visited {
  padding: 0;
  outline: none;
  border: 0;
  background: none;
  box-shadow: none;
  color: #fff;
  text-align: center;
  text-decoration: none;
  text-shadow: 0 1px 2px rgba(0, 0, 0, .6);
  font-style: normal;
  font-size: 35px;
  font-family: Arial,Baskerville,monospace;
  line-height: 35px;
}

.lity-close:active {
  top: 1px;
}

.lity-image img {
  display: block;
  max-width: 100%;
  border: 0;
  line-height: 0;
}

.lity-facebookvideo .lity-container, .lity-googlemaps .lity-container, .lity-iframe .lity-container, .lity-vimeo .lity-container, .lity-youtube .lity-container {
  width: 100%;
  max-width: 964px;
}

.lity-iframe-container {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
  transform: translateZ(0);
  pointer-events: auto;
}

.lity-iframe-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: #000;
  box-shadow: 0 0 8px rgba(0, 0, 0, .6);
}

.lity-hide {
  display: none;
}

.lity {
  background-color: rgba(0, 0, 0, .8);
}

/* custom
============================== */
.lity-wrap {
  padding: 5.3333333333vw;
}

@media screen and (min-width: 736.001px) {
  .lity-wrap {
    padding: 0;
  }
}

.lity-close, .lity-close:active, .lity-close:focus, .lity-close:hover, .lity-close:visited {
  position: absolute;
  top: -8vw !important;
  width: 5.33333vw !important;
  height: 5.33333vw !important;
  font-size: 9.3333333333vw;
  line-height: 5.3333333333vw;
}

@media screen and (min-width: 736.001px) {
  .lity-close, .lity-close:active, .lity-close:focus, .lity-close:hover, .lity-close:visited {
    top: -60px !important;
    width: 40px !important;
    height: 40px !important;
    font-size: 70px;
    line-height: 40px;
  }
}

.lity-content:after, .lity-iframe-container iframe {
  box-shadow: none;
}

[data-simplebar] {
  position: relative;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
  align-content: flex-start;
}

.simplebar-wrapper {
  overflow: hidden;
  width: inherit;
  height: inherit;
  max-width: inherit;
  max-height: inherit;
}

.simplebar-mask {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0;
  overflow: hidden;
  width: auto !important;
  height: auto !important;
  margin: 0;
  padding: 0;
  direction: inherit;
}

.simplebar-offset {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  -webkit-overflow-scrolling: touch;
  box-sizing: inherit !important;
  margin: 0;
  padding: 0;
  resize: none !important;
  direction: inherit !important;
}

.simplebar-content-wrapper {
  position: relative;
  display: block;
  /* Needed for vertical scroll to trigger */
  overflow: auto;
  box-sizing: border-box !important;
  /* Required for horizontal native scrollbar to not appear if parent is taller than natural height */
  width: auto;
  height: 100%;
  max-width: 100%;
  /* Not required for horizontal scroll to trigger */
  max-height: 100%;
  direction: inherit;

  scrollbar-width: none;
  -ms-overflow-style: none;
}

.simplebar-content-wrapper::-webkit-scrollbar,
.simplebar-hide-scrollbar::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
}

.simplebar-content:before,
.simplebar-content:after {
  content: ' ';
  display: table;
}

.simplebar-placeholder {
  width: 100%;
  max-width: 100%;
  max-height: 100%;
  pointer-events: none;
}

.simplebar-height-auto-observer-wrapper {
  position: relative;
  z-index: -1;
  float: left;
  flex-grow: inherit;
  flex-shrink: 0;
  flex-basis: 0;
  overflow: hidden;
  box-sizing: inherit !important;
  width: 100%;
  height: 100%;
  max-width: 1px;
  max-height: 1px;
  margin: 0;
  padding: 0;
  pointer-events: none;
}

.simplebar-height-auto-observer {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  display: block;
  overflow: hidden;
  box-sizing: inherit;
  width: 1000%;
  height: 1000%;
  min-width: 1px;
  min-height: 1px;
  opacity: 0;
  pointer-events: none;
}

.simplebar-track {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}

[data-simplebar].simplebar-dragging {
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;

  -webkit-touch-callout: none;
   -khtml-user-select: none;
}

[data-simplebar].simplebar-dragging .simplebar-content {
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;

  -webkit-touch-callout: none;
   -khtml-user-select: none;
}

[data-simplebar].simplebar-dragging .simplebar-track {
  pointer-events: all;
}

.simplebar-scrollbar {
  position: absolute;
  right: 0;
  left: 0;
  min-height: 10px;
}

.simplebar-scrollbar:before {
  content: '';
  position: absolute;
  right: 0;
  left: 0;
  border-radius: 4px;
  background: #999;
  opacity: 1;
  transition: opacity .2s .5s linear;
}

.simplebar-scrollbar.simplebar-visible:before {
  transition-delay: 0s;
  transition-duration: 0s;
}

.simplebar-track.simplebar-vertical {
  top: 0;
  width: 11px;
}

.simplebar-scrollbar:before {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.simplebar-track.simplebar-horizontal {
  left: var(--inner-padding);
  width: calc(100% - var(--inner-padding) * 2);
  height: 8px;
  border-radius: 4px;
  background: #d9d9d9;
}

.simplebar-track.simplebar-horizontal .simplebar-scrollbar {
  top: 0;
  right: auto;
  bottom: 0;
  left: 0;
  width: auto;
  min-width: 10px;
  min-height: 0;
}

/* Rtl support */
[data-simplebar-direction='rtl'] .simplebar-track.simplebar-vertical {
  right: auto;
  left: 0;
}

.simplebar-dummy-scrollbar-size {
  position: fixed;
  visibility: hidden;
  overflow-x: scroll;
  overflow-y: hidden;
  width: 500px;
  height: 500px;
  opacity: 0;
  direction: rtl;

  -ms-overflow-style: scrollbar !important;
}

.simplebar-dummy-scrollbar-size > div {
  width: 200%;
  height: 200%;
  margin: 10px 0;
}

.simplebar-hide-scrollbar {
  position: fixed;
  left: 0;
  visibility: hidden;
  overflow-y: scroll;

  scrollbar-width: none;
  -ms-overflow-style: none;
}

/* ============================================================= *

Utility

* ============================================================= */
/* Media Query Setting
====================================== */
.u-tablet-block {
  display: none !important;
}

@media screen and (max-width: 768px) {
  .u-tablet-block {
    display: block !important;
  }
}

.u-tablet-inline-block {
  display: none !important;
}

@media screen and (max-width: 768px) {
  .u-tablet-inline-block {
    display: inline-block !important;
  }
}

.u-tablet-flex {
  display: none !important;
}

@media screen and (max-width: 768px) {
  .u-tablet-flex {
    display: flex !important;
  }
}

@media screen and (max-width: 768px) {
  .u-tablet-none {
    display: none !important;
  }
}

.u-mobile-block {
  display: none !important;
}

@media screen and (max-width: 560px) {
  .u-mobile-block {
    display: block !important;
  }
}

.u-mobile-inline-block {
  display: none !important;
}

@media screen and (max-width: 560px) {
  .u-mobile-inline-block {
    display: inline-block !important;
  }
}

.u-mobile-flex {
  display: none !important;
}

@media screen and (max-width: 560px) {
  .u-mobile-flex {
    display: flex !important;
  }
}

@media screen and (max-width: 560px) {
  .u-mobile-none {
    display: none !important;
  }
}

/* text align
====================================== */
.u-ta-left {
  text-align: left !important;
}

.u-ta-right {
  text-align: right !important;
}

.u-ta-center {
  text-align: center !important;
}

/* display
====================================== */
.u-d-block {
  display: block !important;
}

.u-d-none {
  display: none !important;
}

.u-d-inline {
  display: inline !important;
}

.u-d-ib {
  display: inline-block !important;
}

/* position
====================================== */
.u-pos-static {
  position: static !important;
}

.u-pos-relative {
  position: relative !important;
}

.u-pos-absolute {
  position: absolute !important;
}

.u-pos-fixed {
  position: fixed !important;
}

/* clear
====================================== */
.u-clearfix:after {
  content: "";
  display: block;
  visibility: hidden;
  clear: both;
}

/* other
====================================== */
.u-strong {
  font-weight: bold !important;
}

.u-pointer {
  cursor: pointer;
}

.u-nowrap {
  white-space: nowrap;
}

.u-color-honda {
  color: #cc0000 !important;
}

.u-color-ciao {
  color: #0068b6 !important;
}

.u-color-mamoru {
  color: #8fc31f !important;
}

.u-rotate-90 {
  transform: rotate(90deg);
}

/* animationn
====================================== */
.u-no-transition {
  transition: none !important;
}
