

/* ========================================
   Primitive Tokens（変更不可）
   ======================================== */
:root {
  --white: #ffffff;
  --black: #000000;

  /* Primary */
  --color-primary-50: #f6fbfb;
  --color-primary-100: #eaf5f4;
  --color-primary-200: #b8e0e0;
  --color-primary-300: #89d1d1;
  --color-primary-400: #5cc7c7;
  --color-primary-500: #14b4b4;
  --color-primary-600: #009a9a;
  --color-primary-700: #168989;
  --color-primary-800: #057e7e;
  --color-primary-900: #005b5e;

  /* Gray */
  --color-gray-50: #f5f6f6;
  --color-gray-100: #eaeced;
  --color-gray-200: #d5d9d9;
  --color-gray-300: #b1b6b7;
  --color-gray-400: #9ea3a3;
  --color-gray-500: #888e8e;
  --color-gray-600: #697071;
  --color-gray-700: #4a5253;
  --color-gray-800: #3e4847;
  --color-gray-900: #242727;

  /* Decorative（装飾・演出専用） */
  --color-deco-lemon: #ffe041;
  --color-deco-lemon-light: #fef9d3;

  /* font-size */
  --font-size-12: 12px;
  --font-size-14: 14px;
  --font-size-16: 16px;
  --font-size-18: 18px;
  --font-size-20: 20px;
  --font-size-24: 24px;
  --font-size-28: 28px;
  --font-size-32: 32px;
  --font-size-40: 40px;
  --font-size-48: 48px;

  /* font-weight */
  --font-weight-normal: 400;
  --font-weight-bold: 700;
}

/* ========================================
   System Palette（変更不可）
   ======================================== */
:root {
  --system-success: #15bb03;
  --system-error: #ff4855;

  /* プラン */
  --color-plan-a: #0aa8a8;
  --color-plan-a-bg-light: #e5f5f5;
  --color-plan-a-dark: #13888e;
  --color-plan-b: #3c9600;
  --color-plan-b-bg-light: #ebf4e5;
  --color-plan-b-dark: #2a6800;
  --color-plan-c: #2869a0;
  --color-plan-c-bg-light: #e9f0f5;
  --color-plan-c-dark: #002f57;
}

/* ========================================
   Semantic Tokens
   ======================================== */
/* primitive Tokens を値に設定 */
:root {
  /*  text */
  --text-300: var(--font-size-12);
  --text-400: var(--font-size-14);
  --text-500: var(--font-size-16);
  --text-600: var(--font-size-18);
  --text-700: var(--font-size-20);
  --text-800: var(--font-size-24);
  --text-900: var(--font-size-28);
  --text-1000: var(--font-size-32);
  --text-1100: var(--font-size-40);
  --text-1200: var(--font-size-48);
}

/* ========================================
   all
   ======================================== */
#price {
  font-size: 16px;
}
#price h3 {
  font-size: var(--text-1000);
  font-weight: var(--font-weight-normal);
  line-height: 1.4;
  text-align: center;
}
#price .h2title-sentence {
  margin: 0;
}
#price > section:first-of-type {
  padding: 20px 20px 0;
}

@media screen and (width <= 670px) {
  #price h3 {
    font-size: var(--text-800);
  }
}

/* ====================================
   Hero Section
   ==================================== */
#price .hero .hero-anker {
  display: flex;
  gap: 16px;
  justify-content: space-between;
  width: 100%;
  max-width: 1000px;
  margin: 128px auto 0;
}
#price .hero .hero-anker a {
  position: relative;
  display: block;
  width: 33%;
  padding: 16px;
  color: inherit;
  background-color: var(--color-primary-100);
  border-radius: 8px;
}
#price .hero .hero-anker a:nth-child(2) {
  background-color: var(--color-deco-lemon-light);
}
#price .hero .hero-anker a::after {
  position: absolute;
  top: -4px;
  right: 20px;
  bottom: 0;
  width: 7px;
  height: 7px;
  margin: auto;
  content: "";
  border-right: solid 2px #3296d2;
  border-bottom: solid 2px #3296d2;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: 0.5s;
}

@media screen and (width <= 940px) {
  #price .hero .hero-anker {
    margin-top: 80px;
  }
}
@media screen and (width <= 670px) {
  #price .hero .hero-anker {
    gap: 8px;
    margin-top: 40px;
  }
  #price .hero .hero-anker a {
    padding: 8px 8px 32px;
    font-size: var(--text-400);
    text-align: center;
  }
  #price .hero .hero-anker a span {
    display: none;
  }
  #price .hero .hero-anker a::after {
    inset: auto 0 16px;
  }
}

