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

index

------------------------
	0. base
	1. layout
			1.1 header
			1.2 footer
	2. module
			2.1 container
			2.2 accordion
			2.3 tab
			2.4 label
			2.5 table
			2.6 input
			2.7 radio
			2.8 checkbox
			2.9 select
			2.10 button
			2.11 section
			2.12 status
			2.13 facility
			2.14 detail
			2.15 note
			2.16 ballon
			2.17 window
			2.18 plan
			2.19 confirm
			2.20 carousel
			2.21 modal
			2.22 card
			2.23 star
			2.24 search
			2.25 pagination
			2.26 feature
			2.27 attention
			2.28 recommend
			2.29 information
			2.30 map
			2.31 hotel
			2.32 popup
 */
 /*--------------------------------

0. base

 --------------------------------*/
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0; }

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

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

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

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

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

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

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

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

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

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

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

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

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

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

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

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block; }

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

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none; }

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

/* reset
========================================================================== */
div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video, input, textarea {
  margin: 0;
  padding: 0;
  border: none;
  font-size: 100%;
  font-weight: normal;
  font-style: normal;
  vertical-align: baseline;
  background: transparent; }

img {
  vertical-align: top; }

input {
  display: inline;
  vertical-align: middle; }
  input:focus {
    outline: none; }

button:focus {
  outline: none; }

body {
  height: 100%;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 14px;
  color: #333;
  line-height: 1;
  letter-spacing: 0.01rem;
  -webkit-font-smoothing: antialiased; }

html.is-fixed,
body.is-fixed {
  overflow: hidden;
  height: 100%; }

