.ag {
  color: #333;
  font-family: "HondaGlobalFontJP-Regular", sans-serif;
  font-weight: normal;
  font-feature-settings: "palt";
  font-size: 16px;
  line-height: 1.7; }
  .ag * {
    box-sizing: border-box;
    margin: 0;
    padding: 0; }
  .ag h1,
  .ag h2,
  .ag h3,
  .ag b,
  .ag strong {
    font-family: "HondaGlobalFontJP-Bold", sans-serif; }
  .ag small {
    font-family: "HondaGlobalFontJP-Light", sans-serif; }
  .ag .container {
    width: 900px;
    max-width: 92%;
    margin-left: auto;
    margin-right: auto; }
  .ag .ti1 {
    text-indent: -1em;
    padding-left: 1em;
    line-height: 1.3; }
  .ag .ag__kv {
    background: #d3def0;
    background: linear-gradient(90deg, #d3def0 50%, #e1e9f6 50%);
    line-height: 0; }
    .ag .ag__kv .container {
      width: 980px;
      max-width: 100%; }
  .ag .ag__banner {
    padding: 3rem 0; }
  .ag .ag__banner__box {
    background: #f9d1d1;
    border-radius: 12px;
    display: flex;
    justify-content: center;
    padding: 1rem; }
    .ag .ag__banner__box figure {
      flex: 0 0 18%;
      transform: scale(1.2);
      transform-origin: right bottom; }
    .ag .ag__banner__box__txt {
      padding: 0 0 0 2rem; }
    .ag .ag__banner__box h1 {
      font-size: clamp(20px, 5vw, 38px);
      line-height: 1.3; }
      .ag .ag__banner__box h1 i {
        font-size: 1.3em;
        transform: translateY(4%);
        display: inline-block; }
      .ag .ag__banner__box h1 b {
        font-size: 1.4em;
        color: #e60020; }
      .ag .ag__banner__box h1 em {
        display: block; }
      .ag .ag__banner__box h1 small {
        font-size: 0.6em; }
  .ag .ag__bluebg {
    background: #eaeff9;
    margin-top: 3em; }
    .ag .ag__bluebg .container {
      position: relative; }
    .ag .ag__bluebg h2 {
      position: absolute;
      top: 0;
      left: 0;
      transform: translateY(calc(-100% + 1px));
      font-family: "HondaGlobalFontJP-Regular", sans-serif;
      font-weight: 400;
      display: flex;
      align-items: center;
      font-size: 1.1em; }
      .ag .ag__bluebg h2 em {
        background: #eaeff9;
        border-radius: 8px 8px 0 0;
        color: #617499;
        display: inline-block;
        padding: 4px 8px 4px 10px;
        letter-spacing: 2px;
        min-width: 8em;
        text-align: center; }
      .ag .ag__bluebg h2 small {
        padding-left: 2rem;
        font-size: 0.8em; }
        .ag .ag__bluebg h2 small a {
          color: #00a0e9; }
  .ag .ag__outline .container {
    padding: 2rem 0; }
  .ag .ag__outline dl {
    display: flex;
    align-items: flex-start;
    margin-bottom: 2rem;
    font-size: 0.9em; }
  .ag .ag__outline dt {
    color: #fff;
    white-space: nowrap;
    text-align: center;
    min-width: 8em;
    line-height: 1;
    padding-top: 8px; }
    .ag .ag__outline dt b {
      font-family: "HondaGlobalFontJP-Regular", sans-serif;
      font-weight: 400;
      display: block;
      padding: 2px 4px;
      background: #617499; }
  .ag .ag__outline dd {
    padding-left: 1.5rem; }
    .ag .ag__outline dd b {
      font-size: 1.5em; }
  .ag .ag__supplies {
    padding: 6rem 0 3rem; }
    .ag .ag__supplies h2 {
      color: #005bac;
      font-size: 2.1em;
      text-align: center;
      position: relative; }
      .ag .ag__supplies h2 b {
        display: inline-block;
        background: #fff;
        padding: 0 1rem;
        position: relative;
        z-index: 2; }
      .ag .ag__supplies h2::after {
        content: "";
        z-index: 1;
        position: absolute;
        left: 0;
        top: 49%;
        width: 100%;
        height: 2px;
        background: #005bac; }
    .ag .ag__supplies ul {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      padding-bottom: 2rem; }
      .ag .ag__supplies ul li {
        margin-top: 4rem;
        flex: 0 0 48%;
        border-radius: 0 0 24px 24px;
        overflow: hidden;
        line-height: 0; }
        .ag .ag__supplies ul li em {
          display: flex;
          background: #eaeff9;
          color: #617499;
          line-height: 1.2;
          padding: 1rem 4px;
          font-size: 1.4em;
          text-align: center;
          justify-content: center;
          align-items: center;
          min-height: 3em; }
        .ag .ag__supplies ul li i {
          display: block;
          background: #e7e6e2; }
    .ag .ag__supplies h3 {
      font-family: "HondaGlobalFontJP-Regular", sans-serif;
      margin-bottom: 4rem;
      font-size: 1.1em; }
    .ag .ag__supplies p small {
      font-size: 12px; }
  .ag .ag__table {
    font-size: 0.9em; }
    .ag .ag__table a {
      color: #00a0e9; }
    .ag .ag__table table {
      width: 100%; }
    .ag .ag__table th, .ag .ag__table td {
      padding: 4px 8px;
      border: 1px solid #444;
      vertical-align: middle; }
      .ag .ag__table th a, .ag .ag__table td a {
        display: inline-flex; }
        .ag .ag__table th a span, .ag .ag__table td a span {
          flex: 0 0 11em; }
      .ag .ag__table th a:hover, .ag .ag__table td a:hover {
        color: #617499; }
    .ag .ag__table th {
      background: #617499;
      text-align: left; }
    .ag .ag__table thead th {
      text-align: center;
      color: #fff;
      font-family: "HondaGlobalFontJP-Bold", sans-serif;
      font-size: 1.2em; }
    .ag .ag__table .t_blue th {
      background: #b1dbfd; }
    .ag .ag__table .t_blue td {
      background: #f3fafe; }
    .ag .ag__table .t_yellow th {
      background: #fff3c3; }
    .ag .ag__table .t_yellow td {
      background: #fffcf0; }
    .ag .ag__table .t_red th {
      background: #f9d2dc; }
    .ag .ag__table .t_red td {
      background: #fdf2f5; }
  .ag .ag__howto .container {
    padding: 4rem 0; }
  .ag .ag__howto__flow {
    padding: 0 0 1rem;
    display: flex;
    justify-content: space-between; }
    .ag .ag__howto__flow dl {
      flex: 0 0 29%;
      flex-direction: column;
      justify-content: flex-end; }
    .ag .ag__howto__flow dt {
      color: #fff;
      display: flex;
      flex-direction: column;
      flex-wrap: wrap;
      align-items: center;
      justify-content: center;
      text-align: center;
      background: #617499;
      min-height: 5em;
      font-size: 1.2em;
      font-size: clamp(16px, 2vw, 20px); }
      .ag .ag__howto__flow dt small {
        font-size: 12px; }
    .ag .ag__howto__flow dd {
      position: relative;
      background: #fff;
      padding: 2rem 3rem; }
      .ag .ag__howto__flow dd::after {
        content: "";
        position: absolute;
        right: -11%;
        top: 50%;
        transform: translate(50%, -50%);
        background: #617499;
        width: 2rem;
        height: 2.4rem;
        clip-path: polygon(0 0, 100% 50%, 0 100%); }
    .ag .ag__howto__flow dl:last-child dd::after {
      content: none; }
  .ag p small {
    font-size: 12px; }
  .ag .ag__guidelines {
    padding: 4rem 0 6rem; }
    .ag .ag__guidelines h3 {
      background: #617499;
      color: #fff;
      padding: 4px 2rem;
      font-size: 1.1em; }
    .ag .ag__guidelines h4 {
      color: #617499;
      padding-top: 3rem;
      font-family: "HondaGlobalFontJP-Bold", sans-serif; }
    .ag .ag__guidelines ul {
      font-size: 0.8em;
      color: #555;
      padding-top: 1rem; }
    .ag .ag__guidelines li {
      padding: 3px 0;
      text-indent: -0.6em;
      padding-left: 0.6em;
      line-height: 1.3; }
    .ag .ag__guidelines .ti1 {
      text-indent: -1em;
      padding-left: 1em; }
    .ag .ag__guidelines .ml1 {
      margin-left: 1rem; }
  .ag .sp {
    display: none; }
  .ag .tsp {
    display: none; }

@media (max-width: 736px) {
  .ag .sp {
    display: block; }
  .ag br.sp {
    display: inline; }
  .ag .ag__banner__box {
    align-items: center; }
    .ag .ag__banner__box figure {
      flex: 0 0 20%;
      transform: scale(1.8) translate(-20%, 10%);
      transform-origin: center bottom; }
    .ag .ag__banner__box h1 {
      line-height: 1.2;
      font-size: 4vw; }
      .ag .ag__banner__box h1 b {
        display: block;
        font-size: 2.4em; }
  .ag .ag__bluebg {
    margin-top: 8rem; }
    .ag .ag__bluebg h2 {
      width: 100%;
      text-align: center;
      display: block;
      top: -1rem; }
      .ag .ag__bluebg h2 em {
        background: none;
        display: block;
        font-family: "HondaGlobalFontJP-Bold", sans-serif;
        font-size: min(6.4vw, 24px);
        color: #005bac; }
  .ag .ag__outline dl {
    display: block;
    padding-top: 1rem; }
  .ag .ag__outline dt {
    display: inline-block;
    letter-spacing: 1px;
    padding-top: 0; }
    .ag .ag__outline dt b {
      padding: 3px 4px 3px; }
  .ag .ag__outline dd {
    padding-left: 0;
    padding-top: 8px;
    font-size: min(3.1vw, 16px); }
  .ag .ag__outline small {
    font-size: 11px;
    display: inline-block;
    line-height: 1.4; }
  .ag .ag__outline p small {
    display: inline; }
  .ag .ag__supplies {
    padding-top: 4rem; }
    .ag .ag__supplies h2 {
      font-size: min(5.8vw, 24px);
      letter-spacing: 2px;
      color: #005bac; }
    .ag .ag__supplies ul li {
      margin-top: 2rem;
      margin-bottom: 1rem;
      flex: 0 0 100%; }
      .ag .ag__supplies ul li em {
        font-size: min(5vw, 21px); }
    .ag .ag__supplies h3 {
      font-size: 1em; }
  .ag .ag__table {
    font-size: 0.8em; }
    .ag .ag__table .tsp {
      display: table-row; }
    .ag .ag__table .tpc {
      display: none; }
    .ag .ag__table th {
      text-align: center; }
  .ag .ag__howto__flow {
    flex-direction: column;
    padding-bottom: 0; }
    .ag .ag__howto__flow dl {
      flex: auto;
      display: flex;
      flex-direction: row;
      margin-bottom: 4rem;
      justify-content: flex-start; }
      .ag .ag__howto__flow dl:last-child {
        margin-bottom: 1rem; }
    .ag .ag__howto__flow dt {
      flex: 1 1 auto;
      font-size: min(3.8vw, 20px);
      padding: 1rem;
      flex-direction: row; }
      .ag .ag__howto__flow dt small {
        flex: 0 0 100%; }
    .ag .ag__howto__flow dd {
      padding: 2rem;
      flex: 0 0 170px;
      display: flex;
      justify-content: center;
      align-items: center; }
      .ag .ag__howto__flow dd img {
        margin: auto;
        max-width: 55%; }
      .ag .ag__howto__flow dd::after {
        right: 100%;
        top: 100%;
        width: 2em;
        height: 1.25em;
        transform: translate(50%, 50%);
        clip-path: polygon(0 0, 100% 0, 50% 100%); } }