/* ====================================
   URIHO mini
   ==================================== */
#price .urihomini {
  margin-top: 96px;
}
#price .urihomini a {
  display: flex;
  justify-content: space-between;
  max-width: 700px;
  margin: 0 auto;
  color: inherit;
  text-align: center;
  background-color: var(--color-primary-500);
  border: 4px solid var(--color-primary-500);
  border-radius: 8px;
  transition: 0.2s;
}
#price .urihomini a:hover {
  text-decoration: none;
  background-color: var(--color-primary-700);
  border: 4px solid var(--color-primary-700);
}
#price .urihomini a .primary {
  flex-grow: 0.5;
  padding: 16px;
  background-color: var(--white);
  border-radius: 4px;
}
#price .urihomini a .primary p span {
  font-size: var(--text-700);
  font-weight: var(--font-weight-bold);
}
#price .urihomini a .primary .logo-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: center;
  margin-top: 8px;
}
#price .urihomini a .primary .logo-wrap figure {
  max-width: 200px;
}
#price .urihomini a .primary .logo-wrap figure img {
  width: 100%;
}
#price .urihomini a .secondary {
  flex-grow: 1.5;
  margin: 16px 0 8px;
  color: var(--white);
}
#price .urihomini a .secondary p:first-child {
  font-size: var(--text-800);
  font-weight: var(--font-weight-bold);
}
#price .urihomini a .secondary p:first-child span {
  font-size: var(--text-1000);
}
#price .urihomini a .secondary p:last-child {
  width: 100%;
  max-width: 160px;
  padding: 4px 0;
  margin: 0 auto;
  margin-top: 12px;
  text-align: center;
  border: 1px solid var(--white);
  border-radius: 400px;
  transition: 0.2s;
}
#price .urihomini a:hover .secondary p:last-child {
  color: var(--color-primary-700);
  background-color: var(--white);
}

@media screen and (width <= 670px) {
  #price .urihomini a {
    display: block;
  }
  #price .urihomini a .primary {
    padding-block: 16px 8px;
  }
  #price .urihomini a .primary p span {
    font-size: var(--text-500);
  }
  #price .urihomini a .secondary {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
  }
  #price .urihomini a .secondary p:first-child {
    font-size: var(--text-500);
  }
  #price .urihomini a .secondary p:first-child span {
    margin-inline: 4px;
  }
  #price .urihomini a .secondary p:last-child {
    max-width: 100px;
    margin: 0;
  }
}

/* ====================================
   料金表
   ==================================== */