a {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

/*--------------------------------

1. layout

--------------------------------*/
/*--------------------------------
1.1 header
--------------------------------*/
.f-header {
  display: flex;
  align-items: center;
  width: 100%;
  height: 60px;
  border-top: 4px solid #20208C;
  box-sizing: border-box; }

.f-header__inner {
  display: flex;
  align-items: center;
  width: calc(100% - 60px);
  height: 60px;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-header__logo {
  width: 160px;
  margin-left: 12px;
  padding-bottom: 4px; }

.f-header__label {
  width: 100px;
  margin-left: 15px; }

.f-header__menu,
.f-header__menu-inner {
  display: inline-block;
  box-sizing: border-box;
  transition: all 0.4s ease-out; }

.f-header__menu {
  position: relative;
  width: 60px;
  height: 60px;
  background-color: #20208C;
  box-sizing: border-box; }

.f-header__menu-inner {
  position: absolute;
  left: 20px;
  width: 20px;
  height: 2px;
  margin-top: 21px;
  margin-bottom: 21px;
  background-color: #fff; }

.f-header__menu-inner:nth-of-type(1) {
  top: 0; }

.f-header__menu-inner:nth-of-type(2) {
  top: 8px; }

.f-header__menu-inner:nth-of-type(3) {
  bottom: 0; }

.is-open .f-header__menu-inner:nth-of-type(1) {
  transform: translateY(7px) rotate(-45deg); }

.is-open .f-header__menu-inner:nth-of-type(2) {
  opacity: 0; }

.is-open .f-header__menu-inner:nth-of-type(3) {
  transform: translateY(-9px) rotate(45deg); }

.f-header-nav {
  display: none;
  position: absolute;
  top: 62px;
  left: 0;
  width: 100%;
  height: calc(100vh - 60px);
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 10; }

nav.f-header-nav ul.f-header-nav__list {
  height: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch; }

.f-header-nav__item {
  list-style: none; }

.f-header-nav__link {
  display: block;
  position: relative;
  padding: 22px 20px;
  font-size: 16px;
  font-weight: bold;
  color: #333;
  text-decoration: none;
  background-color: #fff;
  border-bottom: 1px solid #dedede; }
  .f-header-nav__link::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-header-nav__button {
  padding-top: 18px;
  padding-bottom: 18px;
  color: #fff;
  text-align: center;
  background-color: #a0a0a0; }

.f-header-nav__text {
  position: relative;
  padding-right: 28px;
  font-weight: bold; }
  .f-header-nav__text::before {
    content: "";
    display: block;
    position: absolute;
    top: -1px;
    right: 13px;
    width: 2px;
    height: 16px;
    background-color: #fff;
    transform: rotate(45deg); }
  .f-header-nav__text::after {
    content: "";
    display: block;
    position: absolute;
    top: 6px;
    right: 6px;
    width: 16px;
    height: 2px;
    background-color: #fff;
    transform: rotate(45deg); }

@media screen and (max-width: 320px) {
  .f-header__logo {
    width: 140px; }

  .f-header__label {
    width: 80px;
    margin-left: 10px; } }
/*--------------------------------
1.2 footer
--------------------------------*/
.f-footer-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 90px;
  padding-left: 12px;
  padding-right: 12px;
  border-top: 1px solid #dedede; }

.f-footer-top__text {
  font-size: 12px;
  color: #a0a0a0; }

.f-footer-top__link {
  position: relative;
  width: 120px;
  height: 26px;
  padding-top: 7px;
  padding-left: 18px;
  font-size: 10px;
  color: #333;
  text-decoration: none;
  background-color: #ededed;
  border: 1px solid #ccc;
  border-radius: 2px;
  box-sizing: border-box;
  transition: opacity 0.2s ease-out; }
  .f-footer-top__link::after {
    content: "";
    position: absolute;
    top: 10px;
    right: 17px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #333;
    border-left: 2px solid #333;
    transform: rotate(45deg); }

.f-footer-middle {
  width: 100%;
  padding: 30px 12px 10px;
  background-color: #ededed;
  border-top: 1px solid #dedede;
  box-sizing: border-box; }

.f-footer-middle__list + .f-footer-middle__list {
  margin-top: 8px;
  padding-top: 25px;
  border-top: 1px solid #dedede; }

.f-footer-middle__item {
  display: inline-block;
  position: relative;
  margin-right: 9px;
  margin-bottom: 18px;
  padding-right: 15px;
  list-style: none;
  line-height: 12px;
  white-space: nowrap; }
  .f-footer-middle__item:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 1px;
    height: 11px;
    background-color: #a0a0a0;
    transform: translateY(-40%); }

.f-footer-middle__link {
  display: inline;
  font-size: 12px;
  line-height: 1;
  text-decoration: none;
  color: #333; }

.f-footer-bottom {
  width: 100%;
  background-color: #20208C; }

.f-footer-bottom__container {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px; }

.f-footer-bottom__copyright {
  font-family: Helvetica, sans-serif;
  font-size: 10px;
  color: #fff; }

@media screen and (min-width: 321px) and (max-width: 440px) {
  .f-footer-middle__list:first-child > .f-footer-middle__item:nth-child(3) {
    margin-right: 0;
    padding-right: 0; }
    .f-footer-middle__list:first-child > .f-footer-middle__item:nth-child(3)::after {
      background: none; }
  .f-footer-middle__list:last-child > .f-footer-middle__item:nth-child(2), .f-footer-middle__list:last-child > .f-footer-middle__item:last-child {
    margin-right: 0; }
    .f-footer-middle__list:last-child > .f-footer-middle__item:nth-child(2)::after, .f-footer-middle__list:last-child > .f-footer-middle__item:last-child::after {
      background: none; } }
@media screen and (max-width: 320px) {
  .f-footer-bottom__copyright {
    font-size: 9px; } }
/*--------------------------------

2. module

--------------------------------*/
/*--------------------------------
2.1 container
--------------------------------*/
.f-container {
  width: 100%;
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box; }

.f-container_flex {
  display: flex;
  justify-content: space-between; }

.f-container_half {
  width: 470px; }
  .f-container_half + .f-container_half {
    margin-left: 10px; }

/*--------------------------------
2.2 accordion
--------------------------------*/
.f-accordion__button {
  position: relative;
  width: 22px;
  height: 22px;
  background-color: #20208C;
  border-radius: 22px; }
  .f-accordion__button::before, .f-accordion__button::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 6px;
    width: 10px;
    height: 1px;
    background-color: #fff;
    transform: translateY(-50%); }
  .f-accordion__button::before {
    top: 50%;
    right: 10px;
    width: 1px;
    height: 10px;
    transform-origin: center;
    transition: transform 0.2s ease-out; }
  .f-accordion__button.is-open::before {
    transform: translateY(-50%) rotate(-90deg); }

.f-accordion__button--white {
  position: relative;
  width: 22px;
  height: 22px;
  background-color: #fff;
  border-radius: 22px; }
  .f-accordion__button--white::before, .f-accordion__button--white::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 6px;
    width: 10px;
    height: 1px;
    background-color: #20208C;
    transform: translateY(-50%); }
  .f-accordion__button--white::before {
    top: 50%;
    right: 10px;
    width: 1px;
    height: 10px;
    transform-origin: center;
    transition: transform 0.2s ease-out; }
  .f-accordion__button--white.is-open::before {
    transform: translateY(-50%) rotate(-90deg); }

.f-accordion-more__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 30px;
  margin: 10px auto 20px;
  font-size: 11px;
  border: 1px solid #ccc;
  border-radius: 2px;
  transition: all 0.2s ease; }
  .f-accordion-more__button.is-open {
    display: none; }

.f-accordion_more__text {
  position: relative;
  padding-right: 15px; }
  .f-accordion_more__text::before {
    content: "";
    position: absolute;
    top: 1px;
    right: 4px;
    width: 1px;
    height: 9px;
    background-color: #333; }
  .f-accordion_more__text::after {
    content: "";
    position: absolute;
    top: 5px;
    right: 0;
    width: 9px;
    height: 1px;
    background-color: #333; }

.f-accordion-more {
  display: none;
  padding-bottom: 20px; }

.f-accordion__button {
  position: relative;
  width: 22px;
  height: 22px;
  background-color: #20208C;
  border-radius: 22px; }
  .f-accordion__button::before, .f-accordion__button::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 6px;
    width: 10px;
    height: 1px;
    background-color: #fff;
    transform: translateY(-50%); }
  .f-accordion__button::before {
    top: 50%;
    right: 10px;
    width: 1px;
    height: 10px;
    transform-origin: center;
    transition: transform 0.2s ease-out; }
  .f-accordion__button.is-open::before {
    transform: translateY(-50%) rotate(-90deg); }

/*--------------------------------
2.3 tab
--------------------------------*/
.f-tab__menu--medium {
  display: flex;
  justify-content: space-between;
  margin-top: 36px;
  padding-left: 12px;
  padding-right: 12px;
  border-bottom: 2px solid #dedede; }

.f-tab__item--medium {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  width: 48.5%;
  height: 60px;
  font-weight: bold;
  border-top: 2px solid #dedede;
  box-sizing: border-box;
  cursor: pointer; }

.f-tab__item--medium.is-active {
  position: relative;
  color: #20208C;
  border-top: 2px solid #20208C;
  border-left: 2px solid #dedede;
  border-right: 2px solid #dedede; }
  .f-tab__item--medium.is-active::before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #fff; }
  .f-tab__item--medium.is-active::after {
    content: "";
    position: absolute;
    bottom: -3px;
    left: 50%;
    border: 4px solid transparent;
    border-top: 8px solid #20208C;
    transform: translateX(-50%); }
  .f-tab__item--medium.is-active > .f-tab__item-inner {
    margin-top: -1px; }
    .f-tab__item--medium.is-active > .f-tab__item-inner > .f-tab__icon {
      margin-top: 0; }

.f-tab__menu-bottom--medium {
  display: flex;
  justify-content: space-between;
  margin-bottom: 40px;
  padding-left: 12px;
  padding-right: 12px;
  border-top: 2px solid #dedede; }

.f-tab__item-bottom--medium {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  width: 48.5%;
  height: 60px;
  font-weight: bold;
  border-bottom: 2px solid #dedede;
  box-sizing: border-box;
  cursor: pointer; }

.f-tab__item-bottom--medium.is-active {
  position: relative;
  color: #20208C;
  border-bottom: 2px solid #20208C;
  border-left: 2px solid #dedede;
  border-right: 2px solid #dedede; }
  .f-tab__item-bottom--medium.is-active::before {
    content: "";
    position: absolute;
    top: -2px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #fff; }
  .f-tab__item-bottom--medium.is-active::after {
    content: "";
    position: absolute;
    top: -3px;
    left: 50%;
    border: 4px solid transparent;
    border-bottom: 8px solid #20208C;
    transform: translateX(-50%); }
  .f-tab__item-bottom--medium.is-active > .f-tab__item-inner {
    margin-top: -1px; }
    .f-tab__item-bottom--medium.is-active > .f-tab__item-inner > .f-tab__icon {
      margin-top: 0; }

.f-tab__icon-facility {
  position: relative;
  padding-left: 20px;
  font-weight: bold; }
  .f-tab__icon-facility::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 13px;
    height: 13px;
    background: url("../images/icon/ico_facility02.png") no-repeat 0 0;
    background-size: 13px 13px;
    transform: translateY(-50%); }

.f-tab__icon-facility-plan {
  position: relative;
  padding-left: 20px;
  font-weight: bold; }
  .f-tab__icon-facility-plan::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 16px;
    height: 12px;
    background: url("../images/icon/ico_facility01.png") no-repeat 0 0;
    background-size: 16px 12px;
    transform: translateY(-50%); }

.f-tab__icon-map {
  position: relative;
  padding-left: 15px;
  font-weight: bold; }
  .f-tab__icon-map::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 10px;
    height: 13px;
    background: url("../images/icon/ico_pointer01.png") no-repeat 0 0;
    background-size: 10px 13px;
    transform: translateY(-50%); }

.f-tab__icon-plan {
  position: relative;
  padding-left: 20px;
  font-weight: bold; }
  .f-tab__icon-plan::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 15px;
    height: 13px;
    background: url("../images/icon/ico_plan01.png") no-repeat 0 0;
    background-size: 15px 13px;
    transform: translateY(-50%); }

.f-tab__content--small {
  display: none;
  padding-top: 13px;
  padding-bottom: 13px; }

.f-tab__content--small.is-active {
  display: block; }

.f-tab__content--medium {
  display: none;
  padding-top: 20px;
  padding-bottom: 40px;
  overflow: hidden; }

.f-tab__content--medium.is-active {
  display: block; }

.f-tab__menu {
  display: flex; }

.f-tab__item {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 50%;
  height: 53px;
  font-weight: bold;
  line-height: 35px;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box;
  cursor: pointer; }
  .f-tab__item::before {
    content: "";
    position: absolute;
    top: 0;
    left: 10px;
    width: calc(100% - 20px);
    height: 1px;
    background-color: #ededed; }

.f-tab__icon {
  width: 14px;
  margin-left: 8px; }

.f-tab__item.is-active {
  position: relative;
  color: #20208C;
  border-top: 1px solid #20208C;
  border-left: 1px solid #dedede;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #fff; }
  .f-tab__item.is-active > .f-tab__icon {
    margin-top: -1px; }

.f-tab__item.is-active::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 50%;
  border: 4px solid transparent;
  border-top: 8px solid #20208C;
  transform: translateX(-50%); }

.f-tab__content {
  display: none;
  padding-top: 13px;
  padding-bottom: 13px;
  overflow: hidden; }

.f-tab__content.is-active {
  display: block; }

.f-tab-three__menu {
  display: flex;
  width: 100%; }
  .f-tab-three__menu.is-fixed {
    position: fixed;
    top: 70px;
    left: 0; }

.f-tab-three__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 33.333%;
  height: 46px;
  color: #20208C;
  background-color: #fff;
  border-top: 2px solid #20208C;
  border-bottom: 2px solid #20208C;
  box-sizing: border-box;
  cursor: pointer; }
  .f-tab-three__item + .f-tab-three__item {
    border-left: 2px solid #20208C; }

.f-tab-three__item.is-active {
  color: #fff;
  background-color: #20208C; }
  .f-tab-three__item.is-active .f-tab-tree__icon {
    color: #20208C;
    background-color: #fff; }

.f-tab-three__content {
  display: none;
  overflow: hidden; }

.f-tab-three__content.is-active {
  display: block; }

.f-tab-tree__icon {
  display: inline-block;
  width: 26px;
  height: 26px;
  margin-right: 10px;
  padding: 5px;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  background-color: #20208C;
  border-radius: 26px;
  box-sizing: border-box; }

.f-tab-favorite {
  margin-bottom: 30px; }

.f-tab-favorite__menu {
  display: flex;
  border-bottom: 2px solid #ffb100; }

.f-tab-favorite__item {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  width: 49%;
  height: 46px;
  padding-top: 4px;
  font-weight: bold;
  color: #a0a0a0;
  background-color: #ededed;
  box-sizing: border-box;
  cursor: pointer; }
  .f-tab-favorite__item + .f-tab-favorite__item {
    margin-left: 2%; }

.f-tab-favorite__item.is-active {
  position: relative;
  color: #fff;
  background-color: #ffb100;
  border-bottom: 2px solid #ffb100; }

.f-tab__icon-heart {
  position: relative;
  padding-left: 18px;
  font-weight: bold; }
  .f-tab__icon-heart::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 14px;
    height: 12px;
    background: url("../images/icon/ico_heart04.png") no-repeat 0 0;
    background-size: 14px 12px;
    transform: translateY(-48%); }

.is-active .f-tab__icon-heart::before {
  background: url("../images/icon/ico_heart03.png") no-repeat 0 0;
  background-size: 14px 12px; }

.f-tab__icon-history {
  position: relative;
  padding-left: 18px;
  font-weight: bold; }
  .f-tab__icon-history::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 14px;
    height: 14px;
    background: url("../images/icon/ico_history02.png") no-repeat 0 0;
    background-size: 14px 14px;
    transform: translateY(-48%); }

.is-active .f-tab__icon-history::before {
  background: url("../images/icon/ico_history01.png") no-repeat 0 0;
  background-size: 14px 14px; }

.f-tab-favorite__content {
  display: none;
  padding: 18px 12px;
  background-color: #fff9f0; }

.f-tab-favorite__content.is-active {
  display: block; }

.f-tab-favorite__inner {
  padding-top: 1px;
  padding-bottom: 1px;
  background-color: #fff; }
  .f-tab-favorite__inner .f-card__copy {
    padding-right: 8px; }

.f-tab__train-text {
  position: relative;
  margin-top: 5px;
  font-weight: bold; }

.f-tab__text--small {
  width: 100%;
  color: #cc0d39;
  font-weight: bold;
  text-align: center;
  margin-bottom: 12px;
  font-size: 12px; }

/*--------------------------------
2.4 label
--------------------------------*/
.f-label {
  font-size: 0; }

.f-label-type {
  display: inline-block;
  height: 21px;
  margin-top: 5px;
  margin-right: 3px;
  padding: 5px 5px;
  font-size: 11px;
  font-weight: bold;
  color: #fff;
  list-style: none;
  background-color: #a0a0a0;
  box-sizing: border-box; }

.f-label-type--line {
  display: inline-block;
  height: 21px;
  margin-top: 5px;
  margin-right: 3px;
  padding: 5px 5px;
  font-size: 11px;
  font-weight: bold;
  color: #ccc;
  list-style: none;
  border: 1px dotted #ccc;
  box-sizing: border-box; }

.f-label-type--large {
  display: inline-block;
  height: 25px;
  margin-top: 5px;
  margin-right: 7px;
  padding: 7px 8px 5px;
  font-size: 11px;
  font-weight: bold;
  color: #fff;
  list-style: none;
  background-color: #a0a0a0;
  box-sizing: border-box; }

.f-label-type--large-line {
  display: inline-block;
  height: 25px;
  margin-top: 5px;
  margin-right: 7px;
  padding: 6px 8px;
  font-size: 11px;
  font-weight: bold;
  color: #ccc;
  list-style: none;
  border: 1px dotted #ccc;
  box-sizing: border-box; }

.f-label-type__icon-nosmorking {
  display: inline-block;
  height: 11px;
  padding-left: 13px;
  font-weight: bold;
  background: url("../images/icon/ico_nosmoking01.png") no-repeat 0 center;
  background-size: 11px 11px; }

.f-label-train--standard {
  display: inline-block;
  margin-top: 6px;
  margin-right: 8px;
  margin-bottom: 4px;
  padding: 2px 11px;
  font-size: 11px;
  font-weight: bold;
  background-color: #fff;
  border: 1px solid #ccc; }

.f-label-train--green {
  display: inline-block;
  margin-top: 6px;
  margin-right: 8px;
  margin-bottom: 4px;
  padding: 2px 11px;
  font-size: 11px;
  font-weight: bold;
  color: #27a639;
  background-color: #fff;
  border: 1px solid #27a639; }

.f-label-limited {
  display: inline-block;
  margin-top: 6px;
  margin-right: 8px;
  padding: 6px;
  font-size: 11px;
  font-weight: bold;
  color: #fff;
  background-color: #20208C; }

.f-label-limited--small {
  display: inline-block;
  margin-top: 6px;
  margin-right: 8px;
  padding: 5px 10px 4px;
  font-size: 10px;
  font-weight: bold;
  color: #fff;
  background-color: #20208C; }

.f-label-left {
  display: inline-block;
  margin-top: 6px;
  margin-right: 5px;
  padding: 4px 10px;
  font-size: 10px;
  font-weight: bold;
  color: #cc0d21;
  background-color: #ffeaf1;
  border: 1px solid #e61b61;
  box-sizing: border-box; }

/*--------------------------------
2.5 table
--------------------------------*/
.f-table {
  width: 100%;
  border-top: 1px solid #dedede;
  border-collapse: collapse; }

.f-table__head {
  height: 36px;
  padding-left: 3px;
  padding-right: 3px;
  font-size: 12px;
  line-height: 1.3;
  vertical-align: middle;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-table__head:last-child {
    border-right: none; }

.f-table__head--strong {
  display: block;
  margin-left: 7px;
  font-weight: bold;
  text-align: left; }

.f-table__head--center {
  font-weight: bold;
  text-align: center; }

.f-table__row-body.is-checked {
  background-color: #ffeaf1; }

.f-table__data {
  padding: 14px 12px;
  line-height: 1.3;
  vertical-align: middle;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-table__data:last-child {
    border-right: none; }

.f-table__text--small {
  font-size: 8px; }

.f-table__text--medium {
  font-size: 12px; }

.f-table__text--strong {
  font-weight: bold; }

.f-table__text--right {
  text-align: right; }

.f-table__text--important {
  margin-left: 10px;
  font-weight: bold;
  color: #cc0d21; }

.f-table__text--middle {
  margin-top: 10px;
  margin-right: -12px;
  margin-bottom: 10px;
  font-size: 13px;
  line-height: 1.5; }

.f-table-train__cell--button {
  width: 92px; }

.f-table-train__cell--medium {
  width: 70px;
  text-align: center;
  vertical-align: top; }

.f-table-train__cell--large {
  width: 86px;
  text-align: right;
  white-space: nowrap; }

.f-table-calendar {
  width: 100%;
  border-top: 1px solid #a0a0a0;
  border-left: 1px solid #a0a0a0;
  border-collapse: collapse; }

.f-table-calendar__head {
  font-weight: bold;
  background-color: #ededed;
  border-right: 1px solid #a0a0a0;
  border-bottom: 1px solid #a0a0a0; }

.f-table-calendar__head,
.f-table-calendar__data {
  position: relative;
  width: 14.28%;
  height: auto;
  box-sizing: border-box; }
  .f-table-calendar__head:first-child,
  .f-table-calendar__data:first-child {
    font-weight: bold;
    color: #cc0d21; }
  .f-table-calendar__head:last-child,
  .f-table-calendar__data:last-child {
    font-weight: bold;
    color: #21A4Ea; }
  .f-table-calendar__head::before,
  .f-table-calendar__data::before {
    content: "";
    display: block;
    padding-top: 100%; }

.f-table-calendar__head--strong {
  display: block;
  margin-left: 7px;
  font-weight: bold;
  text-align: left; }

.f-table-calendar__row-body.is-checked {
  background-color: #ffeaf1; }

.f-table-calendar__data {
  font-family: Helvetica, sans-serif;
  border-right: 1px solid #a0a0a0;
  border-bottom: 1px solid #a0a0a0;
  background-clip: padding-box; }

.f-table-calendar__inner {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }

.f-table-calendar__day-today {
  background-color: #fff9f0;
  background-clip: padding-box; }

.f-table-calendar__day-select {
  color: #e61b61;
  background-color: #ffeaf1;
  background-clip: padding-box; }

.f-table--row {
  width: 100%;
  border-collapse: collapse; }

.f-table__head--row {
  padding-top: 18px;
  padding-bottom: 18px;
  padding-left: 12px;
  text-align: left;
  border-bottom: 1px solid #dedede; }

.f-table__data--row {
  padding-top: 18px;
  padding-bottom: 18px;
  padding-right: 12px;
  text-align: right;
  border-bottom: 1px solid #dedede; }

.f-table-line {
  width: 100%;
  margin-top: 15px;
  margin-bottom: 20px;
  border-top: 1px solid #dedede;
  border-collapse: collapse; }

.f-table-line__head {
  padding: 18px 12px;
  font-weight: bold;
  text-align: left;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-table-line__data {
  padding: 18px 12px;
  border-bottom: 1px solid #dedede; }

.f-table-line__data-right {
  padding: 18px 12px;
  font-size: 12px;
  text-align: right;
  border-bottom: 1px solid #dedede; }

.f-table-line__text--strong {
  font-weight: bold;
  font-size: 14px;
  color: #cc0d21; }

/*--------------------------------
2.6 input
--------------------------------*/
.f-input {
  width: 100%;
  height: 42px;
  padding: 10px;
  line-height: normal;
  border: 1px solid #a0a0a0;
  border-radius: 4px;
  box-shadow: none;
  box-sizing: border-box;
  appearance: none; }

.f-input-calendar__wrap {
  position: relative; }
  .f-input-calendar__wrap + .f-input-calendar__wrap {
    position: relative;
    margin-top: 25px; }
    .f-input-calendar__wrap + .f-input-calendar__wrap::before {
      content: "";
      position: absolute;
      top: -16px;
      left: 23px;
      width: 0;
      height: 0;
      border-right: 5px solid transparent;
      border-left: 5px solid transparent;
      border-top: 10px solid #a0a0a0;
      transform: translateX(-50%); }

.f-input-calendar {
  position: relative;
  width: 100%;
  height: 34px;
  padding: 10px 30px 10px 10px;
  line-height: normal;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: none;
  box-sizing: border-box;
  appearance: none; }

.is-attention .f-input-calendar {
  position: relative;
  width: 100%;
  height: 34px;
  padding: 10px 30px 10px 10px;
  line-height: normal;
  background-color: #fff9f0;
  border: 1px solid #cc0d21;
  border-radius: 4px;
  box-shadow: none;
  box-sizing: border-box;
  appearance: none; }

.is-attention .f-input-calendar::-webkit-input-placeholder {
  font-weight: bold;
  color: #cc0d21; }

.is-attention .f-input-calendar::placeholder {
  font-weight: bold;
  color: #cc0d21; }

.f-input-calendar__button {
  position: absolute;
  top: 0;
  right: 0;
  width: 35px;
  height: 100%; }
  .f-input-calendar__button::after {
    content: "";
    position: absolute;
    top: 9px;
    right: 10px;
    width: 16px;
    height: 16px;
    background: url("../images/icon/ico_calendar01.png") no-repeat 0 0;
    background-size: 16px 16px; }

.is-attention .f-input-calendar__button::after {
  background: url("../images/icon/ico_calendar02.png") no-repeat 0 0;
  background-size: 16px 16px; }

.f-input-calendar__icon {
  width: 100%; }

.f-input-calendar__body {
  display: none;
  position: absolute;
  top: 42px;
  left: 0;
  width: 100%;
  padding: 20px;
  background-color: #fff;
  border: 1px solid #20208C;
  box-sizing: border-box;
  z-index: 1; }
  .f-input-calendar__body.is-show {
    display: block; }
  .f-input-calendar__body::before {
    content: "";
    position: absolute;
    top: -13px;
    right: 8px;
    width: 0;
    height: 0;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-bottom: 13px solid #20208C;
    z-index: 1; }
  .f-input-calendar__body::after {
    content: "";
    position: absolute;
    top: -11px;
    right: 8px;
    width: 0;
    height: 0;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-bottom: 13px solid #fff;
    z-index: 2; }

.f-input-calendar__month {
  display: flex;
  align-items: center;
  margin-bottom: 20px; }

.f-input-calendar__prev {
  width: 10px;
  height: 10px;
  margin-left: 20px;
  border-bottom: 3px solid #20208C;
  border-left: 3px solid #20208C;
  transform: rotate(45deg); }
  .f-input-calendar__prev.is-hidden {
    visibility: hidden; }

.f-input-calendar__current {
  flex-grow: 1;
  font-weight: bold;
  color: #000;
  text-align: center; }

.f-input-calendar__next {
  width: 10px;
  height: 10px;
  margin-right: 20px;
  border-top: 3px solid #20208C;
  border-right: 3px solid #20208C;
  transform: rotate(45deg); }
  .f-input-calendar__next.is-hidden {
    visibility: hidden; }

.f-input-search__wrap {
  position: relative;
  width: 100%;
  height: 46px;
  padding-left: 12px;
  line-height: normal;
  border-top: 1px solid #a0a0a0;
  border-left: 1px solid #a0a0a0;
  border-bottom: 1px solid #a0a0a0;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
  box-sizing: border-box; }

.f-input-search {
  width: 100%;
  height: 46px;
  line-height: normal;
  appearance: none; }

.f-input-search__clear {
  position: absolute;
  top: 50%;
  right: 16px;
  width: 16px;
  height: 16px;
  background-color: #ccc;
  border-radius: 2px;
  cursor: pointer;
  transform: translateY(-50%); }
  .f-input-search__clear::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 4px;
    width: 8px;
    height: 1px;
    background-color: #fff;
    transform: rotate(45deg); }
  .f-input-search__clear::after {
    content: "";
    position: absolute;
    top: 8px;
    left: 4px;
    width: 8px;
    height: 1px;
    background-color: #fff;
    transform: rotate(-45deg); }

/*--------------------------------
2.7 radio
--------------------------------*/
.f-radio__wrap {
  display: block; }

.f-radio__background.is-checked {
  background-color: #ffeaf1; }

.f-radio {
  display: none; }

.f-radio + .f-radio__label {
  display: inline-flex;
  align-items: center;
  position: relative;
  padding-left: 35px;
  line-height: 1.3;
  cursor: pointer;
  min-height: 35px; }

.f-radio + .f-radio__label::before {
  content: "";
  display: block;
  position: absolute;
  top: 46%;
  left: 0;
  width: 26px;
  height: 26px;
  background-color: #fff;
  border: 2px solid #a0a0a0;
  border-radius: 50%;
  box-sizing: border-box;
  transform: translateY(-50%); }

.f-radio:checked + .f-radio__label::before {
  border: 2px solid #e61b61; }

.f-radio:checked + .f-radio__label::after {
  content: "";
  display: block;
  position: absolute;
  top: 46%;
  left: 7px;
  width: 12px;
  height: 12px;
  background-color: #e61b61;
  border-radius: 50%;
  transform: translateY(-50%); }

/*--------------------------------
2.8 checkbox
--------------------------------*/
.f-checkbox__wrap {
  display: block; }

.f-checkbox__background.is-checked {
  background-color: #ffeaf1; }

.f-checkbox {
  display: none; }

.f-checkbox__text {
  display: inline-flex;
  align-items: center;
  position: relative;
  min-height: 35px;
  padding-left: 35px;
  padding-right: 15px;
  line-height: 1.3;
  box-sizing: border-box;
  cursor: pointer; }

.f-checkbox__text::before {
  content: "";
  display: block;
  position: absolute;
  top: 4px;
  left: 0;
  width: 26px;
  height: 26px;
  background-color: #fff;
  border: 1px solid #a0a0a0;
  border-radius: 4px;
  box-sizing: border-box; }

.f-checkbox:checked + .f-checkbox__text::before {
  border: 1px solid #20208C; }

.f-checkbox:checked + .f-checkbox__text::after {
  content: "";
  display: block;
  position: absolute;
  top: 9px;
  left: 9px;
  width: 5px;
  height: 9px;
  transform: rotate(40deg);
  border-bottom: 3px solid #20208C;
  border-right: 3px solid #20208C; }

.f-checkbox-button__wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 68px;
  height: 60px;
  background-color: #fff;
  border: 1px solid #a0a0a0;
  border-radius: 4px;
  box-shadow: 0 1px 2px #d6d6d6;
  box-sizing: border-box;
  cursor: pointer; }
  .f-checkbox-button__wrap.is-checked {
    background-color: #e61b61;
    border: none;
    box-shadow: none; }

.f-checkbox-button__text {
  position: relative;
  padding-top: 22px;
  font-size: 12px;
  font-weight: bold; }

.f-checkbox-button__text::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  width: 17px;
  height: 17px;
  background-color: #ccc;
  border-radius: 17px;
  transform: translateX(-50%); }

.f-checkbox-button__text::after {
  content: "";
  display: block;
  position: absolute;
  top: 6px;
  left: 50%;
  width: 3px;
  height: 5px;
  border-bottom: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(40deg) translateX(-52%);
  transform: rotate(40deg) translateX(-52%); }

.f-checkbox-button__text.is-checked {
  color: #fff; }

.is-checked.f-checkbox-button__text::before {
  background-color: #fff; }

.is-checked.f-checkbox-button__text::after {
  border-bottom: 2px solid #e61b61;
  border-right: 2px solid #e61b61; }

.f-checkbox-button__text--ok {
  position: relative;
  padding-top: 22px;
  font-size: 12px;
  font-weight: bold; }

.f-checkbox-button__text--ok::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 50%;
  width: 18px;
  height: 18px;
  background: none;
  border: 2px solid #21A4Ea;
  border-radius: 18px;
  box-sizing: border-box;
  transform: translateX(-50%); }

.f-checkbox-button:checked + .f-checkbox-button__text--ok {
  color: #fff; }

.f-checkbox-button:checked + .f-checkbox-button__text--ok::before {
  width: 17px;
  height: 17px;
  background-color: #fff;
  border: none;
  border-radius: 17px;
  transform: translateX(-50%); }

.f-checkbox-button:checked + .f-checkbox-button__text--ok::after {
  content: "";
  display: block;
  position: absolute;
  top: 6px;
  left: 50%;
  width: 3px;
  height: 5px;
  border-bottom: 2px solid #e61b61;
  border-right: 2px solid #e61b61;
  transform: rotate(40deg) translateX(-52%); }

.f-checkbox-button__text--few {
  position: relative;
  padding-top: 22px;
  font-size: 12px;
  font-weight: bold; }

.f-checkbox-button__text--few::before {
  content: "";
  display: block;
  position: absolute;
  top: -1px;
  left: 50%;
  width: 18px;
  height: 18px;
  background: url("../images/icon/ico_triangle01.png") no-repeat center center;
  background-size: 20px 17px;
  box-sizing: border-box;
  transform: translateX(-50%); }

.f-checkbox-button:checked + .f-checkbox-button__text--few {
  color: #fff; }

.f-checkbox-button:checked + .f-checkbox-button__text--few::before {
  width: 17px;
  height: 17px;
  background-image: none;
  background-color: #fff;
  border: none;
  border-radius: 17px;
  transform: translateX(-50%); }

.f-checkbox-button:checked + .f-checkbox-button__text--few::after {
  content: "";
  display: block;
  position: absolute;
  top: 5px;
  left: 50%;
  width: 3px;
  height: 5px;
  border-bottom: 2px solid #e61b61;
  border-right: 2px solid #e61b61;
  transform: rotate(40deg) translateX(-55%); }

.f-checkbox-button__wrap--full {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 68px;
  height: 60px;
  background-color: #dedede;
  border-radius: 4px;
  box-sizing: border-box; }

.f-checkbox-button__text--full {
  position: relative;
  padding-top: 22px;
  font-size: 12px;
  font-weight: bold; }

.f-checkbox-button__text--full::before,
.f-checkbox-button__text--full::after {
  content: "";
  display: block;
  position: absolute;
  top: 8px;
  left: 0;
  width: 22px;
  height: 2px;
  background-color: #cc0d21; }

.f-checkbox-button__text--full::before {
  transform: rotate(-45deg); }

.f-checkbox-button__text--full::after {
  transform: rotate(45deg); }

/*--------------------------------
2.9 select
--------------------------------*/
.f-select__wrap {
  display: inline-block;
  position: relative;
  height: 34px; }
  .f-select__wrap::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 36px;
    height: 100%;
    background: #000;
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    pointer-events: none;
    z-index: 0; }
  .f-select__wrap::after {
    content: '';
    position: absolute;
    top: 10px;
    right: 13px;
    width: 8px;
    height: 8px;
    border-bottom: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    pointer-events: none;
    z-index: 0; }
  .f-select__wrap.is-disabled {
    opacity: 0.5;
    pointer-events: none; }
  .f-select__wrap #SelectJrUseDateReturn {
    padding-right: 40px; }

.f-select__wrap-pax {
  display: inline-block;
  position: relative;
  height: 34px; }
  .f-select__wrap-pax::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 36px;
    height: 100%;
    background: #000;
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    pointer-events: none;
    z-index: 0; }
  .f-select__wrap-pax::after {
    content: '';
    position: absolute;
    top: 10px;
    right: 13px;
    width: 8px;
    height: 8px;
    border-bottom: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
    pointer-events: none;
    z-index: 0; }
  .f-select__wrap-pax.is-disabled {
    opacity: 0.5;
    pointer-events: none; }

.f-select {
  width: 100%;
  min-width: 90px;
  height: 34px;
  padding-left: 10px;
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
  cursor: pointer;
  appearance: none; }

.f-select-child {
  width: 120px;
  height: 34px;
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
  cursor: pointer;
  appearance: none; }

.f-select-pax {
  min-width: 135px;
  height: 34px;
  padding-left: 10px;
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
  cursor: pointer;
  appearance: none; }

.na {
  background-color: lightgray; }

.f-select::-ms-expand {
  display: none; }

/*--------------------------------
2.10 button
--------------------------------*/
.f-button__wrap {
  display: flex;
  justify-content: space-between; }

.f-button-line {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 60px;
  font-size: 16px;
  font-weight: bold;
  color: #20208C;
  background-color: #fff;
  border: 2px solid #20208C;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  box-sizing: border-box;
  cursor: pointer; }
  .f-button-line::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-button-line--small {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 148px;
  height: 40px;
  font-size: 12px;
  font-weight: bold;
  color: #20208C;
  background-color: #fff;
  border: 1px solid #20208C;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  box-sizing: border-box;
  cursor: pointer; }
  .f-button-line--small::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-button-line--exsmall {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 46%;
  height: 40px;
  font-size: 12px;
  font-weight: bold;
  color: #20208C;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208C;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  cursor: pointer; }
  .f-button-line--exsmall::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-button-line--half {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 48%;
  height: 40px;
  font-size: 12px;
  font-weight: bold;
  color: #20208C;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208C;
  border-radius: 4px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  cursor: pointer; }
  .f-button-line--half::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-button-line--cancel {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 46%;
  height: 40px;
  font-size: 12px;
  font-weight: bold;
  color: #333;
  background-color: #fff;
  border: 1px solid #a0a0a0;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  cursor: pointer; }
  .f-button-line--cancel::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
    transform: rotate(45deg) translateY(-50%); }

.f-button-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 73px;
  font-size: 18px;
  color: #fff;
  text-align: center;
  text-decoration: none;
  background-color: #e61b61;
  border: none;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  cursor: pointer; }
  .f-button-submit::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }

.f-button-submit--small {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 50px;
  font-size: 18px;
  color: #fff;
  text-decoration: none;
  background-color: #e61b61;
  border: none;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  cursor: pointer; }
  .f-button-submit--small::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }

.f-button-submit--exsmall {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 46px;
  font-size: 18px;
  color: #fff;
  text-decoration: none;
  background-color: #e61b61;
  border: none;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  cursor: pointer; }
  .f-button-submit--exsmall::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }

.f-button__text--small {
  margin-top: 4px;
  margin-left: 8px;
  font-weight: bold;
  font-size: 14px; }

.f-button-submit--half {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 48%;
  height: 40px;
  font-size: 12px;
  color: #fff;
  text-decoration: none;
  background-color: #e61b61;
  border: none;
  border-radius: 4px;
  box-shadow: 0 2px 0 #d6d6d6;
  cursor: pointer; }
  .f-button-submit--half::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }

.f-button__inner {
  font-weight: bold; }

.f-button-submit__text--small {
  font-size: 12px;
  font-weight: bold; }

.f-button-cancel {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 46px;
  margin-top: 20px;
  font-size: 18px;
  color: #fff;
  text-decoration: none;
  background-color: #a0a0a0;
  border: none;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  cursor: pointer; }
  .f-button-cancel::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }

.f-button-back {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 34px;
  margin-left: auto;
  margin-right: auto;
  color: #fff;
  text-decoration: none;
  background-color: #a0a0a0;
  border: none;
  border-radius: 6px;
  cursor: pointer; }

.f-button-more {
  display: flex;
  align-items: center;
  position: relative;
  width: 160px;
  height: 30px;
  padding-top: 2px;
  padding-left: 35px;
  font-size: 12px;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: 0 1px 0 #d6d6d6;
  cursor: pointer; }
  .f-button-more::before {
    content: "";
    position: absolute;
    top: 11px;
    left: 13px;
    width: 7px;
    height: 7px;
    border-bottom: 1px solid #20208C;
    border-right: 1px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-button-change {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 140px;
  height: 30px;
  padding-top: 2px;
  font-size: 12px;
  text-decoration: none;
  background-color: #f5f5f5;
  border: none;
  border-radius: 4px;
  box-shadow: 0 1px 1px #d6d6d6;
  cursor: pointer; }

.f-button-seat {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 36px;
  margin-top: 15px;
  font-size: 12px;
  color: #333;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208C;
  border-radius: 4px;
  box-shadow: 0 2px 1px #dedede;
  box-sizing: border-box; }

.f-button-seat__icon {
  display: block;
  width: 11px;
  margin-right: 5px; }

.f-button-seat__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  text-align: center; }

.f-button-clear {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 68px;
  height: 38px;
  margin-top: 10px;
  margin-bottom: 5px;
  font-size: 12px;
  font-weight: bold;
  color: #333;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #a0a0a0;
  border-radius: 4px;
  box-shadow: 0 2px 1px #dedede;
  box-sizing: border-box; }

.f-button__fixed {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 12px;
  background-color: rgba(255, 255, 255, 0.8);
  box-sizing: border-box;
  backface-visibility: hidden;
  overflow: hidden;
  z-index: 8; }

.f-button-favorite {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 97px;
  height: 26px;
  padding-top: 1px;
  background-color: #fff;
  border: 1px solid #a0a0a0;
  border-radius: 4px;
  box-sizing: border-box;
  line-height: 1.0; }
  .f-button-favorite.is-active {
    border: 1px solid #ffba00; }
    .f-button-favorite.is-active .f-button-favorite__text {
      color: #ff8b17; }
      .f-button-favorite.is-active .f-button-favorite__text::before {
        background: url("../images/icon/ico_heart01.png") no-repeat 0 0;
        background-size: 12px 11px; }

.f-button-favorite__text {
  position: relative;
  padding-left: 14px;
  font-size: 11px;
  font-weight: bold;
  color: #a0a0a0;
  text-decoration: none; }
  .f-button-favorite__text::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 12px;
    height: 11px;
    background: url("../images/icon/ico_heart02.png") no-repeat 0 0;
    background-size: 12px 11px; }

.f-button-detail {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 62px;
  height: 62px;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208C;
  border-radius: 4px;
  box-shadow: 0 2px 1px #dedede;
  box-sizing: border-box; }

.f-button-detail__inner {
  font-size: 12px;
  font-weight: bold;
  color: #333;
  text-align: center; }

.f-button-detail__icon {
  display: block;
  width: 16px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 5px; }

.f-button-hint {
  display: inline-block;
  position: relative;
  top: -2px;
  width: 20px;
  height: 20px;
  margin-left: 10px;
  box-sizing: border-box; }

.f-button-hint--left {
  display: inline-block;
  position: relative;
  top: -2px;
  width: 20px;
  height: 20px;
  margin-right: 8px;
  box-sizing: border-box; }

.f-button-hint__image {
  width: 100%; }

.f-button-prev {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100px;
  height: 38px;
  font-weight: bold;
  font-size: 12px;
  border: 1px solid #a0a0a0;
  border-radius: 4px;
  box-shadow: 0 2px 1px #dedede;
  color: black;
  text-decoration: none;
  cursor: pointer; }
  .f-button-prev::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 7px;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #20208C;
    border-left: 2px solid #20208C;
    transform: rotate(45deg) translateY(-60%); }

.f-button-next {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100px;
  height: 38px;
  font-weight: bold;
  font-size: 12px;
  border: 1px solid #a0a0a0;
  border-radius: 4px;
  box-shadow: 0 2px 1px #dedede;
  color: black;
  text-decoration: none;
  cursor: pointer; }
  .f-button-next::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 15px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-60%); }

.f-button-reset {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 140px;
  height: 30px;
  font-size: 12px;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: 0 1px 0 #d6d6d6;
  box-sizing: border-box;
  cursor: pointer;
  transition: opacity 0.3s ease-out; }
  .f-button-reset:hover {
    opacity: 0.5; }

.f-button-compare {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 46px;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  background-color: #ffb100;
  border: none;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box; }
  .f-button-compare::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }

.f-button-list {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 46px;
  margin-top: 15px;
  font-size: 16px;
  color: #fff;
  text-decoration: none;
  background-color: #a0a0a0;
  border: none;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box; }
  .f-button-list::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }

.f-button-search {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 60px;
  height: 46px;
  padding-top: 2px;
  background-color: #000;
  border: none;
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px; }

.f-button-search__icon {
  width: 17px; }

.f-button-access {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 80px;
  height: 26px;
  padding-right: 5px;
  font-size: 11px;
  font-weight: normal;
  color: #20208C;
  line-height: 26px;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208C;
  border-radius: 2px;
  box-sizing: border-box; }
  .f-button-access::after {
    content: "";
    position: absolute;
    top: 49%;
    right: 8px;
    width: 3px;
    height: 3px;
    border-top: 1px solid #20208C;
    border-right: 1px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-button-access__icon {
  width: 14px;
  margin-right: 3px; }

.f-button-map {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 60px;
  height: 26px;
  margin-top: 5px;
  margin-bottom: 5px;
  padding-right: 5px;
  font-size: 11px;
  font-weight: normal;
  color: #20208C;
  line-height: 26px;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208C;
  border-radius: 2px;
  box-sizing: border-box; }
  .f-button-map::after {
    content: "";
    position: absolute;
    top: 49%;
    right: 8px;
    width: 3px;
    height: 3px;
    border-top: 1px solid #20208C;
    border-right: 1px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-button-change {
  display: block;
  position: relative;
  width: 100%;
  height: 40px;
  margin-top: 30px;
  padding-top: 12px;
  font-size: 12px;
  color: #333;
  text-align: center;
  text-decoration: none;
  background-color: #ededed;
  border: 1px solid #ccc;
  border-radius: 6px;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out; }
  .f-button-change::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #a0a0a0;
    border-right: 2px solid #a0a0a0;
    transform: rotate(45deg) translateY(-50%); }
  .f-button-change:hover {
    opacity: 0.6; }

@media screen and (max-width: 320px) {
  .f-button-submit--half {
    padding-right: 5px;
    font-size: 11px; } }
/*--------------------------------
2.11 section
--------------------------------*/
.f-section {
  margin-top: 20px; }
  .f-section input:disabled + label {
    color: #CCCCCC; }

.f-section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  padding-top: 18px;
  padding-bottom: 18px;
  font-size: 18px;
  font-weight: bold;
  border-top: 4px solid #ededed; }
  .f-section__head::before {
    content: "";
    position: absolute;
    top: -4px;
    left: 0;
    width: 60px;
    height: 4px;
    background-color: #20208C; }

.f-section__head--line {
  position: relative;
  padding-top: 18px;
  padding-bottom: 18px;
  font-size: 18px;
  font-weight: bold;
  border-top: 4px solid #ededed;
  border-bottom: 1px solid #ededed; }
  .f-section__head--line::before {
    content: "";
    position: absolute;
    top: -4px;
    left: 0;
    width: 60px;
    height: 4px;
    background-color: #20208C; }

.f-section__title {
  font-size: 18px;
  font-weight: bold; }

.f-section__button-top {
  padding: 30px 12px 20px;
  border-top: 1px solid #dedede; }

.f-section__button-inner {
  display: flex;
  justify-content: center;
  margin-top: 30px; }

.f-section__text--important {
  width: 100%;
  padding: 6px 15px;
  font-size: 12px;
  font-weight: bold;
  color: #cc0d21;
  line-height: 1.5;
  text-align: center;
  border: 1px solid #cc0d21;
  box-sizing: border-box; }

.f-section__link {
  font-weight: bold;
  color: #cc0d21;
  text-decoration: underline; }

.f-section__button-bottom {
  padding: 30px 12px;
  border-top: 1px solid #dedede; }
  .f-section__button-bottom > .f-button-back {
    margin-top: 50px;
    margin-bottom: 14px; }

.f-section__button {
  padding: 20px 12px 30px; }
  .f-section__button > .f-button-back {
    margin-top: 50px;
    margin-bottom: 14px; }

.f-section__text--attention {
  font-size: 12px;
  font-weight: bold;
  color: #cc0d21;
  line-height: 1.2;
  text-align: center; }

.f-section__name {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5; }

.f-section__name--small {
  margin-top: 5px;
  font-size: 12px;
  color: #a0a0a0;
  line-height: 1.5; }

.f-section__text--small {
  margin-top: 10px;
  font-size: 11px;
  color: #a0a0a0;
  line-height: 1.5; }

.f-section__pr_label {
  margin: 6px 0;
  font-size: 13px; }

.f-section__pr_icon_01 {
  display: inline-block;
  border: 1px solid #e04c31;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #e04c31;
  font-weight: bold;
  vertical-align: middle; }

.f-section__pr_icon_01_text {
  display: inline-block;
  list-style: none;
  padding: 6px 9px;
  color: #e04c31;
  vertical-align: middle;
  white-space: pre-wrap;
  max-width: calc(100% - 120px);
  box-sizing: border-box; }

.f-section__pr_icon_02 {
  display: inline-block;
  border: 1px solid #069ad6;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #069ad6;
  font-weight: bold; }

.f-section-review {
  padding-top: 15px;
  padding-bottom: 10px;
  border-bottom: 1px dashed #dedede; }

.f-section-review__stars {
  display: flex;
  align-items: center;
  font-weight: bold;
  font-size: 15px; }

.f-section-access__list {
  display: flex;
  margin-top: 15px; }

.f-section-access__item {
  width: 60px;
  font-weight: bold;
  font-size: 12px;
  line-height: 1.5; }

.f-section-access__description {
  width: calc(100% - 60px);
  font-size: 12px;
  line-height: 1.5; }

/*--------------------------------
2.12 status
--------------------------------*/
.f-status {
  margin-top: 20px; }

.f-status__list {
  display: flex;
  justify-content: center;
  position: relative;
  padding-left: 0; }
  .f-status__list::before {
    content: "";
    position: absolute;
    top: 12px;
    left: 0;
    width: 63%;
    height: 2px;
    background-color: #ededed;
    z-index: -1; }
  .f-status__list::after {
    content: "";
    position: absolute;
    top: 10px;
    left: 64%;
    width: 25%;
    height: 2px;
    border-bottom: 2px dotted #ededed;
    z-index: -1; }

.f-status__list--first {
  display: flex;
  justify-content: center;
  position: relative;
  padding-left: 0; }
  .f-status__list--first::before {
    content: "";
    position: absolute;
    top: 12px;
    left: 14%;
    width: 49%;
    height: 2px;
    background-color: #ededed;
    z-index: -1; }
  .f-status__list--first::after {
    content: "";
    position: absolute;
    top: 10px;
    left: 50%;
    width: 36%;
    height: 2px;
    border-bottom: 2px dotted #ededed;
    z-index: -1; }

.f-status__item {
  width: 25%;
  list-style: none;
  font-size: 11px;
  font-weight: bold;
  color: #ccc;
  line-height: 1.3;
  text-align: center; }
  .f-status__item.is-current {
    color: #20208C; }
    .f-status__item.is-current .f-status__number {
      position: relative;
      width: 24px;
      height: 24px;
      margin: 0 auto 7px;
      color: transparent;
      background-color: #20208C;
      border-radius: 26px; }
      .f-status__item.is-current .f-status__number::before {
        content: "";
        display: block;
        position: absolute;
        top: 7px;
        left: 7px;
        border-left: 2px solid #fff;
        border-bottom: 2px solid #fff;
        width: 9px;
        height: 5px;
        transform: rotate(-45deg); }

.f-status__number {
  display: block;
  width: 18px;
  height: 18px;
  margin: 5px auto 8px;
  padding-top: 4px;
  font-family: Helvetica, sans-serif;
  font-size: 11px;
  font-weight: bold;
  color: #fff;
  line-height: 11px;
  background-color: #ccc;
  border-radius: 22px;
  box-sizing: border-box; }

/*--------------------------------
2.13 facility
--------------------------------*/
.f-facility-info__head {
  display: flex;
  align-items: center;
  width: 100%;
  height: 40px;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: bold;
  background-color: #ededed;
  box-sizing: border-box; }

.f-facility-info__icon {
  position: relative;
  top: 1px;
  width: 16px;
  margin-right: 5px; }

.f-facility-info__body {
  padding: 17px 12px 30px; }
  .f-facility-info__body .f-label {
    margin-top: 5px; }

.f-facility-info__image {
  width: 80px;
  margin-right: 8px; }

.f-facility-info__picture {
  width: 100%; }

.f-facility-info__inner {
  position: relative;
  width: calc(100% - 88px);
  padding-bottom: 17px; }

.f-facility-info__title {
  margin-top: -3px;
  font-weight: bold;
  line-height: 1.5; }

.f-facility-info__text {
  position: absolute;
  bottom: 0;
  right: 0;
  font-size: 12px;
  color: #a0a0a0; }

.f-facility-info__list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 10px;
  border-top: 1px solid #dedede; }

.f-facility-info__item {
  width: 110px;
  padding: 7px 8px 5px;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.2;
  background-color: #ededed;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-facility-info__description {
  width: calc(100% - 110px);
  padding: 7px 8px 5px;
  font-size: 13px;
  line-height: 1.2;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

/*--------------------------------
2.14 detail
--------------------------------*/
.f-detail__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 46px;
  margin-top: 1px;
  padding-left: 12px;
  padding-right: 12px;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  background-color: #20208C;
  box-sizing: border-box; }

.f-detail__title {
  font-weight: bold; }

.f-detail__list {
  margin-top: 10px;
  margin-bottom: 10px;
  padding-left: 0; }

.f-detail__item {
  padding-left: 12px;
  font-size: 12px;
  list-style: none;
  line-height: 1.5;
  position: relative; }
  .f-detail__item::before {
    content: '・';
    position: absolute;
    top: 0;
    left: 0; }

.f-detail__body {
  padding-bottom: 35px; }

.f-detail__body--small {
  padding-top: 10px;
  padding-bottom: 25px; }

.f-detail__body--large {
  padding-top: 15px;
  padding-bottom: 35px; }

.f-detail__body--exlarge {
  padding-top: 20px;
  padding-bottom: 35px; }

.f-detail__text {
  line-height: 1.5; }
  .f-detail__text + .f-detail__text {
    margin-top: 20px; }

.f-detail__text--strong {
  font-weight: bold; }

.f-detail__text--small {
  font-size: 12px;
  line-height: 1.5; }

.f-detail__text--right {
  font-size: 12px;
  text-align: right; }

.f-detail__text--important {
  font-weight: bold;
  color: #cc0d21; }

.f-detail__text--attention,
.f-detail-note__list--important {
  color: #cc0d21; }

.f-detail-note__list {
  width: 100%;
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box;
  padding-top: 20px; }

.f-detail-note__menu {
  margin-top: 5px;
  margin-bottom: 5px; }

.f-detail-note__item {
  padding-left: 1.4em;
  font-size: 12px;
  list-style: none;
  line-height: 1.5;
  text-indent: -1.4em; }

.f-detail-note__item--large {
  font-size: 14px;
  list-style: none;
  line-height: 1.5; }

.f-detail-via__item {
  width: 100%;
  padding: 12px;
  font-size: 12px;
  font-weight: bold;
  background-color: #ededed;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-via__description {
  width: 100%;
  padding: 16px 12px;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-roundtrip__text {
  font-size: 12px;
  margin-bottom: 20px; }

.f-detail-roundtrip__text--small {
  width: 100%;
  font-size: 12px;
  font-weight: bold; }

.f-detail-roundtrip__text--large {
  width: 100%;
  font-weight: bold;
  line-height: 1.3; }

.f-detail-roundtrip__list {
  display: flex;
  position: relative; }
  .f-detail-roundtrip__list::after {
    content: "";
    position: absolute;
    bottom: -10px;
    left: 50%;
    width: 0;
    height: 0;
    border-right: 6px solid transparent;
    border-left: 6px solid transparent;
    border-top: 10px solid #a0a0a0;
    transform: translateX(-50%);
    z-index: 1; }

.f-detail-roundtrip__item {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  width: 24.533%;
  min-height: 70px;
  color: #fff;
  background-color: #000;
  box-sizing: border-box; }

.f-detail-roundtrip__icon {
  display: block;
  width: 21px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 5px; }

.f-detail-roundtrip__inner {
  display: block;
  width: 100%;
  font-weight: bold;
  text-align: center; }

.f-detail-roundtrip__description {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  width: 75.466%;
  min-height: 70px;
  padding: 12px;
  font-weight: bold;
  color: #fff;
  background-color: #a0a0a0;
  box-sizing: border-box; }
  .f-detail-roundtrip__description > .f-select__wrap {
    margin-bottom: 5px; }

.f-detail-roundtrip__body {
  padding: 25px 12px 40px;
  background-color: #ededed; }

.f-detail-selected__head {
  padding: 12px;
  font-weight: bold;
  color: #fff;
  background-color: #333; }

.f-detail-selected__list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 10px;
  background-color: #fff; }

.f-detail-selected__item {
  width: 92px;
  padding: 16px 12px;
  text-align: center;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-selected__description {
  width: calc(100% - 92px);
  padding: 16px;
  border-left: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-selected__text--strong {
  font-weight: bold;
  color: #000; }

.f-detail-selected__text--middle {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 13px;
  line-height: 1.5; }

.f-detail-selected__text {
  font-size: 13px; }

.f-detail-selected__text--important {
  display: inline-block;
  margin-left: 20px;
  font-weight: bold;
  color: #cc0d21; }

.f-detail-seat {
  margin: 0px 10px 15px 10px;
  display: none; }

.f-detail-seat__list {
  border-top: 1px solid #ccc;
  border-left: 1px solid #ccc; }

.f-detail-seat__item {
  padding: 14px 12px;
  list-style: none;
  border-bottom: 1px solid #ccc;
  border-right: 1px solid #ccc; }

.f-detail-seat__text--small {
  display: block;
  font-size: 12px; }

.f-detail-term {
  width: 100%;
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box; }

.f-detail-term__text {
  font-size: 12px;
  font-weight: bold;
  margin-bottom: 17px; }

.f-detail-term__list + .f-detail-term__list {
  margin-top: 30px; }

.f-detail-term__item {
  padding: 2px 10px;
  font-weight: bold;
  border-left: 4px solid #20208C; }

.f-detail-term__description {
  padding-top: 18px; }

.f-detail-term__label {
  margin-bottom: 15px; }

.f-detail-term__choice {
  width: 100%;
  margin-bottom: 15px;
  word-break: break-all;
  box-sizing: border-box; }
  .f-detail-term__choice .f-detail-term__checkbox:last-of-type .f-checkbox__text {
    padding-right: 0; }

.f-detail-timezone__list {
  display: flex; }

.f-detail-timezone__label {
  width: 88px;
  margin-bottom: 10px;
  padding-top: 10px;
  padding-right: 5px;
  font-size: 13px;
  text-align: right;
  box-sizing: border-box; }

.f-detail-timezone__choice {
  width: calc(100% - 88px);
  margin-bottom: 10px; }
  .f-detail-timezone__choice .f-select__wrap {
    width: 90%; }

.f-detail-timezone__choice label {
  display: inline-flex;
  align-items: center;
  position: relative;
  min-height: 35px;
  padding-left: 35px;
  padding-right: 15px;
  line-height: 1.3;
  box-sizing: border-box;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  max-width: 100%;
  margin: 0 auto;
  padding: 0; }

.f-detail-select__head {
  padding: 17px 10px;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  background-color: #333; }

.f-detail-select__body .f-table__head,
.f-detail-select__body .f-table__data {
  border-right: none; }

.f-detail-roundtrip__text {
  margin-bottom: 20px; }

.f-detail-roundtrip__text--small {
  width: 100%;
  font-size: 12px;
  font-weight: bold; }

.f-detail-roundtrip__text--large {
  margin-top: 10px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.3; }

.f-detail-select__data {
  margin-top: 15px;
  margin-right: 12px;
  margin-bottom: 15px;
  text-align: right; }

.f-detail-select__text--ok {
  position: relative;
  padding-left: 18px;
  font-size: 12px; }
  .f-detail-select__text--ok::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 13px;
    height: 13px;
    background: none;
    border: 2px solid #21A4Ea;
    border-radius: 13px;
    box-sizing: border-box;
    transform: translateY(-50%); }

.f-detail-select__text--few {
  position: relative;
  margin-left: 10px;
  padding-left: 20px;
  font-size: 12px; }
  .f-detail-select__text--few::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 18px;
    height: 18px;
    background: url("../images/icon/ico_triangle02.png") no-repeat center center;
    background-size: 13px 11px;
    box-sizing: border-box;
    transform: translateY(-50%); }

.f-detail-select__text {
  padding: 15px 12px;
  font-size: 12px;
  line-height: 15px; }

.f-detail-request__radio {
  margin-bottom: 20px; }
  .f-detail-request__radio > .f-radio__wrap {
    padding: 16px 12px;
    border-bottom: 1px solid #dedede; }

.f-detail-request__inner {
  width: 100%;
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box; }
  .f-detail-request__inner > .f-detail-note__list--important {
    margin-top: 10px; }

.f-detail-request__text {
  margin-bottom: 15px;
  font-weight: bold; }

.f-detail-info__list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 15px;
  margin-bottom: 10px;
  border-top: 1px solid #dedede; }

.f-detail-info__item {
  width: 110px;
  padding: 5px 8px;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.5;
  background-color: #ededed;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-info__item--long {
  width: 115px;
  padding: 5px 8px;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.5;
  background-color: #ededed;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-info__item--simple {
  width: 110px;
  padding: 5px 8px;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-info__text {
  display: inline-block;
  font-weight: bold;
  margin-top: 8px; }

.f-detail-info__description {
  display: flex;
  align-items: center;
  width: calc(100% - 110px);
  padding: 5px 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-info__description--short {
  display: flex;
  align-items: center;
  width: calc(100% - 115px);
  padding: 5px 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-info__description-noflex {
  width: calc(100% - 110px);
  padding: 5px 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-checkin__list {
  display: flex;
  align-items: center;
  margin-top: 20px; }

.f-detail-checkin__item {
  width: 170px;
  padding-top: 5px;
  font-weight: bold; }

.f-detail-checkin__description {
  width: calc(100% - 170px);
  margin-bottom: -5px; }
  .f-detail-checkin__description .f-select {
    min-width: 120px; }

.f-detail-form--line {
  margin-top: 15px;
  padding-bottom: 15px;
  border-bottom: 1px solid #dedede; }

.f-detail-form {
  margin-top: 15px;
  padding-bottom: 15px; }

.f-detail-form__row {
  padding-top: 20px; }

.f-detail-form__title {
  display: block;
  margin-bottom: 10px;
  font-weight: bold;
  white-space: nowrap; }

.f-detail-form__list {
  margin-bottom: 15px;
  border-top: 1px solid #ccc;
  border-left: 1px solid #ccc; }

.f-detail-form__item {
  padding: 14px 12px;
  list-style: none;
  border-bottom: 1px solid #ccc;
  border-right: 1px solid #ccc; }

.f-detail-form__text--small {
  margin-left: 15px;
  font-size: 12px; }

.f-detail-form__flex {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding-top: 14px;
  padding-bottom: 14px; }

.f-detail-form__flex-line {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding-top: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid #ccc; }

.f-detail-form__flex-title {
  display: block;
  width: 92px;
  font-weight: bold; }

.f-detail-form__flex-inner {
  width: calc(100% - 92px); }

.f-detail-unit {
  margin-top: 20px;
  padding-bottom: 15px;
  border-bottom: 1px solid #dedede; }

.f-detail-unit__title {
  margin-bottom: 8px;
  padding-top: 2px;
  padding-left: 10px;
  padding-bottom: 2px;
  font-weight: bold;
  line-height: 1.3;
  border-left: 4px solid #20208C; }

.f-detail-unit__text {
  margin-bottom: 15px;
  font-size: 12px;
  line-height: 1.5; }
  .f-detail-unit__text + .f-detail-unit__text {
    margin-top: 10px; }

.f-detail-table__head {
  padding: 12px 8px;
  font-weight: bold;
  font-size: 12px;
  background-color: #ededed;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-detail-table__head--large {
  padding: 8px;
  font-weight: bold;
  font-size: 13px;
  background-color: #ededed;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-detail-table {
  margin-top: 20px; }

.f-detail-table--small {
  margin-top: 10px; }

.f-detail-table__list {
  display: flex;
  flex-wrap: wrap; }

.f-detail-table__item {
  width: 33%;
  padding-top: 4px;
  padding-bottom: 4px;
  padding-left: 8px;
  font-weight: bold;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #ccc;
  box-sizing: border-box; }

.f-detail-table__description {
  width: calc(100% - 33%);
  padding-top: 4px;
  padding-bottom: 4px;
  padding-right: 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #ccc;
  box-sizing: border-box; }

.f-detail-table__body {
  margin-top: 10px;
  margin-left: 8px;
  margin-right: 8px; }

.f-detail-table__text {
  line-height: 1.5;
  letter-spacing: 0.01em; }
  .f-detail-table__text + .f-detail-table__text {
    margin-top: 8px; }

.f-detail-arrow__list {
  margin-top: 10px; }

.f-detail-arrow__list--right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-top: 20px; }

.f-detail-arrow__item {
  margin-right: 5px;
  list-style: none; }
  .f-detail-arrow__item + .f-detail-arrow__item {
    margin-left: 20px; }

.f-detail-arrow__link {
  position: relative;
  padding-right: 10px;
  color: #0065D6;
  text-decoration: none; }
  .f-detail-arrow__link::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 5px;
    height: 5px;
    border-top: 2px solid #0065D6;
    border-right: 2px solid #0065D6;
    transform: rotate(45deg) translateY(-50%); }

.f-detail-difference__title {
  margin-top: 20px;
  padding: 12px;
  font-weight: bold;
  color: #fff;
  background-color: #333; }

.f-detail-difference__text {
  font-size: 13px;
  line-height: 1.5; }

.f-detail-difference__list {
  display: flex;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-detail-difference__item {
  width: 180px;
  padding: 15px 12px;
  font-weight: bold;
  font-size: 13px; }

.f-detail-difference__description {
  width: calc(100% - 180px);
  padding: 15px 12px;
  font-size: 13px; }

.f-detail-notice {
  margin: 20px 12px; }

.f-detail-notice__text {
  font-size: 12px;
  color: #cc0d21;
  line-height: 1.5; }

.f-detail-notice__list {
  margin-top: 15px;
  font-size: 12px; }

.f-detail-notice__item {
  padding-left: 1em;
  list-style: none;
  color: #cc0d21;
  line-height: 1.5;
  text-indent: -1em; }

@media screen and (max-width: 320px) {
  .f-detail__hidden {
    display: none; }

  .f-detail-timezone__list {
    display: block; }

  .f-detail-timezone__label {
    width: 100%;
    padding-top: 0;
    text-align: left; }

  .f-detail-timezone__choice {
    width: 100%; }
    .f-detail-timezone__choice .f-select__wrap {
      width: 100%; }

  .f-detail-form__flex-inner .f-select {
    min-width: 90px; }

  .f-detail-form__text--small {
    margin-left: 0; } }
/* ラジオボタン範囲調整 */
.f-detail-form .f-detail-form__item {
  padding: 0; }
.f-detail-form .f-radio__label {
  padding: 14px 12px 14px 47px;
  width: 100%;
  box-sizing: border-box; }
.f-detail-form .f-radio + .f-radio__label::before {
  left: 12px; }
.f-detail-form .f-radio + .f-radio__label::after {
  left: 19px; }

.f-detail-request__radio .f-radio__wrap {
  padding: 0; }
.f-detail-request__radio .f-radio__label {
  padding: 16px 12px 16px 47px;
  width: 100%;
  box-sizing: border-box; }
.f-detail-request__radio .f-radio + .f-radio__label::before {
  left: 12px; }
.f-detail-request__radio .f-radio + .f-radio__label::after {
  left: 19px; }

#JrDepStaSelect .f-table__data:not(.f-table-train__cell--large),
#JrArrStaSelect .f-table__data:not(.f-table-train__cell--large) {
  padding: 0; }
  #JrDepStaSelect .f-table__data:not(.f-table-train__cell--large) .f-radio__label,
  #JrArrStaSelect .f-table__data:not(.f-table-train__cell--large) .f-radio__label {
    padding: 14px 12px 14px 47px;
    width: 100%;
    box-sizing: border-box; }
  #JrDepStaSelect .f-table__data:not(.f-table-train__cell--large) .f-radio + .f-radio__label::before,
  #JrArrStaSelect .f-table__data:not(.f-table-train__cell--large) .f-radio + .f-radio__label::before {
    left: 12px; }
  #JrDepStaSelect .f-table__data:not(.f-table-train__cell--large) .f-radio + .f-radio__label::after,
  #JrArrStaSelect .f-table__data:not(.f-table-train__cell--large) .f-radio + .f-radio__label::after {
    left: 19px; }

.f-detail-via__description {
  padding: 0; }
  .f-detail-via__description .f-radio__label {
    padding: 16px 12px 16px 47px;
    width: 100%;
    box-sizing: border-box; }
  .f-detail-via__description .f-radio + .f-radio__label::before {
    left: 12px; }
  .f-detail-via__description .f-radio + .f-radio__label::after {
    left: 19px; }

.f-detail-seat__item {
  padding: 0; }
  .f-detail-seat__item .f-radio__label {
    padding: 14px 12px 14px 47px; }
  .f-detail-seat__item .f-radio + .f-radio__label::before {
    left: 12px; }
  .f-detail-seat__item .f-radio + .f-radio__label::after {
    left: 19px; }

.f-detail-marstime-container {
  display: flex;
  margin-bottom: 10px;
  margin-top: 10px; }

.f-detail-marstime-left {
  display: inline-block;
  width: 100px;
  height: 85px; }

.f-detail-marstime-right {
  display: inline-block;
  padding-top: 22px; }

.f-detail-marstime-hour-container {
  display: inline-block;
  margin-left: 10px; }

.f-detail-marstime-minute-container {
  display: inline-block; }

.f-detail-marstime-hour-inner.f-select,
.f-detail-marstime-minute-inner.f-select {
  min-width: 70px;
  padding-left: 5px; }

.f-detail-marsmark {
  text-align: right;
  font-size: 12px;
  margin-bottom: 10px;
  padding-right: 10px;
  line-height: 15px;
  vertical-align: middle; }

.f-detail-marsmark .OK {
  position: relative;
  padding-left: 15px; }
  .f-detail-marsmark .OK:before {
    content: "";
    position: absolute;
    background: none;
    border: 2px solid #21A4Ea;
    border-radius: 18px;
    top: 0px;
    left: 2px;
    width: 10px;
    height: 10px; }

.f-detail-marsmark .Few {
  position: relative;
  padding-left: 21px; }
  .f-detail-marsmark .Few:before {
    content: "";
    position: absolute;
    background-image: url("../images/icon/ico_triangle02.png");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 16px 14px;
    top: -2px;
    left: 7px;
    width: 15px;
    height: 16px; }

.f-detail-marsmark .Full {
  position: relative;
  padding-left: 20px; }
  .f-detail-marsmark .Full:before, .f-detail-marsmark .Full:after {
    content: "";
    position: absolute;
    background-color: #cc0d21;
    top: 6px;
    left: 6px;
    width: 16px;
    height: 2px; }
  .f-detail-marsmark .Full:before {
    transform: rotate(-45deg); }
  .f-detail-marsmark .Full:after {
    transform: rotate(45deg); }

.f-detail-marsstatus__container {
  margin-top: 80px;
  margin-bottom: 15px;
  font-size: 14px;
  line-height: 16px; }

.f-detail-marsstatus__badge {
  display: inline-block;
  height: 16px;
  line-height: 15px;
  padding: 5px;
  border-radius: 4px;
  color: white;
  margin-bottom: 5px; }

.f-detail-marsstatus__text {
  line-height: 18px; }

.f-detail-marserror {
  display: none;
  padding: 5px;
  margin: 2px 10px;
  color: #cc0d21;
  font-size: 15px;
  vertical-align: middle;
  border: 2px solid #cc0d21; }

.f-detail-genteiinfo {
  font-size: 12px;
  margin: 12px 0 12px 0;
  padding: 6px;
  line-height: 16px; }

.f-detail-path__text {
  display: none;
  font-size: 12px;
  margin: 12px; }

.f-detail-searchbox__text {
  padding: 50px 15px 450px 15px; }

/*--------------------------------
2.15 note
--------------------------------*/
.f-note__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 48px;
  padding-left: 10px;
  padding-right: 10px;
  background-color: #ededed;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box;
  cursor: pointer; }

.f-note__title {
  display: flex;
  align-items: center;
  height: 24px;
  padding-left: 15px;
  font-size: 16px;
  font-weight: bold;
  border-left: 4px solid #20208C; }

.f-note__body {
  padding: 15px 12px 35px; }
  .f-note__body.is-close {
    display: none; }

.f-note__body--large {
  padding: 22px 12px 30px; }
  .f-note__body--large.is-close {
    display: none; }

.f-note__body--small {
  padding: 5px 12px 30px;
  border-bottom: 1px solid #dedede; }
  .f-note__body--small.is-close {
    display: none; }

.f-note__body--exsmall {
  padding: 20px 12px; }
  .f-note__body--exsmall.is-close {
    display: none; }

.f-note__body-noline {
  margin: 20px 12px 30px; }
  .f-note__body-noline.is-close {
    display: none; }
  .f-note__body-noline .f-detail-info__list {
    margin: 0; }

.f-note__text {
  font-size: 12px;
  line-height: 1.5; }

.f-note__text--indent {
  padding-left: 1.4em;
  font-size: 12px;
  line-height: 1.5;
  text-indent: -1.4em; }

.f-note__text--strong {
  font-weight: bold; }

.f-note__attention {
  font-weight: bold;
  color: #cc0d21; }

.f-note__list {
  margin-top: 10px;
  margin-bottom: 10px;
  padding-left: 0; }

.f-note__item {
  padding-left: 12px;
  font-size: 12px;
  list-style: none;
  line-height: 1.5;
  position: relative; }
  .f-note__item::before {
    content: '・';
    position: absolute;
    top: 0;
    left: 0; }

.f-note__link {
  color: #0065D6;
  text-decoration: none;
  transition: opacity 0.2s ease-out; }

.f-note-info__list {
  margin-top: 20px; }

.f-note-info__item {
  position: relative;
  margin-bottom: 8px;
  padding-left: 15px;
  font-size: 13px;
  font-weight: bold; }
  .f-note-info__item::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 8px;
    height: 2px;
    background-color: #20208C;
    transform: translateY(-50%); }

.f-note-info__item--strong {
  position: relative;
  margin-bottom: 8px;
  padding-left: 15px;
  font-size: 13px;
  font-weight: bold; }
  .f-note-info__item--strong::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 8px;
    height: 2px;
    background-color: #e61b61;
    transform: translateY(-50%); }

.f-note-info__description {
  margin-bottom: 15px; }

.f-note-info__text--strong {
  margin-top: 8px;
  margin-bottom: 8px;
  font-size: 12px;
  font-weight: bold; }

.f-note-train {
  margin-bottom: 25px; }

/*--------------------------------
2.16 ballon
--------------------------------*/
.f-ballon {
  width: 100%;
  margin-bottom: 30px;
  border: 1px solid #ccc;
  box-sizing: border-box; }

.f-ballon--standard {
  width: 100%;
  border: 1px solid #ccc;
  box-sizing: border-box; }

.f-ballon__head {
  display: flex;
  align-items: center;
  height: 46px;
  padding-left: 12px;
  padding-right: 12px; }

.f-ballon__title {
  width: calc(100% - 25px);
  font-size: 15px;
  font-weight: bold; }

.f-ballon__body {
  display: none;
  position: relative;
  padding-top: 15px; }
  .f-ballon__body::before {
    content: "";
    position: absolute;
    top: 0;
    left: 12px;
    width: calc(100% - 24px);
    height: 1px;
    background-color: #ccc; }
  .f-ballon__body.is-open {
    display: flex; }

/*--------------------------------
2.17 window
--------------------------------*/
.f-window {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  overflow-y: auto;
  backface-visibility: hidden;
  z-index: 20; }
  .f-window .f-detail-roundtrip__list::after {
    border: none; }

.f-window__inner {
  padding-bottom: 75px;
  -webkit-overflow-scrolling: touch; }

.f-window__head--fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 30; }

.f-window-gallery {
  padding-bottom: 46px; }

.f-window-gallery__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 15px 12px;
  background-color: #20208C; }

.f-window-gallery__title {
  position: relative;
  padding-left: 30px;
  font-weight: bold;
  font-size: 18px;
  color: #fff; }
  .f-window-gallery__title::before {
    content: "";
    position: absolute;
    top: 1px;
    left: 5px;
    width: 17px;
    height: 15px;
    background: url("../images/icon/ico_photo02.png") no-repeat 0 0;
    background-size: 17px 15px; }

.f-window-gallery__icon {
  width: 42px; }

.f-window-gallery__body {
  margin-top: 90px;
  margin-left: 12px;
  margin-right: 12px; }

.f-window-gallery__image {
  background-color: #eeeeec;
  text-align: center; }

.f-window-gallery__inner {
  margin-top: 20px; }

.f-window-gallery__inner-bottom {
  margin-top: 30px;
  margin-bottom: 46px; }

.f-window-gallery__heading {
  display: flex;
  align-items: center;
  height: 20px;
  margin-bottom: 17px;
  padding-left: 10px;
  font-weight: bold;
  border-left: 4px solid #20208C; }

.f-window-gallery__detail {
  margin-bottom: 20px; }

.f-window-gallery__picture {
  height: 310px; }

.f-window-gallery__caption {
  margin-top: 10px;
  font-size: 12px; }

.f-window .f-search-window__item-choice {
  padding: 0; }
.f-window .f-radio__label {
  padding: 12px 5px 12px 47px; }
.f-window .f-radio + .f-radio__label::before {
  left: 12px; }
.f-window .f-radio + .f-radio__label::after {
  left: 19px; }
.f-window.f-search-keywords__radio .f-radio__label {
  padding: 0;
  padding-left: 35px;
  width: auto; }
.f-window.f-search-keywords__radio .f-radio + .f-radio__label::before {
  left: 0; }
.f-window.f-search-keywords__radio .f-radio + .f-radio__label::after {
  left: 7px; }

/* チェックボックス */
.f-window .f-search-window__item-choice {
  padding: 0; }
.f-window .f-detail-term__checkbox {
  padding: 12px 5px 12px 12px;
  width: 100%; }
.f-window .f-ballon .f-detail-term__checkbox {
  margin-right: 15px;
  padding: 0; }
.f-window .f-ballon .f-checkbox__text {
  padding-right: 0; }

/*--------------------------------
2.18 plan
--------------------------------*/
.f-plan-facility__head {
  display: flex;
  width: 100%;
  padding: 18px 12px;
  border-top: 1px solid #dedede;
  box-sizing: border-box; }

.f-plan-facility__head-inner {
  width: calc(100% - 62px);
  padding-right: 12px;
  box-sizing: border-box; }

.f-plan-facility__title {
  margin-bottom: 5px;
  font-size: 18px;
  font-weight: bold;
  color: #20208C;
  line-height: 1.5; }

.f-plan-facility__subtitle {
  font-size: 12px;
  color: #a0a0a0;
  line-height: 1.5; }

.f-plan-facility__pr_label {
  margin: 6px 0;
  font-size: 13px; }

.f-plan-facility__pr_icon_01 {
  display: inline-block;
  border: 1px solid #e04c31;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #e04c31;
  font-weight: bold;
  vertical-align: middle; }

.f-plan-facility__pr_icon_01_text {
  display: inline-block;
  list-style: none;
  padding: 6px 9px;
  color: #e04c31;
  vertical-align: middle;
  white-space: pre-wrap;
  max-width: calc(100% - 120px);
  box-sizing: border-box; }

.f-plan-facility__pr_icon_02 {
  display: inline-block;
  border: 1px solid #069ad6;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #069ad6;
  font-weight: bold; }

.f-plan-detail__head {
  padding: 15px 12px;
  background-color: #ededed;
  border-top: 4px solid #20208C;
  box-sizing: border-box; }

.f-plan-detail__title {
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: bold;
  color: #000;
  line-height: 1.5; }

.f-plan-detail__title--short {
  font-size: 18px;
  font-weight: bold;
  color: #000;
  line-height: 1.5; }

.f-plan-detail__body {
  margin-bottom: 30px; }

.f-plan-detail__inner {
  padding-top: 20px;
  padding-left: 12px;
  padding-right: 12px; }

.f-plan-detail__caption {
  min-height: 12px;
  margin-top: 15px;
  margin-left: 12px;
  font-size: 12px; }

.f-plan-detail__word {
  flex-grow: 1;
  line-height: 1.5;
  word-break: break-all;
  overflow-wrap: break-word; }

.f-plan-detail__word--number {
  display: inline-block;
  font-feature-settings: "palt";
  word-break: break-all;
  overflow-wrap: break-word; }

.f-plan-detail__flex {
  display: flex;
  align-items: center;
  width: 100%; }

.f-plan-detail__code {
  width: calc(100% - 91px);
  word-wrap: break-word; }

.f-plan-detail__banner {
  width: 86px;
  display: flex;
  align-items: center;
  margin-left: 5px; }
  .f-plan-detail__banner .f-button-hint {
    margin-top: 4px; }

.f-plan-detail__image {
  width: 56px; }

.f-plan-detail__news {
  margin-top: 20px;
  padding-top: 15px;
  padding-left: 12px;
  padding-right: 12px;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-plan-number__wrap {
  margin-top: -20px;
  margin-bottom: 20px; }

.f-plan-number {
  display: flex;
  flex-wrap: wrap;
  padding-top: 10px;
  padding-bottom: 10px; }
  .f-plan-number .f-detail-unit__title {
    width: 100%; }
  .f-plan-number + .f-plan-number {
    margin-top: -20px; }
  .f-plan-number:nth-child(3) {
    margin-bottom: 30px; }

.f-plan-number-line {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding-top: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid #ccc; }

.f-plan-number__head {
  width: 49px;
  margin-top: 10px;
  font-weight: bold;
  font-size: 13px; }

.f-plan-number__title {
  display: block;
  width: 93px;
  font-weight: bold; }

.f-plan-number__inner {
  width: calc(100% - 93px); }

.f-plan-number__room {
  width: calc(100% - 93px); }

.f-plan-number__body {
  display: flex;
  justify-content: space-between;
  width: calc(100% - 49px); }

.f-plan-number__select-inner {
  display: flex;
  align-items: center;
  margin-bottom: 20px; }

.f-plan-number__strong {
  width: 44px;
  font-weight: bold;
  font-size: 13px;
  text-align: center; }

.f-plan-number__man {
  position: relative;
  width: 44px;
  padding-left: 13px;
  font-size: 13px;
  box-sizing: border-box; }
  .f-plan-number__man::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 11px;
    height: 12px;
    background: url("../images/icon/ico_man01.png") no-repeat 0 0;
    background-size: 11px 12px;
    transform: translateY(-50%); }

.f-plan-number__woman {
  position: relative;
  width: 44px;
  padding-left: 13px;
  font-size: 13px;
  box-sizing: border-box; }
  .f-plan-number__woman::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 11px;
    height: 12px;
    background: url("../images/icon/ico_woman01.png") no-repeat 0 0;
    background-size: 11px 12px;
    transform: translateY(-50%); }

.f-plan-period {
  display: flex;
  align-items: center;
  margin: 15px 0; }

.f-plan-period__detail {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 15px; }

.f-plan-period__inner {
  margin-right: 10px;
  margin-bottom: 13px; }

.f-plan-period__text--light {
  margin-bottom: 5px;
  font-size: 11px;
  color: #a0a0a0; }

.f-plan-period__text {
  justify-content: flex-end;
  white-space: nowrap; }

.f-plan-period__text-date {
  display: inline-block;
  min-width: 160px; }

.f-plan-period__text-from {
  margin-right: 8px;
  font-size: 12px; }

.f-plan-period__select--large {
  margin-top: 15px;
  margin-bottom: 30px; }
  .f-plan-period__select--large .f-select__wrap {
    display: block; }

.f-plan-requirement__background {
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
  padding: 15px 15px 15px 20px;
  background-color: #ededed;
  border: 1px solid #dedede;
  border-radius: 6px;
  box-sizing: border-box; }

.f-plan-requirement__text--small {
  display: block;
  font-size: 9px; }

.f-plan-price .f-table__data {
  font-size: 12px; }

.f-plan-vacancy {
  width: 100%;
  margin-bottom: -10px;
  padding-top: 18px;
  padding-bottom: 18px;
  font-weight: bold;
  text-align: center;
  border-bottom: 1px solid #dedede; }

.f-plan-word {
  margin-top: 20px;
  padding: 12px;
  font-size: 12px;
  line-height: 1.5;
  background-color: #ededed;
  border-radius: 6px; }

.f-plan-calendar {
  margin-top: 30px;
  margin-bottom: 30px;
  padding-left: 12px;
  padding-right: 12px;
  background-color: #fff;
  border: 2px solid #20208C;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6; }

.f-plan-calendar__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px; }

.f-plan-calendar__title {
  width: calc(100% - 22px);
  padding-right: 8px;
  font-size: 16px;
  font-weight: bold;
  color: #20208C;
  text-align: center; }

.f-plan-calendar__icon {
  width: 17px;
  margin-right: 10px; }

.f-plan-calendar__flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 20px;
  padding-bottom: 20px; }
  .f-plan-calendar__flex + .f-plan-calendar__flex {
    padding-top: 20px;
    border-top: 1px solid #dedede; }

.f-plan-calendar__text--right {
  font-size: 12px;
  text-align: right; }

.f-plan-calendar__text--price,
.f-plan-calendar__text--ok {
  color: #0065D6; }

.f-plan-calendar__text--child {
  position: relative;
  padding-top: 8px;
  padding-left: 12px;
  padding-right: 12px;
  font-size: 10px;
  white-space: nowrap; }
  .f-plan-calendar__text--child::after {
    content: "";
    position: absolute;
    top: 12px;
    right: 0;
    width: 5px;
    height: 5px;
    border-top: 2px solid #20208C;
    border-left: 2px solid #20208C;
    transform: rotate(45deg); }
  .f-plan-calendar__text--child.is-close::after {
    top: 9px;
    border: none;
    border-bottom: 2px solid #20208C;
    border-right: 2px solid #20208C; }

.f-plan-calendar__text--sat {
  color: #21A4Ea; }

.f-plan-calendar__text--dayoff {
  color: #cc0d21; }

.f-plan-calendar__body {
  border-top: 2px solid #20208C; }
  .f-plan-calendar__body.is-close {
    display: none; }
  .f-plan-calendar__body .f-select {
    min-width: 120px; }

.f-plan-calendar__wrap {
  margin-top: 20px;
  margin-bottom: 20px; }

.f-plan-calendar__week {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding-top: 14px;
  padding-bottom: 14px;
  border: 1px solid #dedede; }
  .f-plan-calendar__week.is-active {
    background-color: #ffeaf1; }
  .f-plan-calendar__week + .f-plan-calendar__week {
    border-top: none; }

.f-plan-calendar__week-day {
  width: 30%;
  padding-left: 14px;
  box-sizing: border-box; }

.f-plan-calendar__week-vacancy {
  width: 37%;
  padding-left: 20px;
  text-align: center;
  box-sizing: border-box; }

.f-plan-calendar__week-price {
  width: 33%;
  padding-right: 14px;
  text-align: right;
  box-sizing: border-box; }

.f-plan-calendar__child {
  width: 100%;
  margin-top: 10px;
  font-size: 11px; }
  .f-plan-calendar__child.is-close {
    display: none; }

.f-plan-calendar__list {
  display: flex;
  flex-wrap: wrap;
  width: 120px;
  margin-left: calc(100% - 120px); }

.f-plan-calendar__item {
  width: 40%;
  margin-bottom: 5px;
  text-align: left; }

.f-plan-calendar__description {
  width: 50%;
  margin-bottom: 5px;
  text-align: right; }

.f-plan-type__text--woman {
  margin-left: 20px;
  margin-bottom: 12px;
  font-size: 12px;
  color: #cc0d21; }

.f-plan-remarks {
  border-bottom: 1px solid #dedede; }

.f-plan-remarks__title {
  margin-bottom: 20px;
  padding: 12px;
  font-size: 12px;
  font-weight: bold;
  background-color: #ededed; }

.f-plan-remarks__body {
  padding-left: 12px;
  padding-right: 12px; }

.f-plan-requirement__text--important {
  margin-top: 30px;
  margin-bottom: 20px;
  font-size: 12px;
  font-weight: bold;
  font-feature-settings: "palt";
  line-height: 1.3;
  text-align: center; }

.f-plan-schedule__text--strong {
  font-weight: bold;
  color: #20208C; }

.f-plan-schedule__image {
  position: relative;
  top: 6px;
  width: 29px; }

.f-plan-schedule__icon--train {
  position: relative;
  top: 2px;
  width: 11px;
  margin-right: 2px; }

.f-plan-schedule__icon--facility {
  position: relative;
  top: 3px;
  width: 15px;
  margin-right: 2px; }

.f-plan-note_remarks {
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 25px;
  padding-bottom: 25px;
  border-bottom: 1px solid #dedede;
  font-size: 12px;
  line-height: 1.5; }

.f-plan-company {
  margin-top: 30px;
  margin-bottom: 60px; }

.f-plan-company__inner {
  margin-bottom: 30px;
  padding: 18px 12px;
  background-color: #ededed; }

.f-plan-related__head {
  padding: 12px;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.5;
  background-color: #ededed;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-plan-related__body {
  display: block;
  position: relative;
  margin-bottom: 30px;
  padding: 15px 25px 15px 12px;
  color: #333;
  text-decoration: none;
  border-bottom: 1px solid #dedede; }
  .f-plan-related__body::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 15px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-plan-related__inner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }

.f-plan-related__image {
  width: 80px; }

.f-plan-related__picture {
  width: 100%; }

.f-plan-related__copy {
  width: calc(100% - 80px);
  margin-top: -3px;
  margin-bottom: 10px;
  padding-left: 15px;
  font-weight: bold;
  color: #20208C;
  line-height: 1.5;
  box-sizing: border-box; }

.f-plan-related__detail {
  display: flex;
  align-items: center;
  width: calc(100% - 80px);
  padding-left: 10px;
  box-sizing: border-box; }

.f-plan-related__text {
  font-size: 11px;
  line-height: 1.5; }
  .f-plan-related__text + .f-plan-related__inner {
    margin-top: 10px; }

.f-plan-related__text-price {
  font-size: 15px;
  font-weight: bold;
  color: #cc0d21; }

.f-plan-related__text--strong {
  margin-right: 20px;
  font-weight: bold; }

.f-plan-relatec__text--light {
  margin-left: 5px;
  font-size: 11px;
  color: #a0a0a0; }

.f-plan-related__name {
  margin-bottom: 10px;
  font-weight: bold;
  color: #20208C; }

.f-plan-related__stars {
  font-weight: bold;
  font-size: 12px; }

@media screen and (min-width: 410px) {
  .f-plan-number__body {
    justify-content: flex-start; }

  .f-plan-number__select {
    max-width: 180px; }
    .f-plan-number__select + .f-plan-number__select {
      margin-left: 10%; } }
@media screen and (max-width: 369px) {
  .f-plan-detail__container {
    display: block; }

  .f-plan-detail__banner {
    display: flex;
    justify-content: flex-end;
    width: 100%;
    margin-top: 10px; } }
@media screen and (max-width: 320px) {
  .f-plan-calendar__title {
    padding-right: 4px;
    font-size: 14px;
    line-height: 18px; }

  .f-plan-number__select-inner .f-select {
    min-width: 80px; }

  .f-plan-number__head {
    width: 30px;
    font-size: 12px; }

  .f-plan-number__body {
    width: calc(100% - 30px); }

  .f-plan-number__strong,
  .f-plan-number__man,
  .f-plan-number__woman {
    margin-right: 3px;
    font-size: 11px; }

  .f-plan-type__text--woman {
    margin-left: 0; }

  .f-plan-calendar__week {
    font-size: 13px; }

  .f-plan-related__text {
    width: 100%;
    margin-bottom: 5px; }

  .f-plan-related__text--strong {
    margin-right: 20px;
    font-weight: bold; }

  .f-plan-related__text--light {
    display: block;
    width: 100%;
    margin-top: 5px; }

  .f-plan-related__name {
    margin-bottom: 15px; }

  .f-plan-related__stars .f-detail__star--small {
    display: block;
    margin-top: 5px;
    margin-left: 0; } }
/*--------------------------------
2.19 confirm
--------------------------------*/
.f-confirm {
  padding-bottom: 40px;
  border-top: 1px solid #dedede; }

.f-confirm__body {
  padding: 22px 12px 30px; }

.f-confirm__inner {
  margin-bottom: 20px;
  padding: 18px 12px;
  border: 1px solid #dedede; }

.f-confirm__text {
  font-size: 12px;
  line-height: 1.5; }
  .f-confirm__text + .f-confirm__text {
    margin-top: 15px; }

.f-confirm__text--important {
  font-weight: bold;
  color: #cc0d21; }

.f-confirm__text--strong {
  font-weight: bold; }

.f-confirm-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #fff9f0;
  border-bottom: 1px solid #dedede; }

.f-confirm-total__inner {
  padding: 16px 12px;
  border-bottom: 1px solid #dedede; }

.f-confirm-total__text {
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 12px; }

.f-confirm-total__text--price {
  padding-top: 20px;
  padding-bottom: 20px;
  padding-right: 12px;
  font-weight: bold;
  font-size: 18px;
  color: #cc0d21;
  text-align: right; }

.f-confirm-total__text--medium {
  font-size: 13px;
  line-height: 1.5; }
  .f-confirm-total__text--medium + .f-confirm-total__text--medium {
    margin-top: 20px; }

.f-confirm-total__text--small {
  margin-right: 10px;
  font-weight: bold;
  font-size: 12px; }

.f-confirm-total__caption {
  margin: 15px 12px 20px; }

.f-confirm-total-table {
  width: 100%;
  border-collapse: collapse; }

.f-confirm-total-table__head {
  width: 60px;
  padding-top: 18px;
  padding-bottom: 18px;
  padding-left: 12px;
  font-weight: bold;
  font-size: 12px;
  text-align: left;
  vertical-align: middle;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-total-table__data {
  padding: 18px 12px;
  border-bottom: 1px solid #dedede; }
  .f-confirm-total-table__data:last-child {
    text-align: right; }

.f-confirm-plan {
  padding-left: 12px;
  padding-right: 12px;
  padding-bottom: 20px; }

.f-confirm-arrow__list--right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-top: 20px;
  height: 20px; }

.f-confirm-arrow__item {
  height: 20px;
  margin-right: 5px;
  list-style: none; }
  .f-confirm-arrow__item + .f-confirm-arrow__item {
    margin-left: 20px; }
  .f-confirm-arrow__item .f-button-hint__image {
    position: relative;
    top: -2px; }

.f-confirm-schedule {
  padding: 15px 12px 0;
  border-bottom: 1px solid #dedede; }

.f-confirm-schedule__head {
  display: flex;
  align-items: center;
  margin-bottom: 15px; }

.f-confirm-schedule__day {
  width: 80px;
  height: 30px;
  margin-right: 15px;
  padding-top: 8px;
  font-size: 15px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background-color: #20208C;
  box-sizing: border-box; }

.f-confirm-schedule__date {
  font-size: 15px;
  font-weight: bold;
  color: #20208C; }

.f-confirm-schedule__timeline-wrap {
  position: relative;
  margin-top: 7px;
  margin-bottom: 13px;
  padding-top: 20px;
  padding-bottom: 16px; }
  .f-confirm-schedule__timeline-wrap::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 14px;
    height: 16px;
    background: url("../images/icon/ico_train02.png") no-repeat 0 0;
    background-size: 14px 16px; }

.f-confirm-schedule__timeline {
  position: relative;
  padding-left: 22px;
  background: url("../images/img_rail01.png") repeat-y 4px 0;
  background-size: 6px 36px; }
  .f-confirm-schedule__timeline::after {
    content: "";
    position: absolute;
    bottom: -20px;
    left: 0;
    width: 14px;
    height: 16px;
    background: url("../images/icon/ico_train02.png") no-repeat 0 0;
    background-size: 14px 16px; }
  .f-confirm-schedule__timeline:not(:last-child) {
    margin-bottom: 22px; }

.f-confirm-schedule__text-time {
  margin-bottom: 2px;
  line-height: 1.5; }

.f-confirm-schedule__text-info {
  margin-bottom: 2px;
  font-size: 12px;
  line-height: 1.5; }

.f-confirm-schedule__timeline-item {
  position: relative;
  margin-bottom: 5px;
  line-height: 1.3; }

.f-confirm-schedule__box-arrow {
  position: relative;
  margin-bottom: 20px;
  padding: 10px 30px;
  font-size: 12px;
  line-height: 1.5;
  border-top: 1px dashed #dedede;
  border-bottom: 1px dashed #dedede; }
  .f-confirm-schedule__box-arrow::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 8px;
    width: 6px;
    height: 30px;
    background: url("../images/img_arrow01.png") no-repeat 0 0;
    background-size: 6px 30px;
    transform: translateY(-50%); }

.f-confirm-schedule__box-facility {
  display: flex;
  position: relative;
  padding-left: 30px;
  padding-bottom: 5px;
  line-height: 1.5; }
  .f-confirm-schedule__box-facility::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 20px;
    height: 16px;
    background: url("../images/icon/ico_facility01.png") no-repeat 0 0;
    background-size: 20px 16px;
    transform: translateY(-50%); }

.f-confirm-schedule__image {
  width: 80px; }

.f-confirm-schedule__picture {
  width: 100%; }

.f-confirm-schedule__detail {
  width: calc(100% - 80px);
  margin-top: -3px;
  padding-left: 15px;
  box-sizing: border-box; }

.f-confirm-ballon {
  padding-top: 10px;
  padding-bottom: 20px; }

.f-confirm__button {
  margin: 10px 12px 40px; }

.f-confirm__button-inner {
  margin-bottom: 20px; }

.f-confirm-payment__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 10px; }

.f-confirm-payment__item {
  position: relative;
  width: 48.5%;
  margin-top: 10px;
  padding-top: 48px;
  padding-bottom: 20px;
  font-size: 13px;
  list-style: none;
  text-align: center;
  border: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-payment__item::before {
    content: "";
    position: absolute;
    top: 25px;
    left: 50%;
    transform: translateX(-50%); }
  .f-confirm-payment__item:first-child::before {
    width: 18px;
    height: 12px;
    background: url("../images/icon/ico_card01.png") no-repeat 0 0;
    background-size: 18px 12px; }
  .f-confirm-payment__item:nth-child(2)::before {
    width: 16px;
    height: 14px;
    background: url("../images/icon/ico_bank01.png") no-repeat 0 0;
    background-size: 16px 14px; }
  .f-confirm-payment__item:nth-child(3)::before {
    width: 17px;
    height: 12px;
    background: url("../images/icon/ico_store01.png") no-repeat 0 0;
    background-size: 17px 12px; }
  .f-confirm-payment__item:nth-child(4)::before {
    width: 12px;
    height: 12px;
    background: url("../images/icon/ico_tel01.png") no-repeat 0 0;
    background-size: 12px 12px; }
  .f-confirm-payment__item.is-unsupported {
    color: #a0a0a0;
    background-color: #ededed;
    border: none; }
  .f-confirm-payment__item.is-unsupported:first-child::before {
    background: url("../images/icon/ico_card02.png") no-repeat 0 0;
    background-size: 18px 12px; }
  .f-confirm-payment__item.is-unsupported:nth-child(2)::before {
    background: url("../images/icon/ico_bank02.png") no-repeat 0 0;
    background-size: 16px 14px; }
  .f-confirm-payment__item.is-unsupported:nth-child(3)::before {
    background: url("../images/icon/ico_store02.png") no-repeat 0 0;
    background-size: 17px 12px; }
  .f-confirm-payment__item.is-unsupported:nth-child(4)::before {
    background: url("../images/icon/ico_tel02.png") no-repeat 0 0;
    background-size: 12px 12px; }

.f-confirm__text--important {
  margin-top: 15px;
  font-weight: normal;
  font-size: 12px;
  color: #cc0d21;
  line-height: 1.5; }

.f-confirm-apply {
  margin-top: 15px;
  padding-left: 12px;
  padding-right: 12px;
  border-top: 1px solid #dedede; }
  .f-confirm-apply + .f-confirm-apply {
    margin-top: 0; }
  .f-confirm-apply:last-of-type {
    border-bottom: 1px solid #dedede; }

.f-confirm-store__list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 20px;
  border-top: 1px solid #dedede; }

.f-confirm-store__item {
  width: 115px;
  padding: 5px 8px;
  font-weight: bold;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-store__item:first-of-type {
    background-color: #ededed; }

.f-confirm-store__description {
  width: calc(100% - 115px);
  padding: 5px 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-store__description:first-of-type {
    background-color: #ededed; }
  .f-confirm-store__description:last-of-type {
    padding-top: 13px; }

.f-confirm-store__text {
  padding: 5px 8px;
  font-size: 12px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede; }

.f-confirm-store-plan__item {
  padding-top: 8px;
  padding-left: 8px;
  font-weight: bold;
  font-size: 13px;
  line-height: 1.5; }

.f-confirm-store-plan__description {
  padding: 5px 8px 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede; }

.f-confirm-store-bond {
  width: 170px;
  margin-top: 10px; }

.f-confirm-cancel__text {
  margin-top: 18px;
  margin-bottom: 15px;
  font-size: 12px; }

.f-confirm-cancel__text--attention {
  padding: 10px 8px;
  font-weight: bold;
  font-size: 15px;
  color: #333;
  line-height: 1.5;
  border: 1px solid #cc0d21; }

.f-confirm-cancel__list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 20px;
  border-top: 1px solid #dedede; }

.f-confirm-cancel__item {
  width: 180px;
  padding: 5px 8px;
  font-weight: bold;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-cancel__item:first-of-type {
    padding: 13px 5px;
    font-size: 12px;
    color: #000;
    background-color: #ededed; }

.f-confirm-cancel__description {
  width: calc(100% - 180px);
  padding: 5px 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-cancel__description:first-of-type {
    padding: 13px 5px;
    font-weight: bold;
    font-size: 12px;
    color: #000;
    background-color: #ededed; }
  .f-confirm-cancel__description:last-of-type {
    padding-top: 13px; }

.f-confirm-difference .f-table-line__data,
.f-confirm-difference .f-table-line__data-right {
  line-height: 1.3;
  vertical-align: middle; }

.f-confirm-jr-message {
  margin-left: 8px;
  font-size: 14px;
  line-height: 1.5; }

@media screen and (max-width: 320px) {
  .f-confirm-difference {
    font-size: 12px; }
    .f-confirm-difference .f-table-line__head,
    .f-confirm-difference .f-table-line__data,
    .f-confirm-difference .f-table-line__data-right {
      padding: 10px; }

  .f-confirm-schedule__text-time {
    font-size: 12px; }

  .f-confirm-schedule__text-info {
    font-size: 11px; } }
/*--------------------------------
2.20 carousel
--------------------------------*/
.f-carousel__wrap {
  position: relative;
  width: 100%;
  overflow: hidden;
  margin-bottom: 22px; }

.f-carousel__image {
  height: 310px;
  margin: 0 auto;
  max-width: 100%; }

.f-carousel__picture {
  height: 310px;
  margin: 0 auto;
  max-width: 100%; }

.f-carousel__inner {
  height: 100%;
  width: 100%; }

.f-carousel__arrows .slick-arrow {
  display: block;
  position: absolute;
  top: 50%;
  width: 30px;
  height: 60px;
  background-color: rgba(0, 0, 0, 0.8);
  border: none;
  color: transparent;
  outline: none;
  box-sizing: border-box;
  transform: translateY(-70%); }

.f-carousel__arrows .slick-prev {
  left: 0; }

.f-carousel__arrows .slick-prev::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 9px;
  width: 7px;
  height: 7px;
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff;
  box-sizing: border-box;
  transform: rotate(45deg) translateY(-55%); }

.f-carousel__arrows .slick-next {
  right: 0; }

.f-carousel__arrows .slick-next::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 9px;
  width: 7px;
  height: 7px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  box-sizing: border-box;
  transform: rotate(45deg) translateY(-55%); }

.f-carousel__number {
  position: absolute;
  bottom: 0;
  right: 12px;
  font-family: Helvetica, sans-serif;
  font-size: 12px;
  letter-spacing: 0.05em; }

/*--------------------------------
2.21 modal
--------------------------------*/
.f-modal {
  display: none;
  position: fixed;
  width: 90%;
  min-height: 180px;
  padding: 20px 25px 80px;
  background-color: #fff;
  box-sizing: border-box;
  z-index: 150; }

.f-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  z-index: 100; }

.f-modal__text {
  font-size: 13px;
  line-height: 1.3;
  margin-bottom: 20px;
  padding: 0; }
  .f-modal__text + .f-modal__text {
    margin-top: 20px; }

.f-modal__button {
  display: flex;
  justify-content: center;
  position: absolute;
  bottom: 25px;
  left: 0;
  width: 100%;
  padding-left: 25px;
  padding-right: 25px;
  box-sizing: border-box; }

.f-modal__button-flex {
  display: flex;
  justify-content: space-between;
  position: absolute;
  bottom: 25px;
  left: 0;
  width: 100%;
  padding-left: 25px;
  padding-right: 25px;
  box-sizing: border-box; }

.f-modal-detail {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  padding: 12px 25px;
  background-color: #fff;
  box-sizing: border-box;
  z-index: 150; }
  .f-modal-detail .f-detail-unit__title {
    margin-bottom: 18px; }

.f-modal-hint {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  padding: 12px 25px;
  background-color: #fff;
  box-sizing: border-box;
  z-index: 150; }

.f-modal__title {
  display: flex;
  align-items: center;
  margin: 0 0 5px 0;
  padding: 0 10px 0;
  border-left: 3px solid #0b308e;
  font-weight: bold; }
  .f-modal__title img {
    margin-left: 10px;
    padding-bottom: 0; }

.f-modal__button--close {
  position: absolute;
  top: 15px;
  right: 12px;
  width: 24px;
  height: 24px; }
  .f-modal__button--close::before, .f-modal__button--close::after {
    content: "";
    display: block;
    position: absolute;
    top: 8px;
    right: 0;
    width: 24px;
    height: 2px;
    background-color: #a0a0a0; }
  .f-modal__button--close::before {
    transform: rotate(-45deg); }
  .f-modal__button--close::after {
    transform: rotate(45deg); }

.f-modal-gallery {
  position: relative;
  width: 960px;
  margin: 50px auto;
  background-color: #fff;
  z-index: 150; }
  .f-modal-gallery .mfp-close {
    display: none; }

.f-modal-gallery__head {
  display: flex;
  justify-content: space-between;
  padding: 15px 15px 15px 10px;
  background-color: #20208C; }

.f-modal-gallery__title {
  position: relative;
  padding-left: 30px;
  font-weight: bold;
  font-size: 20px;
  color: #fff; }
  .f-modal-gallery__title::before {
    content: "";
    position: absolute;
    top: 3px;
    left: 5px;
    width: 17px;
    height: 15px;
    background: url("../images/icon/ico_photo02.png") no-repeat 0 0;
    background-size: 17px 15px; }

.f-modal-gallery__icon {
  width: 26px; }

.f-modal-gallery__body {
  padding: 30px 70px;
  background-color: #fff; }

.f-modal-gallery__inner {
  margin-bottom: 30px; }

.f-modal-gallery__inner-bottom {
  margin-bottom: 50px; }

.f-modal-gallery__heading {
  padding: 2px 10px;
  font-weight: bold;
  border-left: 4px solid #20208C; }

.f-modal-gallery__flex {
  display: flex; }

.f-modal-gallery__detail {
  width: 375px; }
  .f-modal-gallery__detail:nth-child(even) {
    margin-left: 60px; }

.f-modal-gallery__image {
  display: flex;
  align-items: center;
  width: 375px;
  background-color: #ededed; }

.f-modal-gallery__picture {
  width: 100%; }

.f-modal-gallery__caption {
  margin-top: 15px;
  font-size: 12px; }

.f-modal__icon {
  width: 42px; }

#shadow {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -moz-opacity: 0.70;
  background-color: gray;
  display: none;
  position: absolute;
  top: 0px;
  left: 0px; }

.childNum a {
  text-decoration: none;
  font-size: 95%; }

.modal_window {
  background: #fff;
  -webkit-border-radius: 5px;
  border-radius: 5px;
  -webkit-box-shadow: 5px 5px 5px 5px rgba(5, 5, 5, 0.5);
  box-shadow: 5px 5px 5px 5px rgba(5, 5, 5, 0.5);
  display: none;
  left: 42px;
  position: relative;
  width: 306px;
  z-index: 150; }

.modal_child {
  border: 2px solid #20208c;
  background: #FFFFFF;
  z-index: 100; }

.modal_child .inner {
  padding: 10px 5px; }

.modal_child .inner table {
  margin: 0 auto; }

.modal_child th {
  font-weight: normal;
  text-align: left;
  padding-right: 5px; }

.modal_child .attention {
  text-align: center;
  clear: both;
  font-size: 85%;
  color: #FF0000;
  padding: 10px 5px; }

.modal_child .close {
  text-align: center;
  clear: both;
  padding: 5px; }

.modal_child .close a {
  border: 1px solid #999999;
  border-radius: 4px 4px 4px 4px;
  background: -moz-linear-gradient(center top, #FFFFFF, #e8ecef) repeat scroll 0 0 transparent;
  background: -webkit-gradient(linear, left top, left bottom, from(#FFFFFF), to(#e8ecef));
  text-align: center;
  clear: both;
  font-size: 85%;
  padding: 5px 30px;
  text-decoration: none; }

/*--------------------------------
2.22 card
--------------------------------*/
.f-card__head {
  padding: 12px;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.5;
  background-color: #ededed;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-card__head--check {
  position: relative;
  padding: 16px 12px 16px 32px;
  font-weight: bold;
  font-size: 15px;
  background-color: #ededed;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  box-sizing: border-box; }
  .f-card__head--check::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 18px;
    width: 5px;
    height: 10px;
    margin-top: -5px;
    border-bottom: 3px solid #20208C;
    border-right: 3px solid #20208C;
    transform: rotate(50deg) translate(-60%); }

.f-card__body {
  display: block;
  position: relative;
  margin-bottom: 30px;
  padding: 15px 25px 15px 12px;
  color: #333;
  text-decoration: none; }
  .f-card__body::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 15px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-card__inner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }

.f-card__link {
  display: block;
  padding: 10px;
  color: #333;
  text-decoration: none;
  border-bottom: 1px solid #ccc; }

.f-card__link--noline {
  display: block;
  padding: 10px;
  color: #333;
  text-decoration: none; }

.f-card__label--recommend {
  margin-bottom: 10px;
  padding-top: 5px;
  padding-bottom: 5px;
  font-weight: bold;
  font-size: 11px;
  color: #fff;
  text-align: center;
  background-color: #e61b61; }

.f-card__block {
  display: flex;
  position: relative;
  padding-right: 10px; }
  .f-card__block::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 6px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-card__image {
  width: 80px; }

.f-card__picture {
  width: 100%; }

.f-card__copy {
  width: calc(100% - 80px);
  margin-top: -3px;
  padding-left: 15px;
  font-weight: bold;
  color: #20208C;
  line-height: 1.5;
  box-sizing: border-box; }

.f-card__list {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px; }

.f-card__list--small {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  margin-right: 20px; }

.f-card__list--exsmall {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px; }

.f-card__item {
  font-size: 11px; }

.f-card__item--small {
  margin-top: 2px;
  font-size: 10px; }

.f-card__description {
  font-size: 15px;
  font-weight: bold;
  color: #cc0d21; }

.f-card__detail {
  display: flex;
  align-items: center;
  width: calc(100% - 80px);
  padding-left: 10px;
  box-sizing: border-box; }

.f-card__text {
  margin-top: 10px;
  font-size: 11px;
  line-height: 1.5; }
  .f-card__text + .f-card__inner {
    margin-top: 10px; }

.f-card__text--strong {
  margin-right: 20px;
  font-weight: bold; }

.f-card__text--light {
  margin-left: 5px;
  font-size: 11px;
  color: #a0a0a0; }

.f-card__name {
  margin-bottom: 10px;
  font-weight: bold;
  color: #20208C; }

.f-card__stars {
  font-weight: bold;
  font-size: 12px; }

@media screen and (max-width: 320px) {
  .f-card__list--small {
    margin-right: 5px; }

  .f-card__list--exsmall .f-card__copy {
    font-size: 12px; }
  .f-card__list--exsmall .f-card__description {
    font-size: 12px; }

  .f-card__item {
    font-size: 10px; }

  .f-card__item--small {
    font-size: 9px; }

  .f-card__description {
    font-size: 12px; } }
/* card */
.f-tab-favorite__content .f-card {
  border-bottom: 1px solid #ccc; }
  .f-tab-favorite__content .f-card:last-child {
    border-bottom: none; }
.f-tab-favorite__content .f-card__link {
  border-bottom: none; }

/*--------------------------------
2.23 star
--------------------------------*/
.f-star {
  position: relative;
  display: inline-block;
  width: 89px;
  height: 18px;
  margin-top: -3px;
  margin-left: 12px;
  font-size: 18px;
  letter-spacing: 1px; }

.f-star:before,
.f-star:after {
  content: "★★★★★";
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  height: 18px; }

.f-star--small {
  position: relative;
  display: inline-block;
  width: 70px;
  height: 12px;
  margin-left: 10px;
  font-size: 14px;
  letter-spacing: 1px; }

.f-star--small:before,
.f-star--small:after {
  content: "★★★★★";
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  height: 12px; }

.f-star:before,
.f-star--small:before {
  color: #ededed; }

.f-star:after,
.f-star--small:after {
  color: #ffba00;
  overflow: hidden;
  white-space: nowrap; }

.f-star0:after {
  width: 0; }

.f-star1:after {
  width: 20%; }

.f-star1-5:after {
  width: 32%; }

.f-star2:after {
  width: 40%; }

.f-star2-5:after {
  width: 53%; }

.f-star3:after {
  width: 62%; }

.f-star3-5:after {
  width: 75%; }

.f-star4:after {
  width: 82%; }

.f-star4-5:after {
  width: 96%; }

.f-star5:after {
  width: 102%; }

/*--------------------------------
2.24 search
--------------------------------*/
.f-plan-detail-attention {
  margin: 0 12px 0 12px; }

.f-search-attention {
  margin-bottom: 20px;
  border: 1px solid #cc0d21; }

.f-search-attention__head {
  padding: 6px 12px;
  font-weight: bold;
  font-size: 12px;
  color: #fff;
  background-color: #cc0d21; }

.f-search-attention__body {
  padding: 10px 12px;
  font-size: 12px;
  color: #cc0d21;
  line-height: 1.5; }

.f-search-attention__text--strong {
  font-weight: bold; }

.f-search-selected {
  margin-bottom: 20px; }

.f-search-selected__head {
  padding: 6px 12px;
  font-weight: bold;
  font-size: 12px;
  color: #fff;
  background-color: #a0a0a0; }

.f-search-selected__body {
  padding: 12px 12px 20px;
  border: 1px solid #ededed; }

.f-search-selected__list {
  display: flex;
  flex-wrap: wrap; }

.f-search-selected__item {
  font-size: 12px;
  color: #a0a0a0; }

.f-search-selected__description {
  margin-right: 10px;
  margin-bottom: 8px;
  font-weight: bold;
  font-size: 12px; }

.f-search-selected__inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 3px;
  padding-top: 5px;
  border-top: 1px dashed #ededed; }

.f-search-selected__text {
  display: flex;
  margin-top: 10px;
  margin-right: 12px;
  font-size: 12px;
  color: #20208C; }

.f-search-selected__button {
  position: relative;
  top: -2px;
  width: 16px;
  margin-left: 5px; }

.f-search-selected__icon {
  width: 100%; }

.f-search-selected__button--delete {
  position: relative;
  top: -2px;
  width: 16px;
  margin-left: 5px; }

.f-search-selected__icon--delete {
  width: 100%; }

.f-search__button-wrap {
  margin-left: 12px;
  margin-right: 12px;
  margin-bottom: 45px; }

.f-search__button-bottom {
  margin-left: 12px;
  margin-right: 12px;
  margin-bottom: 30px; }

.f-search__button {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 43px;
  margin-top: 20px;
  font-size: 16px;
  color: #20208C;
  background-color: #fff;
  border: 2px solid #20208C;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  box-sizing: border-box;
  cursor: pointer; }
  .f-search__button::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 7px;
    height: 7px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-60%); }

.f-search__button--large {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 100%;
  height: 60px;
  margin-top: 20px;
  font-size: 16px;
  color: #20208C;
  background-color: #fff;
  border: 2px solid #20208C;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  box-sizing: border-box;
  cursor: pointer; }
  .f-search__button--large::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 7px;
    height: 7px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-60%); }

.f-search__icon--set {
  position: relative;
  padding-left: 20px;
  font-weight: bold; }
  .f-search__icon--set::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 15px;
    height: 15px;
    background: url("../images/icon/ico_search01.png") no-repeat 0 0;
    background-size: 15px 15px;
    transform: translateY(-50%); }

.f-search {
  margin-left: 10px;
  margin-right: 10px;
  margin-bottom: 20px;
  padding: 20px;
  border: 2px solid #ccc;
  border-radius: 6px;
  box-sizing: border-box; }

.f-search__head {
  display: flex;
  padding-bottom: 15px;
  border-bottom: 2px solid #20208C; }

.f-search__title {
  width: calc(100% - 170px);
  padding-left: 170px;
  font-size: 20px;
  color: #20208C;
  text-align: center;
  box-sizing: border-box; }

.f-search-tab__text {
  margin-top: 10px;
  margin-bottom: 16px;
  font-size: 12px;
  color: #a0a0a0;
  line-height: 1.5;
  text-align: right; }

.f-search-sort {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 46px;
  margin-bottom: 10px;
  border: 2px solid #20208C;
  border-radius: 6px;
  box-sizing: border-box; }

.f-search-sort_button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50%;
  height: 100%;
  font-weight: bold;
  color: #20208C; }
  .f-search-sort_button + .f-search-sort_button {
    border-left: 2px solid #20208C; }
  .f-search-sort_button.is-active {
    color: #fff;
    background-color: #20208C; }

.f-search-facility--large {
  margin-bottom: 35px; }

.f-search-facility__number {
  display: flex;
  align-items: flex-end;
  margin-bottom: 18px; }

.f-search-facility__number-text {
  margin-right: 20px;
  font-weight: bold; }

.f-search-facility__number--important {
  margin-right: 5px;
  font-weight: bold;
  font-size: 24px;
  color: #cc0d21; }

.f-search-facility__head {
  position: relative;
  height: 260px;
  border-top: 4px solid #20208C;
  text-align: center; }

.f-search-facility__head-inner {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  min-height: 130px;
  padding-left: 12px;
  padding-right: 12px;
  padding-bottom: 15px;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0.8) 100%);
  box-sizing: border-box; }

.f-search-facility__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }

.f-search-facility__picture {
  height: 260px;
  width: 100%;
  object-fit: none; }

.f-search-facility__picture-hotel {
  width: 100%; }

.f-search-facility__title {
  position: absolute;
  bottom: 45px;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.5; }

.f-search-facility__link {
  color: #fff;
  text-decoration: none; }

.f-search-facility__body {
  padding-top: 15px;
  padding-left: 12px;
  padding-right: 12px; }

.f-pr_label {
  margin: 6px 0;
  font-size: 13px; }

.f-pr_icon_01 {
  display: inline-block;
  border: 1px solid #e04c31;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #e04c31;
  font-weight: bold;
  vertical-align: middle; }

.f-pr_icon_01_text {
  display: inline-block;
  list-style: none;
  padding: 6px 9px;
  color: #e04c31;
  vertical-align: middle;
  white-space: pre-wrap;
  max-width: calc(100% - 120px);
  box-sizing: border-box; }

.f-pr_icon_02 {
  display: inline-block;
  border: 1px solid #069ad6;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #069ad6;
  font-weight: bold; }

.f-search-facility__place {
  padding-left: 10px;
  font-size: 12px;
  color: #fff;
  line-height: 1.5;
  text-align: right; }

.f-search-facility__flex {
  display: flex;
  margin-top: 15px; }

.f-search-facility__text {
  font-size: 12px;
  line-height: 1.5; }
  .f-search-facility__text + .f-search-facility__text {
    margin-top: 15px; }

.f-search-facility__text__hidden {
  font-size: 12px;
  line-height: 1.5;
  height: 4.5em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap; }

.f-search-facility__list {
  display: flex;
  flex-wrap: wrap;
  width: calc(100% - 120px);
  margin-left: 10px;
  margin-bottom: 15px;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc; }

.f-search-facility__item {
  width: 100px;
  padding-top: 5px;
  padding-bottom: 5px;
  font-weight: bold;
  font-size: 12px;
  line-height: 1.5; }
  .f-search-facility__item:not(:nth-last-child(2)) {
    border-bottom: 1px dashed #ccc; }

.f-search-facility__description {
  width: calc(100% - 100px);
  padding-top: 5px;
  padding-bottom: 5px;
  font-size: 12px;
  line-height: 1.5; }
  .f-search-facility__description:not(:last-child) {
    border-bottom: 1px dashed #ccc; }

.f-search-review {
  display: flex;
  align-items: center;
  position: absolute;
  bottom: 15px;
  width: calc(100% - 24px);
  box-sizing: border-box; }

.f-search-review__stars {
  font-weight: bold;
  font-size: 12px;
  color: #fff;
  white-space: nowrap; }
  .f-search-review__stars .f-star--small {
    margin-left: 5px; }

.f-search-review__text {
  margin-top: 2px;
  font-size: 12px; }

.f-search-access__wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px; }

.f-search-access {
  width: calc(100% - 60px);
  padding-left: 5.3em;
  padding-right: 10px;
  font-size: 12px;
  line-height: 1.5;
  text-indent: -5.3em;
  box-sizing: border-box; }

.f-search-access__text--strong {
  margin-right: 15px;
  font-weight: bold; }

.f-search-plan {
  margin-top: 20px; }
  .f-search-plan .f-detail-info__item {
    width: 115px; }
  .f-search-plan .f-detail-info__description {
    width: calc(100% - 115px); }

.f-search-plan__head {
  display: flex;
  justify-content: space-between;
  margin-bottom: -5px;
  padding-top: 15px;
  padding-bottom: 5px;
  border-top: 1px solid #dedede; }

.f-search-plan__head--small {
  display: flex;
  justify-content: space-between;
  padding-top: 15px;
  padding-bottom: 5px;
  border-top: 1px solid #dedede; }

.f-search-plan__inner {
  margin-left: 12px;
  margin-right: 12px;
  margin-bottom: 15px; }

.f-search-plan__body {
  border-bottom: 1px solid #dedede; }

.f-search-plan__title {
  display: flex;
  align-items: center;
  height: 20px;
  padding-left: 10px;
  font-weight: bold;
  border-left: 4px solid #20208C;
  box-sizing: border-box; }

.f-search-plan__arrow {
  max-width: 230px;
  margin-top: 3px;
  padding-right: 5px;
  text-align: right;
  box-sizing: border-box; }
  .f-search-plan__arrow .f-detail-arrow__link {
    padding-right: 5px; }

.f-search-plan__link {
  display: block;
  position: relative;
  padding: 15px 12px 15px;
  color: #333;
  text-decoration: none;
  border-top: 1px solid #ccc;
  box-sizing: border-box; }

.f-search-plan__label {
  display: flex;
  margin-top: -6px;
  margin-bottom: 10px; }

.f-search-plan__info {
  display: flex;
  position: relative;
  width: 100%;
  margin-bottom: 10px;
  padding-right: 15px;
  box-sizing: border-box;
  text-decoration: none; }
  .f-search-plan__info::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 5px;
    width: 7px;
    height: 7px;
    border-top: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-search-plan__image--large {
  width: 120px; }

.f-search-plan__image {
  width: 80px; }

.f-search-plan__picture {
  width: 100%; }

.f-search-plan__lead {
  width: calc(100% - 80px);
  margin-top: -3px;
  padding-left: 12px;
  font-weight: bold;
  color: #20208C;
  line-height: 1.5;
  box-sizing: border-box; }

.f-search-plan__flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  margin-bottom: 13px;
  padding-right: 15px;
  padding-bottom: 13px;
  border-bottom: 1px dashed #ededed;
  box-sizing: border-box; }

.f-search-plan__flex-noline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  margin-top: -5px;
  box-sizing: border-box; }

.f-search-plan__flex-label {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 10px;
  box-sizing: border-box; }

.f-search-plan__text--small {
  font-size: 11px;
  font-feature-settings: "plat"; }

.f-search-plan__text--important {
  font-weight: bold;
  font-size: 14px;
  color: #cc0d21; }

.f-search-plan__label--type {
  margin-top: 8px; }
  .f-search-plan__label--type .f-label-type {
    margin-right: 0; }

.f-search-plan__button {
  padding: 20px 12px 40px;
  border-top: 1px solid #ccc; }

.f-search-map__info {
  margin-left: 12px;
  margin-right: 12px;
  margin-bottom: 15px; }

.f-search-map {
  padding-left: 10px;
  padding-right: 10px; }

.f-search-map__list-pointer {
  display: flex;
  justify-content: flex-end;
  padding-top: 15px;
  padding-bottom: 15px; }

.f-search-map__item-pointer {
  position: relative;
  margin-left: 15px;
  padding-left: 15px;
  font-size: 12px;
  list-style: none; }
  .f-search-map__item-pointer::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 10px;
    height: 13px; }
  .f-search-map__item-pointer:first-child::before {
    background: url("../images/icon/ico_pointer02.png") no-repeat 0 0;
    background-size: 10px 13px; }
  .f-search-map__item-pointer:nth-child(2)::before {
    background: url("../images/icon/ico_pointer03.png") no-repeat 0 0;
    background-size: 10px 13px; }
  .f-search-map__item-pointer:nth-child(3)::before {
    background: url("../images/icon/ico_pointer04.png") no-repeat 0 0;
    background-size: 10px 13px; }

.f-search-map__image {
  position: relative;
  width: 100%;
  padding-top: 161%;
  background: url("../images/img_map02.png") no-repeat 0 0;
  background-size: contain;
  box-sizing: border-box; }

.f-search-map__image-inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  max-height: 255px;
  margin: auto; }

.f-search-popup-container {
  cursor: auto;
  height: 0;
  position: absolute;
  /* The max width of the popup window. */
  width: calc(100% - 24px);
  max-width: 370px; }

.f-search-popup-anchor {
  /* Position the div a fixed distance above the tip. */
  position: absolute;
  width: 100%;
  bottom: 17px;
  left: 0; }

.f-search-popup-anchor::before {
  content: "";
  position: absolute;
  bottom: -18px;
  left: 50%;
  width: 0;
  height: 0;
  border-right: 10px solid transparent;
  border-left: 10px solid transparent;
  border-top: 17px solid #000;
  opacity: 0.1;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: 1; }

.f-search-popup-anchor::after {
  content: "";
  position: absolute;
  bottom: -15px;
  left: 50%;
  width: 0;
  height: 0;
  border-right: 8px solid transparent;
  border-left: 8px solid transparent;
  border-top: 15px solid #fff;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: 2; }

.f-search-balloon {
  position: relative;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 12px 12px 24px;
  background-color: #fff;
  border-radius: 6px;
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
  box-sizing: border-box; }

.gm-style .f-search-balloon {
  font-family: 'Noto Sans JP', "Yu Gothic Medium", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-seif;
  font-size: 14px;
  text-decoration: none; }
.gm-style .f-search-balloon__detail-inner a {
  text-decoration: none; }
.gm-style .f-star--medium:before, .gm-style .f-star--medium:after {
  height: auto; }

.f-search-balloon__button-close {
  width: 26px;
  cursor: pointer; }

.f-search-balloon__flex {
  display: flex;
  justify-content: space-between; }

.f-search-balloon__block {
  margin-top: 15px; }

.f-search-balloon__image {
  width: 80px; }

.f-search-balloon__detail {
  display: flex;
  width: calc(100% - 80px);
  padding-left: 10px;
  box-sizing: border-box; }

.f-search-balloon__name {
  margin-top: -5px;
  margin-bottom: 5px;
  font-weight: bold;
  font-size: 16px;
  color: #20208C;
  line-height: 1.4; }

.f-search-balloon__stars {
  font-weight: bold;
  font-size: 12px;
  /* reset google map style */
  line-height: 1.0; }
  .f-search-balloon__stars .f-star--medium {
    margin-left: 15px; }

.f-search-balloon__text {
  margin-top: 13px;
  margin-bottom: 13px;
  padding-left: 5.8em;
  font-size: 12px;
  line-height: 1.3;
  text-indent: -5.8em; }

.f-search-balloon__text--strong {
  margin-right: 20px;
  font-weight: bold; }

.f-search-balloon__list {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 15px;
  margin-bottom: 15px; }

.f-search-balloon__item {
  font-size: 11px;
  max-width: 155px; }

.f-search-balloon__description {
  font-weight: bold;
  font-size: 13px;
  color: #cc0d21; }

.f-search-balloon__picture,
.f-search-map__icon {
  width: 100%; }

.f-search-favorite {
  text-align: center; }

.f-search-favorite__explain {
  margin: 50px 20px 80px;
  padding: 15px;
  border: 2px solid #ccc;
  box-sizing: border-box; }

.f-search-favorite__text--zero {
  padding-top: 20px;
  margin-right: 5px;
  font-weight: bold;
  color: #a0a0a0;
  text-align: right; }

.f-search-favorite__text--strong {
  margin-bottom: 12px;
  font-weight: bold;
  font-size: 16px;
  color: #ff8b17; }

.f-search-favorite__text {
  font-size: 12px;
  line-height: 1.5; }

.f-search-favorite__text--attention {
  color: #cc0d21; }

.f-search-favorite__button {
  margin-top: 10px;
  margin-bottom: 5px; }

.f-search-recommend {
  margin: 15px 12px 35px; }

.f-search-window__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 70px;
  padding-left: 12px;
  padding-right: 12px;
  background-color: #20208C;
  box-sizing: border-box;
  backface-visibility: hidden;
  overflow: hidden;
  z-index: 5; }

.f-search-window__title {
  position: relative;
  padding-left: 23px;
  font-weight: bold;
  font-size: 18px;
  color: #fff; }
  .f-search-window__title::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 17px;
    height: 17px;
    background: url("../images/icon/ico_search02.png") no-repeat 0 0;
    background-size: 15px 15px;
    transform: translateY(-40%); }

.f-search-window__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 38px;
  font-weight: bold;
  font-size: 12px;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 4px; }

.f-search-window__body {
  margin-top: 70px; }
  .f-search-window__body .f-select__wrap,
  .f-search-window__body .f-select {
    min-width: 100%; }
  .f-search-window__body .f-select__wrap-departure {
    min-width: 40%; }
    .f-search-window__body .f-select__wrap-departure .f-select {
      padding-right: 40px; }
  .f-search-window__body input:disabled + span {
    color: #CCCCCC; }
  .f-search-window__body input:disabled + label {
    color: #CCCCCC; }

.f-search-window__label {
  display: block;
  margin-bottom: 10px;
  font-weight: bold; }

.f-search-window__list-term {
  display: flex;
  flex-wrap: wrap;
  padding-bottom: 5px; }

.f-search-window__item-term {
  width: 110px;
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 11px;
  color: #a0a0a0; }

.f-search-window__description-term {
  width: calc(100% - 110px);
  margin-bottom: 10px; }

.f-search-window__list {
  display: flex;
  flex-wrap: wrap; }

.f-search-window__list-departure {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; }

.f-search-window__item {
  width: 86px;
  margin-top: 10px;
  margin-bottom: 10px;
  font-weight: bold; }

.f-search-window__description {
  width: calc(100% - 86px);
  margin-bottom: 10px; }

.f-note__body--dp-search {
  width: 100%;
  text-align: center;
  padding-bottom: 10px; }

.f-search-window__box {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid #dedede; }

.f-search-window__box--small {
  margin-top: 5px;
  padding-top: 15px;
  border-top: 1px solid #dedede; }

.f-search-window__text-term {
  display: inline-block;
  margin-top: 8px;
  margin-left: 10px; }

.f-search-window__background {
  padding: 10px 12px;
  background-color: #ededed;
  border-radius: 6px; }

.f-search-window__text--light {
  margin-top: 15px;
  margin-bottom: 15px;
  color: #a0a0a0; }

.f-search-window__list-area {
  padding: 0px 5px;
  margin-bottom: 10px;
  font-size: 90%;
  line-height: normal; }

.f-search-window__item-area {
  position: relative;
  font-weight: bold;
  list-style: none; }
  .f-search-window__item-area + .f-search-window__item-area {
    padding-left: 20px; }
    .f-search-window__item-area + .f-search-window__item-area::before {
      content: ">";
      position: absolute;
      top: -1px;
      left: 7px;
      width: 5px;
      height: 5px;
      font-weight: bold;
      color: #333; }

.f-search-window__link {
  color: #0065D6;
  text-decoration: none; }

.f-search-window__image,
.f-search-window__picture {
  width: 100%; }

.f-search-window__button-toggle {
  margin-top: 15px;
  text-align: right; }

.f-search-window__text-toggle {
  position: relative;
  padding-left: 20px;
  font-weight: bold;
  color: #0065D6; }
  .f-search-window__text-toggle::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 8px;
    height: 8px;
    border: none;
    border-bottom: 2px solid #333;
    border-right: 2px solid #333;
    transform: rotate(45deg); }
  .f-search-window__text-toggle.is-open::after {
    content: "";
    position: absolute;
    top: 4px;
    left: 0;
    width: 8px;
    height: 8px;
    border: none;
    border-top: 2px solid #333;
    border-left: 2px solid #333;
    transform: rotate(45deg); }

.f-search-window__flex {
  display: flex;
  justify-content: space-between; }

.f-search-window__half {
  width: 47%; }

.f-search-window__half-pax {
  width: 54%; }

.f-search-window__half-room {
  width: 42%; }

.f-search-window__list-choice {
  display: flex;
  flex-wrap: wrap;
  margin-top: 10px;
  border-top: 1px solid #ccc;
  border-left: 1px solid #ccc; }

.f-search-window__item-choice {
  display: flex;
  align-items: center;
  width: 50%;
  padding: 12px 5px 12px 12px;
  list-style: none;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  box-sizing: border-box; }
  .f-search-window__item-choice .f-checkbox__text {
    padding-right: 0; }

.f-search-keywords__head {
  padding-top: 12px;
  padding-bottom: 12px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background-color: #333; }

.f-search-keywords__body {
  padding: 23px 12px 28px; }

.f-search-keywords__flex {
  display: flex; }

.f-search-keywords__radio {
  margin-top: 14px; }
  .f-search-keywords__radio .f-radio__label {
    min-height: 30px; }
    .f-search-keywords__radio .f-radio__label:last-child {
      margin-right: 0; }

.f-search-keywords__radio-dp {
  margin-top: 14px; }
  .f-search-keywords__radio-dp .f-radio__label {
    min-height: 30px;
    padding: 3px 5px 3px 47px; }
  .f-search-keywords__radio-dp .f-radio__label:first-of-type {
    margin-right: 62px; }
  .f-search-keywords__radio-dp .f-radio__label:last-of-type {
    margin-left: 20px; }

.f-search-requirement__head {
  position: relative;
  padding: 15px 12px;
  font-weight: bold;
  font-size: 15px;
  color: #20208C;
  text-align: left;
  background-color: #eff5ff;
  border-top: 1px solid #c5cede;
  border-bottom: 1px solid #c5cede; }
  .f-search-requirement__head::after {
    content: "";
    position: absolute;
    top: 45%;
    right: 22px;
    width: 8px;
    height: 8px;
    border: none;
    border-bottom: 2px solid #20208C;
    border-right: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }
  .f-search-requirement__head.is-open::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 22px;
    width: 8px;
    height: 8px;
    border: none;
    border-top: 2px solid #20208C;
    border-left: 2px solid #20208C;
    transform: rotate(45deg) translateY(-50%); }

.f-search-requirement__body {
  margin: 20px 12px; }

.f-search-requirement__body-short {
  margin: 20px 12px 10px; }

.f-search-requirement__box + .f-search-requirement__box {
  margin-top: 20px; }

.f-search-requirement__label {
  display: flex;
  font-weight: bold;
  color: #20208C; }
  .f-search-requirement__label .f-button-hint {
    position: relative;
    top: -3px; }

.f-search-special {
  margin-bottom: 30px; }

.f-search-special__image {
  width: 100%;
  margin-bottom: 15px; }

.f-search-special__picture {
  width: 100%; }

.f-search-special__text {
  font-size: 12px;
  line-height: 1.5; }
  .f-search-special__text + .f-search-special__text {
    margin-top: 15px; }

.f-search-special__link {
  margin-top: 20px; }

.f-search-none {
  margin-left: 12px;
  margin-right: 12px;
  margin-bottom: 20px;
  padding: 26px 12px;
  text-align: center;
  border: 1px solid #20208C; }

.f-search-none__icon {
  width: 40px;
  margin-bottom: 23px; }

.f-search-none__text--large {
  margin-bottom: 20px;
  font-weight: bold;
  font-size: 16px;
  color: #20208C; }

.f-search-none__text {
  font-size: 12px;
  line-height: 1.5; }

.f-search-map__overlay {
  position: relative; }
  .f-search-map__overlay::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5); }

.f-search-map__attention__wrap {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  height: 140px;
  margin: auto; }

.f-search-map__attention {
  position: relative;
  width: 280px;
  height: 140px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 28px;
  text-align: center;
  background-color: #fff;
  border-radius: 6px;
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
  box-sizing: border-box;
  z-index: 5; }

.f-search-info__body {
  padding: 15px 10px 45px; }

.f-search-info__carousel {
  width: 375px; }

.f-search-info__inner {
  width: 540px; }

.f-search-info__label {
  margin-top: 10px;
  margin-left: 10px;
  margin-right: 10px; }

.f-search-info__list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  line-height: 1.2;
  border-top: 1px solid #dedede; }

.f-search-info__item {
  width: 143px;
  padding-top: 8px;
  padding-bottom: 8px;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-search-info__description {
  width: calc(100% - 143px);
  padding-top: 8px;
  padding-right: 10px;
  padding-bottom: 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-search-info__item--long {
  width: 230px;
  padding-top: 8px;
  padding-left: 20px;
  padding-bottom: 8px;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-search-info__description--short {
  width: calc(100% - 230px);
  padding-top: 8px;
  padding-right: 20px;
  padding-bottom: 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-search-info__flex {
  display: flex;
  justify-content: space-between; }

.f-search-info__lead {
  margin-bottom: 20px;
  border-bottom: 1px dashed #dedede; }
  .f-search-info__lead .f-accordion-more__button {
    margin-top: 20px; }

.f-search-info__text {
  line-height: 1.5;
  padding-bottom: 20px; }
  .f-search-info__text + .f-search-info__text {
    margin-top: 20px; }

.f-search-info__banner {
  width: 60px;
  margin-right: 8px; }

.f-search-info__banner-image {
  width: 100%; }

.f-search-info__link {
  display: block;
  margin: 23px 12px;
  text-align: right;
  text-decoration: none; }

.f-search-info__icon {
  position: relative;
  top: 2px;
  width: 13px;
  margin-right: 2px; }

.f-search-info__button {
  margin-top: 20px;
  margin-left: 12px;
  margin-right: 12px;
  margin-bottom: 30px; }

.f-search-room__list {
  display: flex;
  flex-wrap: wrap;
  width: 250px; }

.f-search-room__item {
  width: 170px;
  line-height: 1.5; }

.f-search-room__description {
  width: 80px;
  line-height: 1.5;
  text-align: right; }

.f-search-detail__head {
  padding: 15px 12px;
  background-color: #ededed;
  border-top: 4px solid #20208C;
  box-sizing: border-box; }

.f-search-detail__title {
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: bold;
  color: #000;
  line-height: 1.5; }

.f-search-detail__banner {
  width: 86px;
  display: flex;
  align-items: center;
  margin-left: 5px; }
  .f-search-detail__banner .f-button-hint {
    margin-top: 4px; }

.f-search-detail__image {
  width: 56px; }

.f-search-detail__code {
  font-size: 12px;
  line-height: 1.3; }

.f-search-detail__label {
  margin-right: 30px; }
  .f-search-detail__label .f-label-type {
    margin-right: 0; }

.f-search-detail__text-small {
  margin-top: 7px;
  font-size: 11px;
  line-height: 1.5; }

@media screen and (max-width: 320px) {
  .f-search-review__stars {
    font-size: 10px; }

  .f-search-plan__flex {
    padding-right: 0; }

  .f-search-facility__place {
    font-size: 10px; }

  .f-search-plan__text--small {
    font-size: 10px; }

  .f-search-plan__text--important {
    font-size: 12px; }

  .f-search-balloon__stars .f-star--small {
    margin-top: 5px;
    margin-left: 0; }

  .f-search-balloon__list {
    display: block; }

  .f-search-balloon__item {
    margin-bottom: 8px; }

  .f-search-window__item-term {
    width: 90px;
    margin-top: 10px;
    margin-bottom: 10px;
    font-size: 11px;
    color: #a0a0a0; }

  .f-search-window__description-term {
    width: calc(100% - 90px);
    margin-bottom: 10px; }

  .f-search-selected__item,
  .f-search-selected__description {
    font-size: 11px; } }
.f-search__shisetsu-list {
  text-align: center; }

.f-search__loading-image {
  margin-top: 30px; }

.f-search__map-overlay {
  background-color: #000000; }

.f-search__map-loading {
  opacity: 0.7; }

.f-search__map-loading-image {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  z-index: 10; }

/*--------------------------------
2.25 pagination
--------------------------------*/
.f-pagination {
  display: flex;
  align-items: center;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc; }

.f-pagination__list {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-grow: 1;
  padding-left: 3px;
  padding-right: 3px; }

.f-pagination__item {
  width: 26px;
  height: 26px;
  margin-left: 2px;
  margin-right: 2px;
  padding-top: 5px;
  font-family: Helvetica, sans-serif;
  font-size: 13px;
  text-align: center;
  list-style: none;
  border: 1px solid transparent;
  border-radius: 4px;
  box-sizing: border-box; }
  .f-pagination__item.is-current {
    color: #20208C;
    background-color: #ededed;
    pointer-events: none; }

.f-pagination__link {
  color: #333;
  text-decoration: none; }

.f-pagination__between {
  width: 26px;
  height: 26px;
  margin-left: 3px;
  margin-right: 3px;
  font-family: Helvetica, sans-serif;
  font-size: 13px;
  text-align: center;
  list-style: none; }

.f-pagination__prev {
  position: relative;
  width: 60px;
  height: 60px;
  list-style: none;
  border-right: 1px solid #ccc;
  box-sizing: border-box;
  transition: opacity 0.1s ease-out;
  cursor: pointer; }
  .f-pagination__prev::after {
    content: "";
    position: absolute;
    top: 48%;
    left: 50%;
    width: 9px;
    height: 9px;
    border-bottom: 3px solid #20208C;
    border-left: 3px solid #20208C;
    transform: rotate(45deg) translate(-50%); }
  .f-pagination__prev:hover {
    opacity: 0.6; }

.f-pagination__next {
  position: relative;
  width: 60px;
  height: 60px;
  list-style: none;
  border-left: 1px solid #ccc;
  box-sizing: border-box; }
  .f-pagination__next::after {
    content: "";
    position: absolute;
    top: 48%;
    left: 45%;
    width: 9px;
    height: 9px;
    border-top: 3px solid #20208C;
    border-right: 3px solid #20208C;
    transform: rotate(45deg) translate(-50%); }
  .f-pagination__next:hover {
    opacity: 0.6; }

/*--------------------------------
2.26 feature
--------------------------------*/
.f-feature__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 48px;
  padding-left: 10px;
  padding-right: 10px;
  box-sizing: border-box;
  cursor: pointer; }

.f-feature__body {
  margin: 20px 10px 20px; }

.f-feature__body--large {
  margin: 20px 10px 30px; }

.f-feature__image {
  margin-bottom: 30px; }

.f-feature__picture {
  width: 100%; }

.f-feature__list {
  margin-top: -5px;
  margin-bottom: 15px; }

.f-feature__text {
  font-size: 13px;
  line-height: 1.5; }

.f-feature-price__list {
  display: flex;
  flex-wrap: wrap;
  margin-top: 8px;
  margin-bottom: 10px; }

.f-feature-price__item {
  margin-top: 2px;
  margin-right: 10px;
  line-height: 1.5;
  white-space: nowrap; }

.f-feature-price__description {
  font-weight: bold;
  font-size: 16px;
  line-height: 1.5; }

.f-feature__select {
  display: flex;
  margin: 20px 12px; }

.f-feature__select-inner {
  display: flex;
  align-items: center;
  justify-content: space-between; }
  .f-feature__select-inner + .f-feature__select-inner {
    margin-left: 10%; }

.f-feature__label {
  width: 44px;
  font-weight: bold;
  font-size: 13px; }

.f-feature__box {
  margin-bottom: 20px; }

.f-feature__box-line {
  padding-bottom: 20px;
  border-bottom: 1px solid #ededed; }

.f-feature-section__list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 5px; }

.f-feature-section__item {
  width: 120px;
  font-weight: bold;
  line-height: 1.5; }

.f-feature-section__description {
  width: calc(100% - 120px);
  line-height: 1.5; }

.f-feature-section__text {
  margin-right: 8px;
  font-weight: bold; }

.f-feature__cell {
  width: 80px;
  padding-top: 14px;
  padding-bottom: 14px;
  line-height: 1.3;
  text-align: center;
  vertical-align: middle;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-feature__cell:last-child {
    border-right: none; }

.f-feature-info__item {
  display: flex;
  align-items: center;
  width: 110px;
  padding: 5px 8px;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.5;
  background-color: #ededed;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

@media screen and (max-width: 320px) {
  .f-feature-price__list {
    display: block; } }
/*--------------------------------
2.27 attention
--------------------------------*/
.f-attention {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 35px;
  margin-bottom: 15px;
  padding-left: 10px;
  padding-right: 10px;
  font-weight: bold;
  font-size: 16px;
  color: #fff;
  background-color: #20208C;
  box-sizing: border-box; }

/*------------------
2.28 recommend
new_osusumeplan_recomend 20200116 from NTA
-------------------*/
#rt_jr_search_plan .f-card__link,
#rt_jr_details_plan .f-card__link {
  width: 100%;
  clear: both;
  box-sizing: border-box;
  padding: 10px;
  display: flex;
  color: #333;
  text-decoration: none;
  border-bottom: 1px solid #ccc; }
  #rt_jr_search_plan .f-card__link:hover,
  #rt_jr_details_plan .f-card__link:hover {
    opacity: 0.5; }

p.side_tool_list_photo a img {
  width: 100px;
  height: auto; }

div.side_tool_list_info {
  width: 100%;
  padding-top: 10px;
  margin-left: 24px; }

div.side_tool_list_info div.side_tool_list_info_in {
  font-size: 11px;
  margin-bottom: 12px;
  height: 60px; }

div.side_tool_list_info div.side_tool_list_info_in p.title {
  margin-bottom: 2%; }

div.side_tool_list_info div.side_tool_list_info_in p.title a,
div.side_tool_list_info div.side_tool_list_info_in p.text {
  line-height: 1.3;
  color: #20208c;
  font-weight: bold;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
  height: 57px; }

div.side_tool_list_info div.side_tool_list_info_in p.text {
  margin: -40px 0 0; }

div.side_tool_list_info p.price {
  text-align: right; }

div.side_tool_list_info p.price span {
  font-weight: bold;
  color: #cc0d21; }

/*new_osusumeplan_recomend 20200116 from NTA*/
/*--------------------------------
2.29 information	緊急文言、年末年始文言など
--------------------------------*/
#attention_message {
  border: 2px solid red;
  margin: 3px 0;
  padding: 6px;
  color: red;
  font-size: 13px; }

#attention_message span {
  font-weight: bold; }

/*-----------------------------
2.30 map	地図
----------------------------*/
#Map, #NTA_JR2_Map {
  position: relative;
  overflow: hidden;
  max-width: 100%;
  width: 300px;
  height: 211px;
  margin: 0 auto;
  padding: 0; }
  #Map div.mapText div.box, #NTA_JR2_Map div.mapText div.box {
    position: absolute;
    cursor: pointer;
    color: #333;
    border: 1px solid #229DE7;
    background-color: white;
    font-size: 10px;
    padding: 0px 3px 2px 3px;
    z-index: 2; }
  #Map div.mapText div.sel, #NTA_JR2_Map div.mapText div.sel {
    color: red;
    border: 2px solid red; }
  #Map div.mapText div.over, #NTA_JR2_Map div.mapText div.over {
    color: red; }
  #Map div.mapText div.na, #NTA_JR2_Map div.mapText div.na {
    cursor: default;
    color: #999;
    background-color: #EEE;
    border: 1px solid transparent; }
  #Map div.mapLayer img, #NTA_JR2_Map div.mapLayer img {
    position: absolute;
    z-index: -1;
    top: 0px;
    left: 0px; }

/*------------------
2.31 hotel	施設の説明
-------------------*/
.hotelDetailBody {
  padding-top: 10px;
  margin-bottom: 10px;
  margin-right: 5px;
  margin-left: 5px; }

.hotelDetailBody .detail {
  width: 450px;
  float: left; }

.hotelDetailBody .detail .catch {
  font-size: 125%;
  font-weight: bold;
  color: #000000;
  margin-bottom: 10px; }

.hotelDetailBody .detail .lead {
  margin-bottom: 15px;
  line-height: 1.5; }

.hotelDetailBody .photos {
  width: 240px; }

.hotelDetailBody .photos .photo {
  margin-bottom: 7px; }

table.detailTable {
  border: 1px solid #CCCCCC;
  margin-bottom: 10px;
  width: 100%; }

table.detailTable th {
  background: #efeeff;
  font-weight: normal;
  text-align: left;
  padding: 3px;
  border: 1px solid #CCCCCC;
  white-space: nowrap; }

table.detailTable td {
  font-weight: normal;
  text-align: left;
  padding: 2px;
  border: 1px solid #CCCCCC;
  vertical-align: top; }

table.detailTable .total {
  font-weight: bold;
  background: #FFFFCC; }

table.detailTable2 {
  border: 1px solid #CCCCCC;
  margin-bottom: 15px; }

table.detailTable2 th {
  background: #efeeff;
  font-weight: normal;
  text-align: center;
  padding: 3px;
  border: 1px solid #CCCCCC;
  line-height: 1.4; }

table.detailTable2 th.col1 {
  background: #eeedf7; }

table.detailTable2 td {
  font-weight: normal;
  text-align: center;
  padding: 3px 10px;
  border: 1px solid #CCCCCC;
  line-height: 1.4; }

table.detailTable2 td.left {
  text-align: left; }

ul.hotelPhotoList {
  text-align: center; }

ul.hotelPhotoList li {
  display: inline;
  margin: 0px 10px; }

/*--------------------------------
2.32 popup 20200303 from NTA
--------------------------------*/
#rt_search_sp_popup {
  width: 90% !important; }
  #rt_search_sp_popup .pagejack_sp img {
    width: 100% !important; }

/*20200303 add popup from NTA*/

/*# sourceMappingURL=dp-jr_commonm.css.map */