#price .pricelist {
  max-width: 1020px;
  padding: 0 20px;
  margin: 0 auto;
  font-size: var(--text-500);
}
#price .pricelist .plana {
  color: var(--color-plan-a);
}
#price .pricelist .planb {
  color: var(--color-plan-b);
}
#price .pricelist .planc {
  color: var(--color-plan-c);
}
#price .pricelist .with-bg {
  box-sizing: border-box;
  display: inline;
  padding: 3px 13px;
  border-radius: 14px;
}
#price .pricelist .plana .with-bg {
  background-color: var(--color-plan-a-bg-light);
}
#price .pricelist .planb .with-bg {
  background-color: var(--color-plan-b-bg-light);
}
#price .pricelist .planc .with-bg {
  background-color: var(--color-plan-c-bg-light);
}
#price .pricelist .listtable {
  width: 100%;
  margin-top: 40px;
  font-weight: var(--font-weight-bold);
  line-height: 1.6;
  text-align: center;
}
#price .pricelist .listtable th {
  font-weight: var(--font-weight-bold);
  vertical-align: middle;
  text-align: center;
}
#price .pricelist .listtable td {
  background-color: #ffffff;
}
#price .pricelist .listtable .title p {
  font-size: var(--text-300);
  font-weight: var(--font-weight-normal);
}
#price .pricelist .listtable .box1 th,
#price .pricelist .listtable .box2 th {
  color: var(--white);
  background-color: var(--color-gray-600);
}
#price .pricelist .listtable .box1 td {
  position: relative;
  width: 26%;
  padding: 32px 0 24px;
  color: var(--white);
}
#price .pricelist .listtable .box1 td::before {
  position: absolute;
  bottom: -6px;
  left: 46%;
  z-index: 10;
  display: inline-block;
  width: 7%;
  height: 16%;
  content: "";
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
#price .pricelist .listtable .box1 .plana,
#price .pricelist .listtable .box1 .plana::before {
  background-color: var(--color-plan-a);
}
#price .pricelist .listtable .box1 .planb,
#price .pricelist .listtable .box1 .planb::before {
  background-color: var(--color-plan-b);
}
#price .pricelist .listtable .box1 .planc,
#price .pricelist .listtable .box1 .planc::before {
  background-color: var(--color-plan-c);
}
#price .pricelist .listtable .box1 .name {
  padding: 4px 1.5em;
  font-weight: var(--font-weight-normal);
  border-radius: 20px;
}
#price .pricelist .listtable .box1 .plana .name {
  background-color: var(--color-plan-a-dark);
}
#price .pricelist .listtable .box1 .planb .name {
  background-color: var(--color-plan-b-dark);
}
#price .pricelist .listtable .box1 .planc .name {
  background-color: var(--color-plan-c-dark);
}
#price .pricelist .listtable .box1 .price {
  margin-top: 8px;
  font-size: var(--text-1100);
}
#price .pricelist .listtable .box1 .price span {
  font-size: var(--text-500);
}
#price .pricelist .listtable .box2 th {
  padding: 20px 0;
}
#price .pricelist .listtable .box2 td {
  padding: 16px 0 24px;
  font-size: var(--text-500);
  vertical-align: middle;
  border-right: 1px solid #cccccc;
  border-bottom: 1px solid #cccccc;
}
#price .pricelist .listtable .box2 td .price {
  font-size: var(--text-1000);
}
#price .pricelist .listtable .op {
  position: absolute;
  font-size: var(--text-300);
}
#price .pricelist .listtable .box2 .title {
  border-top: 1px solid var(--color-gray-400);
}
#price .pricelist .listtable .box2 .title span {
  display: block;
}
#price .pricelist .listtable .box3 th {
  padding: 16px;
  color: var(--color-gray-600);
  background-color: var(--color-gray-100);
  border-top: 1px solid var(--color-gray-200);
  border-left: 1px solid var(--color-gray-200);
}
#price .pricelist .listtable .box3 td {
  line-height: 1.2;
  vertical-align: middle;
  background-color: var(--color-gray-50);
  border-top: 1px solid var(--color-gray-200);
  border-right: 1px solid var(--color-gray-200);
}
#price .pricelist .listtable .last td {
  border-bottom: 1px solid var(--color-gray-200);
}
#price .pricelist .listtable tr:last-child > * {
  border-bottom: 1px solid var(--color-gray-200);
}
#price .pricelist .etc {
  margin: 8px 0;
  font-size: var(--text-300);
  line-height: 1.6;
}
#price .pricelist .etc p.left {
  margin-right: auto;
}
#price .pricelist .etc a,
#price .castomplan .primary a {
  text-decoration: underline;
}
#price .pricelist .etc a:hover,
#price .castomplan .primary a:hover {
  text-decoration: none;
}
#price .pricelist .listtable td.star {
  font-size: 25px;
  line-height: 1;
  color: #eb9e00;
}

@media screen and (width <= 940px) {
  #price .pricelist .listtable .op {
    position: static;
  }
}
@media screen and (width <= 670px) {
  #price .pricelist {
    font-size: 12px;
  }
  #price .pricelist .listtable {
    margin-top: 24px;
  }
  #price .pricelist .listtable th {
    font-size: 12px;
    font-weight: normal;
  }
  #price .pricelist .listtable .title p {
    margin: 0.5em 0 0;
    font-size: 11px;
  }
  #price .pricelist .listtable .box1 td {
    width: 28%;
  }
  #price .pricelist .listtable .box1 .name {
    padding: 0;
    border-radius: 0;
  }
  #price .pricelist .listtable .box1 .price {
    font-size: 15px;
  }
  #price .pricelist .listtable .box1 .price span {
    font-size: 11px;
  }
  #price .pricelist .listtable .box2 td {
    padding: 0 0.3em;
    font-size: 12px;
  }
  #price .pricelist .listtable .box1 td::before {
    display: none;
  }
  #price .pricelist .listtable .box2 td .price {
    font-size: 16px;
  }
  #price .pricelist .listtable .box2.sp-p10 th {
    padding: 10px 0;
  }
  #price .pricelist .listtable .box3 th {
    padding: 20px 0;
  }
  #price .pricelist .etc {
    text-align: left;
  }
  #price .pricelist .with-bg {
    padding: 0;
    font-size: 11px;
    border-radius: 0;
  }
  #price .pricelist .listtable td.star {
    font-size: 18px;
  }
  #price .pricelist .sp-font10 {
    font-size: 10px;
  }
  #price .pricelist .listtable .op {
    position: static;
  }
  #price .pricelist .pt-only {
    display: none;
  }
  #price .pricelist .etc {
    display: inline-block;
  }
}

/* ====================================
	カスタムプラン
	==================================== */
#price .castomplan {
  padding: 24px 2em;
  font-size: var(--text-400);
  background-color: var(--color-primary-100);
}
#price .castomplan .castomplan-inner {
  display: flex;
  gap: 2em;
  align-items: center;
  justify-content: center;
}
#price .castomplan h3 {
  margin-bottom: 4px;
  font-size: var(--text-600);
  font-weight: var(--font-weight-bold);
  text-align: left;
}
#price .castomplan .secondary a {
  font-size: var(--text-1000);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-600);
}
#price .castomplan .secondary a:hover {
  text-decoration: none;
}
#price .castomplan address {
  font-style: normal;
}
#price .castomplan address img {
  height: 24px;
  margin-right: 8px;
}

@media screen and (width <= 940px) {
  #price .castomplan .castomplan-inner {
    max-width: 640px;
    margin: 0 auto;
  }
  #price .castomplan .primary {
    flex: 1.5;
  }
  #price .castomplan .secondary {
    flex: 1;
  }
}
@media screen and (width <= 670px) {
  #price .castomplan {
    padding-inline: 1.5em;
  }
  #price .castomplan .castomplan-inner {
    display: block;
  }
  #price .castomplan h3 {
    margin-bottom: 8px;
    font-size: var(--text-500);
  }
  #price .castomplan address {
    margin-top: 8px;
  }
  #price .castomplan address p {
    font-size: var(--text-300);
  }
  #price .castomplan .secondary a {
    font-size: var(--text-700);
  }
  #price .castomplan address img {
    height: 14px;
    margin-right: 6px;
  }
}

/* ====================================
	保証額の仕組み
	==================================== */
#system {
  max-width: 900px;
  margin: 32px auto 0;
}
section#system {
  padding-bottom: 64px;
}
#system .contents-wrap {
  margin-top: 48px;
}
#system h4 {
  font-size: var(--text-800);
  line-height: 1.6;
}
#system .ex {
  display: flex;
  gap: 16px;
}
#system .ex .secondary {
  flex: 1;
}
#system .ex-title {
  margin-top: 32px;
  font-size: var(--text-600);
  font-weight: var(--font-weight-bold);
}
#system .sentence-title {
  margin-top: 16px;
  font-size: var(--text-900);
  line-height: 1.6;
}
#system .sentence-title br {
  display: none;
}
#system .sentence-wrap {
  margin-top: 24px;
}
#system .sentence {
  position: relative;
  padding-left: 24px;
  margin-top: 16px;
}
#system .sentence::before {
  position: absolute;
  top: 6px;
  left: 0;
  display: inline-block;
  width: 16px;
  height: 14px;
  content: "";
  background: url(/web/img/pre/top/check.svg) 0 0 no-repeat;
  background-size: 16px;
}
#system .secondary img {
  width: 100%;
  max-width: 500px;
}

@media screen and (width <= 940px) {
  #system .sentence-title {
    font-size: var(--text-800);
  }
  #system .ex {
    align-items: center;
  }
}
@media screen and (width <= 670px) {
  #system {
    margin-top: 16px;
  }
  #system .contents-wrap {
    margin-top: 32px;
  }
  #system h4 {
    font-size: var(--text-500);
  }
  #system h4 br {
    display: none;
  }
  #system .ex {
    display: block;
  }
  #system .ex-title {
    font-size: var(--text-500);
  }
  #system .sentence-title {
    font-size: var(--text-800);
  }
  #system .sentence {
    margin-top: 8px;
  }
  #system .secondary {
    margin-top: 24px;
  }
}

/* ====================================
 1ヵ月無料
	==================================== */
#free {
  max-width: 900px;
  padding: 56px 20px;
  margin: 0 auto;
  background-color: var(--color-primary-100);
}
#free h3 span {
  display: block;
  width: 100px;
  padding: 8px;
  margin: 0 auto 16px;
  font-size: var(--text-700);
  background-color: var(--color-deco-lemon);
}
#free .contents-wrap {
  display: flex;
  gap: 2em;
  justify-content: space-between;
  max-width: 760px;
  margin: 64px auto 0;
}
#free .contents-wrap .primary {
  flex-grow: 1;
}
#free .contents-wrap .primary h4 {
  font-size: var(--text-800);
}
#free .contents-wrap .primary figure {
  max-width: 500px;
  margin-block: 40px 16px;
}
#free .contents-wrap .primary img {
  width: 100%;
}
#free .contents-wrap .primary .ex {
  display: flex;
  font-size: var(--text-300);
}
#free .contents-wrap .secondary {
  flex-basis: 260px;
}
#free .contents-wrap .secondary h4 {
  font-size: var(--text-600);
  font-weight: var(--font-weight-bold);
}
#free .contents-wrap .secondary li {
  position: relative;
  padding-left: 24px;
  margin-top: 16px;
}
#free .contents-wrap .secondary li::before {
  position: absolute;
  top: 6px;
  left: 0;
  display: inline-block;
  width: 16px;
  height: 14px;
  content: "";
  background: url(/web/img/pre/top/check.svg) 0 0 no-repeat;
  background-size: 16px;
}
#free .contents-wrap .secondary .note {
  margin-top: 16px;
  font-size: var(--text-300);
}

@media screen and (width <= 940px) {
  #free .contents-wrap {
    margin-top: 64px;
  }
}
@media screen and (width <= 670px) {
  #free h3 span {
    width: 64px;
    padding: 4px;
    margin: 0 auto 8px;
    font-size: var(--text-400);
    font-weight: var(--font-weight-bold);
  }
  #free .contents-wrap {
    display: block;
    margin: 40px auto 0;
  }
  #free .contents-wrap .primary h4 {
    font-size: var(--text-600);
  }
  #free .contents-wrap .primary figure {
    margin-top: 24px;
  }
  #free .contents-wrap .secondary {
    margin-top: 24px;
  }
  #free .contents-wrap .secondary h4 {
    font-size: var(--text-500);
  }
  #free .contents-wrap .secondary ul {
    margin-top: 16px;
  }
  #free .contents-wrap .secondary li {
    margin-top: 8px;
  }
}

/* ====================================
	有料オプション
	==================================== */
#option {
  max-width: 900px;
  margin: 0 auto;
}
#option h3 + p {
  margin-block: 16px;
  line-height: 1.6;
  text-align: center;
}
#option .contents-wrap {
  margin-block: 32px;
}
#option .contents-wrap .card-wrap {
  display: flex;
  gap: 24px;
}
#option .contents-wrap .card {
  flex: 1;
  padding: 40px;
  line-height: 1.6;
  background-color: var(--color-gray-50);
}
#option .contents-wrap h4 {
  padding-block: 0 8px;
  font-size: var(--text-800);
  font-weight: var(--font-weight-bold);
  border-bottom: 1px solid var(--color-gray-200);
}
#option .text-wrap > p {
  margin-block: 16px;
}
#option h5 {
  margin-block: 16px 8px;
  font-weight: var(--font-weight-bold);
}
#option .text-wrap li {
  margin-inline: 24px;
  list-style-position: outside;
  list-style-type: disc;
}
#option .note {
  margin-block: 24px;
  text-align: right;
}
#option .note a {
  text-decoration: underline;
}
#option .note a:hover {
  text-decoration: none;
}

@media screen and (width <= 940px) {
  #option .contents-wrap .card-wrap {
    gap: 1em;
  }
  #option .contents-wrap .card {
    padding: 32px;
  }
}
@media screen and (width <= 670px) {
  #option h3 + p {
    margin-block: 8px;
    font-size: var(--text-400);
  }
  #option .contents-wrap .card-wrap {
    display: block;
  }
  #option .contents-wrap .card {
    padding: 24px;
    margin-top: 16px;
  }
  #option .contents-wrap h4 {
    padding-block: 0 8px;
    font-size: var(--text-700);
  }
  #option .text-wrap li {
    font-size: var(--text-400);
  }
  #option .note {
    margin-block: 16px;
    font-size: var(--text-400);
    text-align: left;
  }
}
