@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 confirm
			2.18 plan
			2.19 carousel
			2.20 tooltip
			2.21 modal
			2.22 card
			2.23 search
			2.24 star
			2.25 pagination
			2.26 feature
			2.27 attention
			2.28 slick
			2.29 recommend
			2.30 information
			2.31 map
			2.32 hotel
*/
/*--------------------------------

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;
  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::-ms-clear {
  visibility: hidden; }

input::-ms-reveal {
  visibility: hidden; }

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

button:focus {
  outline: none; }

a:visited,
a:focus {
  outline: none; }

select::-ms-value {
  background: none;
  color: #333; }

body {
  min-width: 1010px;
  font-family: 'Noto Sans JP', "Yu Gothic Medium", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-seif;
  font-size: 14px;
  color: #333;
  line-height: 1;
  letter-spacing: 0.01rem;
  -webkit-font-smoothing: antialiased; }

html.is-fixed {
  height: 100%; }

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

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

1. layout

--------------------------------*/
/*--------------------------------
1.1 header
--------------------------------*/
.f-header {
  width: 100%;
  border-top: 5px solid #20208c; }

.f-header-top {
  height: 100px;
  display: flex;
  align-items: center;
  width: 1010px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box; }

.f-header__logo {
  width: 235px;
  padding-bottom: 5px; }

.f-header__label {
  width: 157px;
  margin-left: 42px; }

.f-header__inner {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-grow: 1; }

.f-header__item {
  display: inline;
  margin-left: 20px;
  list-style: none;
  line-height: 10px;
  font-size: 11px; }

.f-header__link {
  display: inline-block;
  padding-bottom: 5px;
  font-size: 11px;
  color: #333;
  text-decoration: none;
  transition: opacity 0.2s ease-out; }
  .f-header__link:hover {
    opacity: 0.5; }

.f-header__button {
  margin-left: 25px; }

.f-header-middle {
  display: flex;
  justify-content: space-between;
  margin-top: -5px;
  width: 1010px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box; }

.f-header-middle__domestic {
  width: 534px; }

.f-header-middle__domestic-category {
  margin-bottom: 15px;
  padding-bottom: 5px;
  font-weight: bold;
  font-size: 12px;
  color: #dd335d;
  border-bottom: 2px solid #dd335d; }

.f-header-middle__overseas {
  width: 406px;
  margin-left: 30px; }

.f-header-middle__overseas-category {
  margin-bottom: 15px;
  padding-bottom: 5px;
  font-weight: bold;
  font-size: 12px;
  color: #4eab26;
  border-bottom: 2px solid #4eab26; }

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

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

.f-header-middle__link {
  display: inline-block;
  padding-bottom: 15px;
  font-weight: bold;
  font-size: 13px;
  color: #333;
  text-decoration: none; }
  .f-header-middle__link.is-current {
    border-bottom: 3px solid #20208c; }
  .f-header-middle__link:hover {
    border-bottom: 3px solid #20208c; }

.f-header-bottom {
  width: 100%;
  background-color: #ededed; }

.f-header-bottom__inner {
  display: flex;
  align-items: center;
  justify-content: space-between; }

.f-header__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 40px;
  width: 1010px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box; }

.f-header__text {
  margin-left: 10px;
  font-size: 14px;
  font-weight: bold; }

.f-header-utitlity__item {
  display: inline-block;
  margin-left: 25px;
  padding-left: 18px;
  padding-bottom: 2px;
  list-style: none; }
  .f-header-utitlity__item:first-child {
    background: url("../images/icon/ico_help01.png") no-repeat 0 2px;
    background-size: 10px 14px; }
  .f-header-utitlity__item:last-child {
    background: url("../images/icon/ico_question01.png") no-repeat 0 2px;
    background-size: 14px 14px; }

.f-header-utitlity__link {
  font-size: 12px;
  color: #0065d6;
  text-decoration: none;
  transition: opacity 0.2s ease-out; }
  .f-header-utitlity__link:hover {
    opacity: 0.5; }

.f-header-attention {
  width: 168px;
  height: 40px;
  margin-left: 30px;
  padding: 14px 15px 13px 18px;
  font-size: 12px;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  background-color: #cc0d21;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out; }
  .f-header-attention:hover {
    opacity: 0.6; }

.f-header-attention__icon {
  position: relative;
  top: -1px;
  width: 14px;
  margin-right: 5px; }

/*--------------------------------
1.2 footer
--------------------------------*/
.f-footer__container {
  width: 1010px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box; }

.f-footer-pagetop {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 56px;
  height: 32px;
  background-color: #ccc;
  border-radius: 4px;
  transition: all 0.2s ease-out;
  z-index: 100; }
  .f-footer-pagetop::before {
    content: "";
    position: absolute;
    top: 14px;
    left: 23px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(-45deg); }
  .f-footer-pagetop.is-show {
    display: block; }
  .f-footer-pagetop:hover {
    opacity: 0.6; }

.f-footer-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 134px;
  padding-left: 10px;
  padding-right: 10px;
  border-top: 1px solid #dedede; }

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

.f-footer-top__link {
  position: relative;
  width: 134px;
  height: 28px;
  padding-top: 7px;
  padding-left: 18px;
  font-size: 12px;
  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: "";
    width: 5px;
    height: 5px;
    position: absolute;
    top: 12px;
    right: 17px;
    border-top: 2px solid #333;
    border-left: 2px solid #333;
    transform: rotate(45deg); }
  .f-footer-top__link:hover {
    opacity: 0.5; }

.f-footer-middle {
  width: 100%;
  padding-top: 43px;
  padding-bottom: 43px;
  background-color: #ededed;
  border-top: 1px solid #dedede; }

.f-footer-middle__list {
  text-align: center; }
  .f-footer-middle__list + .f-footer-middle__list {
    margin-top: 30px; }

.f-footer-middle__item {
  display: inline-block;
  padding-left: 10px;
  padding-right: 16px;
  list-style: none;
  line-height: 12px;
  position: relative; }
  .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: 12px;
  text-decoration: none;
  color: #333;
  transition: opacity 0.2s ease-out; }
  .f-footer-middle__link:hover {
    opacity: 0.5; }

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

.f-footer-bottom__container {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  width: 1010px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box; }

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

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

2. module

--------------------------------*/
/*--------------------------------
2.1 container
--------------------------------*/
.f-container {
  width: 1010px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box;
  padding-top: 30px;
  padding-bottom: 60px; }

.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-button {
  width: 100%;
  border: 1px solid #ccc;
  box-sizing: border-box; }

.f-accordion-button__head {
  display: flex;
  align-items: center;
  height: 46px;
  padding-left: 12px;
  padding-right: 12px;
  cursor: pointer; }

.f-accordion-button__title {
  width: calc(100% - 25px);
  font-size: 13px;
  font-weight: bold; }

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

.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;
  cursor: pointer; }

.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; }

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

.f-tab__item {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  width: 470px;
  height: 60px;
  padding-top: 1px;
  font-weight: bold;
  font-size: 16px;
  border-top: 1px solid #dedede;
  box-sizing: border-box;
  cursor: pointer; }

.f-tab__item.is-active {
  position: relative;
  padding-top: 0;
  color: #20208c;
  border-top: 2px solid #20208c;
  border-left: 1px solid #dedede;
  border-right: 1px solid #dedede; }
  .f-tab__item.is-active::before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #fff; }
  .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__menu-bottom {
  display: flex;
  justify-content: space-between;
  margin-bottom: 70px;
  padding-left: 10px;
  padding-right: 10px;
  border-top: 1px solid #dedede; }

.f-tab__item-bottom {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  width: 470px;
  height: 60px;
  padding-bottom: 1px;
  font-weight: bold;
  font-size: 16px;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box;
  cursor: pointer; }

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

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

.f-tab__icon-facility-plan {
  position: relative;
  padding-left: 22px;
  font-weight: bold; }
  .f-tab__icon-facility-plan::before {
    content: "";
    position: absolute;
    top: 2px;
    left: 0;
    width: 17px;
    height: 14px;
    background: url("../images/icon/ico_facility01.png") no-repeat 0 0;
    background-size: 17px 14px; }

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

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

.f-tab__menu--large {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #dedede; }

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

.f-tab__item--large.is-active {
  position: relative;
  color: #20208c;
  border-top: 1px solid #20208c;
  border-left: 1px solid #dedede;
  border-right: 1px solid #dedede; }
  .f-tab__item--large.is-active::before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #fff; }
  .f-tab__item--large.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--large.is-active > .f-tab__item-inner {
    margin-top: -1px; }
    .f-tab__item--large.is-active > .f-tab__item-inner > .f-tab__icon {
      margin-top: 0; }

.f-tab__menu--small {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #dedede; }

.f-tab__menu--rate {
  display: flex;
  justify-content: space-between;
  margin: 7px 8px 6px 8px; }

.f-tab__item--small {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  margin-left: 10px;
  width: 100%;
  height: 53px;
  font-weight: bold;
  border-top: 1px solid #dedede;
  box-sizing: border-box;
  cursor: pointer; }

.f-tab__item--small:first-child {
  margin-left: 0px; }

.f-tab__item--small.is-active {
  position: relative;
  color: #20208c;
  border-top: 1px solid #20208c;
  border-left: 1px solid #dedede;
  border-right: 1px solid #dedede; }
  .f-tab__item--small.is-active::before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #fff; }
  .f-tab__item--small.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--small.is-active > .f-tab__item-inner {
    margin-top: -1px; }
    .f-tab__item--small.is-active > .f-tab__item-inner > .f-tab__icon {
      margin-top: 0; }

.f-tab__item-inner {
  font-weight: bold;
  text-align: center;
  line-height: 1.1; }

.f-tab__item--rate:first-child {
  margin-left: 0px; }

.f-tab__item--rate {
  display: flex;
  align-items: center;
  /* justify-content: center; */
  padding-left: 18px;
  flex-wrap: wrap;
  position: relative;
  width: 100%;
  height: 53px;
  font-weight: bold;
  border: 1px solid #dedede;
  cursor: pointer;
  margin-left: 10px; }

.f-tab__icon {
  width: 14px;
  margin-right: 6px; }

.f-tab__text--small {
  font-size: 11px;
  font-weight: normal; }

.f-tab__content {
  display: none;
  padding-top: 30px;
  padding-bottom: 70px; }

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

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

.f-tab-three__menu {
  display: flex; }

.f-tab-three__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 33.333%;
  height: 46px;
  color: #20208c;
  border-top: 1px solid #20208c;
  border-bottom: 1px solid #20208c;
  box-sizing: border-box;
  cursor: pointer; }
  .f-tab-three__item + .f-tab-three__item {
    border-left: 1px 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-top: 5px;
  padding-left: 1px;
  font-size: 15px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background-color: #20208c;
  border-radius: 26px;
  box-sizing: border-box; }

_:-ms-input-placeholder, :root, .f-tab-tree__icon {
  padding-top: 7px; }

.f-tab-favorite {
  margin-left: 10px;
  margin-right: 10px;
  margin-bottom: 45px; }

.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: 185px;
  height: 46px;
  margin-right: 6px;
  font-weight: bold;
  color: #a0a0a0;
  background-color: #ededed;
  box-sizing: border-box;
  cursor: pointer; }

.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 12px;
  background-color: #fff9f0; }

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

.f-tab-favorite__inner {
  padding: 20px 12px;
  background-color: #fff; }

/*--------------------------------
2.4 label
--------------------------------*/
.f-label-type {
  display: inline-block;
  margin-top: 10px;
  margin-right: 2px;
  padding: 6px 9px;
  font-size: 12px;
  font-weight: bold;
  color: #fff;
  list-style: none;
  background-color: #a0a0a0; }

.f-label-type--line {
  display: inline-block;
  margin-top: 10px;
  margin-right: 2px;
  padding: 6px 9px;
  font-size: 12px;
  font-weight: bold;
  color: #ccc;
  list-style: none;
  background-color: #fff;
  border: 1px dotted #ccc;
  box-sizing: border-box; }

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

.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: 5px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  background-color: #20208c;
  box-sizing: border-box; }

.f-label-left {
  display: inline-block;
  margin-top: 6px;
  margin-right: 5px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: bold;
  color: #e61b61;
  text-decoration: none;
  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__row-head {
  background-color: #ededed; }

.f-table__head {
  height: 40px;
  padding-left: 3px;
  padding-right: 3px;
  font-size: 12px;
  font-feature-settings: "palt";
  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-sort {
  height: 50px;
  font-size: 12px;
  font-feature-settings: "palt";
  line-height: 1.3;
  vertical-align: middle;
  background-color: #ededed;
  background-clip: padding-box;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-table__head-sort:last-child {
    border-right: none; }

.f-table__head-text {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 32px; }

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

.f-table__data {
  padding: 10px 10px;
  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__row-body.is-checked {
  background-color: #ffeaf1; }

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

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

.f-table-train__cell--exsmall {
  width: 63px;
  font-weight: bold;
  text-align: center;
  white-space: nowrap; }

.f-table-train__cell--small {
  width: 76px;
  font-size: 12px;
  font-weight: bold;
  text-align: center;
  white-space: nowrap; }

.f-table-train__cell--medium {
  width: 82px;
  font-weight: bold;
  color: #cc0d21;
  text-align: right;
  white-space: nowrap; }

.f-table-train__cell--large {
  width: 98px;
  text-align: right; }

.f-table__button-bottom {
  position: relative; }

.f-table__button-flex {
  display: flex;
  width: 100%; }

.f-table_button-sort {
  position: relative;
  width: 50%;
  height: 18px;
  border-top: 1px solid #dedede;
  background-color: #f5f5f5;
  cursor: pointer; }
  .f-table_button-sort:first-child {
    border-right: 1px solid #dedede; }
    .f-table_button-sort:first-child::after {
      content: "";
      position: absolute;
      top: 8px;
      left: 50%;
      width: 0;
      height: 0;
      border: 4px solid transparent;
      border-top: 4px solid #20208c;
      transform: translateX(-50%); }
  .f-table_button-sort:last-child::after {
    content: "";
    position: absolute;
    top: 4px;
    left: 50%;
    width: 0;
    height: 0;
    border: 4px solid transparent;
    border-bottom: 4px solid #20208c;
    transform: translateX(-50%); }

.f-table-calendar {
  width: 100%;
  border: 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;
  background-clip: padding-box; }

.f-table-calendar__head,
.f-table-calendar__data {
  position: relative;
  width: 14.28%;
  height: auto;
  font-size: 12px;
  box-sizing: border-box;
  color: grey; }
  .f-table-calendar__head.f-table-calendar__selectable,
  .f-table-calendar__data.f-table-calendar__selectable {
    cursor: pointer;
    color: black; }
    .f-table-calendar__head.f-table-calendar__selectable:first-child,
    .f-table-calendar__data.f-table-calendar__selectable:first-child {
      font-weight: bold;
      color: #cc0d21; }
    .f-table-calendar__head.f-table-calendar__selectable:last-child,
    .f-table-calendar__data.f-table-calendar__selectable: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.f-table-calendar__data-holiday,
  .f-table-calendar__data.f-table-calendar__data-holiday {
    font-weight: bold;
    color: #cc0d21; }
  .f-table-calendar__head.f-table-calendar__day-today,
  .f-table-calendar__data.f-table-calendar__day-today {
    background-color: #fff9f0; }
  .f-table-calendar__head.f-table-calendar__day-select,
  .f-table-calendar__data.f-table-calendar__day-select {
    color: #e61b61;
    background-color: #ffeaf1; }
  .f-table-calendar__head.f-table-calendar__out-of-range,
  .f-table-calendar__data.f-table-calendar__out-of-range {
    color: darkgray;
    cursor: text; }

.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;
  cursor: text; }

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

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

.f-input-calendar__wrap {
  display: flex;
  position: relative;
  width: 210px; }
  .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__wrap--short {
  position: relative;
  width: 200px; }
  .f-input-calendar__wrap--short + .f-input-calendar__wrap {
    position: relative;
    margin-top: 25px; }
    .f-input-calendar__wrap--short + .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: 30px;
  padding-right: 30px;
  padding-left: 10px;
  line-height: normal;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: none;
  box-sizing: border-box;
  appearance: none; }

.f-input-calendar--short {
  position: relative;
  width: 200px;
  height: 30px;
  padding-right: 30px;
  padding-left: 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: 30px;
  padding-right: 30px;
  padding-left: 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::-moz-placeholder {
  font-weight: bold;
  color: #cc0d21;
  opacity: 1; }

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

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

.f-input-calendar__button {
  position: absolute;
  top: 7px;
  right: 10px;
  width: 16px; }
  .f-input-calendar__button::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    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__wrap .f-input-calendar__button {
  position: absolute;
  top: 7px;
  right: -65px;
  width: 16px;
  cursor: pointer; }

.f-search__descirption .f-input-calendar__button {
  position: absolute;
  top: 7px;
  right: -80px;
  width: 16px;
  cursor: pointer; }

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

.f-input-calendar__body__search {
  position: absolute;
  top: 42px;
  left: 62px;
  width: 420px;
  height: 291px;
  padding: 12px;
  background-color: #fff;
  border: 1px solid #20208c;
  box-sizing: border-box;
  z-index: 1; }
  .f-input-calendar__body__search::before {
    content: "";
    position: absolute;
    top: -13px;
    right: 202px;
    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__search::after {
    content: "";
    position: absolute;
    top: -11px;
    right: 202px;
    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__body__hotel {
  position: absolute;
  top: 42px;
  left: 57px;
  width: 420px;
  height: 271px;
  padding: 12px;
  background-color: #fff;
  border: 1px solid #20208c;
  box-sizing: border-box;
  z-index: 1; }
  .f-input-calendar__body__hotel::before {
    content: "";
    position: absolute;
    top: -13px;
    right: 202px;
    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__hotel::after {
    content: "";
    position: absolute;
    top: -11px;
    right: 202px;
    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-top: 5px;
  margin-bottom: 20px;
  font-size: 13px; }

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

.f-input-calendar__current {
  vertical-align: middle;
  flex-grow: 1;
  font-weight: bold;
  color: #000;
  text-align: center; }
  .f-input-calendar__current span {
    display: inline-block;
    width: 35px;
    font-weight: bold; }
    .f-input-calendar__current span a {
      text-decoration: none;
      color: #0065d6; }

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

.f-calendar-month {
  border: 1px solid #a0a0a0;
  border-collapse: collapse; }

.f-calenderBox-left {
  float: left;
  width: 47%;
  margin-left: 5px; }

.f-calenderBox-right {
  float: right;
  width: 47%;
  margin-right: 5px; }

.f-calenderBox {
  width: 47%;
  margin-left: 5px;
  float: left; }

.f-calenderBox + .f-calenderBox {
  margin-left: 16px; }

.f-calendar-disp-month {
  font-weight: bold;
  color: #000;
  text-align: center;
  margin-bottom: 15px; }

.f-input-search__wrap {
  position: relative;
  width: 380px;
  height: 50px;
  padding-left: 12px;
  padding-bottom: 2px;
  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: 320px;
  height: 48px;
  vertical-align: middle;
  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); }

/* プラン詳細画面 */
#goingDateSelect option:disabled,
#returnDateSelect option:disabled {
  color: lightgray; }

/*--------------------------------
2.7 radio
--------------------------------*/
.f-radio__wrap {
  display: block; }
  .f-radio__wrap + .f-radio__wrap {
    margin-top: 7px; }

.f-radio {
  display: none; }

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

.f-radio + .f-radio__label::before {
  content: "";
  display: block;
  position: absolute;
  top: 48%;
  left: 0;
  width: 22px;
  height: 22px;
  background-color: #fff;
  border: 1px 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: 48%;
  left: 6px;
  width: 10px;
  height: 10px;
  background-color: #e61b61;
  border-radius: 50%;
  transform: translateY(-50%); }

_:-ms-input-placeholder, :root, .f-radio + .f-radio__label {
  min-height: auto;
  padding-top: 5px;
  padding-bottom: 5px; }

/* ラジオボタン範囲調整 */
#JrDepStaSelect .f-table__data,
#JrArrStaSelect .f-table__data {
  padding: 0; }
  #JrDepStaSelect .f-table__data.f-table-train__cell--large,
  #JrArrStaSelect .f-table__data.f-table-train__cell--large {
    padding: 10px 10px; }

#JrDepStaSelect .f-radio + .f-radio__label,
#JrArrStaSelect .f-radio + .f-radio__label {
  padding: 10px 10px 10px 40px; }

#JrDepStaSelect .f-radio + .f-radio__label::before,
#JrArrStaSelect .f-radio + .f-radio__label::before {
  left: 10px; }

#JrDepStaSelect .f-radio:checked + .f-radio__label::after,
#JrArrStaSelect .f-radio:checked + .f-radio__label::after {
  left: 16px; }

.f-detail-request__radio > .f-radio__wrap {
  padding: 0; }

.f-detail-seat__item {
  padding: 0; }

.f-detail-request .f-radio + .f-radio__label {
  padding: 0 0 0 30px; }
.f-detail-request .f-radio + .f-radio__label::before {
  left: 0; }
.f-detail-request .f-radio + .f-radio__label::after {
  left: 6px; }

.f-plan-confirm__radio .f-radio__label {
  margin-right: 35px;
  padding-right: 0px; }

.f-search__descirption--long label {
  margin-right: 20px; }

.f-search__descirption--long .f-radio__label {
  margin-right: 0; }

/*--------------------------------
2.8 checkbox
--------------------------------*/
.f-checkbox__wrap {
  display: block; }
  .f-checkbox__wrap .f-checkbox__text {
    margin-right: 0; }

.f-checkbox {
  display: none; }

.f-checkbox__text {
  display: inline-flex;
  align-items: center;
  position: relative;
  min-height: 30px;
  padding-left: 30px;
  line-height: 1.5;
  cursor: pointer; }

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

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

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

.f-checkbox-label {
  margin-right: 20px; }

_:-ms-input-placeholder, :root, .f-checkbox__text {
  min-height: auto;
  padding-top: 5px;
  padding-bottom: 5px; }

.f-checkbox-button__wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  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-weight: bold;
  font-size: 12px; }

.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-weight: bold;
  font-size: 10px; }

.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-weight: bold;
  font-size: 10px;
  font-feature-settings: "palt"; }

.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: 56px;
  height: 56px;
  background-color: #dedede;
  border-radius: 4px;
  box-sizing: border-box; }

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

.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); }

/* チェックボックスの押せる範囲とポインターの範囲を合わせる */
label {
  cursor: pointer; }

.f-detail-term__choice label {
  margin-right: 20px; }

.f-checkbox__text {
  margin-right: 0; }

#NTA_JR2_Brand label {
  margin-right: 20px; }

.f-checkbox__wrap {
  display: inline-block; }

/*--------------------------------
2.9 select
--------------------------------*/
.f-select__wrap {
  display: inline-block;
  position: relative; }
  .f-select__wrap::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 30px;
    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: 9px;
    right: 10px;
    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 + .f-select__wrap {
    margin-top: 10px; }

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

.f-select-stay-nights {
  min-width: 100px; }

.na {
  background-color: lightgray; }

.f-select-departure {
  width: auto; }

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

.f-input-calendar__wrap .f-select {
  padding-right: 20px; }

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

.f-button-reserve {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  width: 100px;
  height: 34px;
  padding-left: 0;
  padding-right: 0;
  font-size: 11px;
  color: #20208c;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208c;
  border-radius: 6px;
  transition: opacity 0.3s ease-out; }
  .f-button-reserve:hover {
    opacity: 0.6; }

.f-button-line {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 210px;
  height: 40px;
  font-size: 12px;
  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;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .f-button-line::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #20208c;
    border-right: 2px solid #20208c;
    transform: rotate(45deg) translateY(-50%); }
  .f-button-line:hover {
    opacity: 0.6; }

.f-button-line--small {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 148px;
  height: 40px;
  font-size: 12px;
  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;
  transition: opacity 0.3s ease-out;
  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--small:hover {
    opacity: 0.6; }

.f-button-line--cancel {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 148px;
  height: 40px;
  margin-right: 30px;
  font-size: 12px;
  color: #333;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #a0a0a0;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .f-button-line--cancel::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:hover {
    opacity: 0.6; }

.f-button-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  flex-wrap: wrap;
  position: relative;
  width: 680px;
  height: 73px;
  margin-left: auto;
  margin-right: auto;
  font-size: 24px;
  color: #fff;
  text-decoration: none;
  background-color: #e61b61;
  border: none;
  border-radius: 6px;
  box-shadow: 0 3px 0 #d6d6d6;
  transition: background 0.3s ease-out;
  cursor: pointer; }
  .f-button-submit::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }
  .f-button-submit:hover {
    background-color: #f077a1; }

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

.f-button-submit__link {
  text-decoration: none; }

.f-button-submit__text--small {
  display: block;
  margin-top: 6px;
  font-weight: bold;
  font-size: 12px; }

.f-button-submit--small {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 210px;
  height: 40px;
  font-size: 12px;
  color: #fff;
  text-decoration: none;
  background-color: #e61b61;
  border: none;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .f-button-submit--small::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-submit--small:hover {
    opacity: 0.6; }

.f-button-submit--long {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 424px;
  height: 43px;
  font-size: 16px;
  color: #fff;
  text-decoration: none;
  background-color: #e61b61;
  border: none;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .f-button-submit--long::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }
  .f-button-submit--long:hover {
    opacity: 0.6; }

.f-button-submit--half {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 470px;
  height: 70px;
  font-size: 24px;
  color: #fff;
  text-decoration: none;
  background-color: #e61b61;
  border: none;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .f-button-submit--half::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }
  .f-button-submit--half:hover {
    background-color: #f077a1; }

.f-button-cancel {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 470px;
  height: 70px;
  font-size: 24px;
  color: #fff;
  text-decoration: none;
  background-color: #a0a0a0;
  border: none;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .f-button-cancel::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }
  .f-button-cancel:hover {
    background-color: lightgray; }

.f-button-back {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 348px;
  height: 34px;
  margin-left: auto;
  margin-right: auto;
  color: #fff;
  text-decoration: none;
  background-color: #a0a0a0;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: opacity 0.3s ease-out; }
  .f-button-back:hover {
    opacity: 0.6; }

.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;
  transition: opacity 0.3s ease-out; }
  .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-more:hover {
    opacity: 0.5; }

.f-button-seat {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
  height: 32px;
  margin-top: 5px;
  margin-bottom: 5px;
  font-size: 12px;
  color: #333;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208c;
  border-radius: 4px;
  box-shadow: 0 2px 1px #dedede;
  cursor: pointer;
  transition: opacity 0.3s ease-out; }
  .f-button-seat:hover {
    opacity: 0.5; }

.f-button-seat__icon {
  width: 10px;
  margin-right: 5px; }

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

.f-button-facility {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  width: 106px;
  height: 35px;
  font-weight: bold;
  font-size: 12px;
  color: #333;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208c;
  border-radius: 4px;
  box-shadow: 0 2px 1px #dedede;
  cursor: pointer;
  transition: opacity 0.3s ease-out; }
  .f-button-facility:hover {
    opacity: 0.5; }

.f-button-facility__icon {
  width: 16px;
  margin-right: 5px; }

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

.f-button-clear {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  width: 56px;
  height: 25px;
  margin-top: 5px;
  font-size: 11px;
  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;
  cursor: pointer;
  transition: opacity 0.3s ease-out; }
  .f-button-clear:hover {
    opacity: 0.5; }

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

.f-button-hint__wrap--top {
  display: flex;
  justify-content: space-between; }
  .f-button-hint__wrap--top .f-button-hint {
    margin-top: 3px; }

.f-search-requirement__item .f-button-hint {
  position: absolute;
  padding-left: 4px; }

.f-button-hint {
  position: relative;
  top: 1px;
  display: inline-block;
  width: 16px;
  height: 16px;
  cursor: pointer;
  transition: opacity 0.2s ease-out; }
  .f-button-hint:hover {
    opacity: 0.6; }

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

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

.f-button-favorite {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 96px;
  height: 26px;
  background-color: #fff;
  border: 1px solid #a0a0a0;
  border-radius: 4px;
  box-sizing: border-box;
  cursor: pointer; }
  .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;
  line-height: 11px;
  text-decoration: none; }
  .f-button-favorite__text::before {
    content: "";
    position: absolute;
    top: 1px;
    left: 0;
    width: 12px;
    height: 11px;
    background: url("../images/icon/ico_heart02.png") no-repeat 0 0;
    background-size: 12px 11px; }

_:-ms-input-placeholder, :root, .f-button-favorite__text {
  padding-top: 1px; }

.f-button-reset {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 160px;
  height: 30px;
  font-size: 12px;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  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: 240px;
  height: 36px;
  font-size: 13px;
  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;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .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-compare:hover {
    opacity: 0.6; }

.f-button-list {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 240px;
  height: 36px;
  margin-left: 20px;
  font-size: 13px;
  color: #fff;
  text-decoration: none;
  background-color: #a0a0a0;
  border: none;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .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-list:hover {
    opacity: 0.6; }

.f-button-search {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  position: relative;
  width: 60px;
  height: 50px;
  padding-top: 2px;
  background-color: #000;
  border: none;
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
  transition: opacity 0.2s ease-out;
  cursor: pointer; }
  .f-button-search:hover {
    opacity: 0.6; }

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

.f-button-map {
  display: inline-block;
  position: relative;
  width: 60px;
  height: 26px;
  margin-left: 43px;
  padding-top: 7px;
  padding-right: 5px;
  font-size: 11px;
  font-weight: normal;
  color: #20208c;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #20208c;
  border-radius: 2px;
  box-sizing: border-box;
  transition: opacity 0.3s ease-out;
  cursor: pointer; }
  .f-button-map::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    width: 3px;
    height: 3px;
    border-top: 1px solid #20208c;
    border-right: 1px solid #20208c;
    transform: rotate(45deg) translateY(-50%); }
  .f-button-map:hover {
    opacity: 0.5; }

.f-button-change {
  display: block;
  position: relative;
  width: 346px;
  height: 46px;
  margin: 43px auto -10px;
  padding-top: 15px;
  font-weight: bold;
  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: 7px;
    height: 7px;
    border-top: 2px solid #a0a0a0;
    border-right: 2px solid #a0a0a0;
    transform: rotate(45deg) translateY(-50%); }
  .f-button-change:hover {
    opacity: 0.6; }

/*--------------------------------
2.11 section
--------------------------------*/
.f-section input:disabled + label {
  color: #CCCCCC; }

.f-section__head {
  display: flex;
  justify-content: space-between;
  position: relative;
  padding: 25px 10px;
  font-size: 22px;
  font-weight: bold;
  border-top: 5px solid #dedede; }
  .f-section__head::before {
    content: "";
    position: absolute;
    top: -5px;
    left: 0;
    width: 120px;
    height: 5px;
    background-color: #20208c; }

.f-section__head--line {
  display: flex;
  justify-content: space-between;
  position: relative;
  margin-bottom: 26px;
  padding: 25px 10px;
  font-size: 22px;
  font-weight: bold;
  border-top: 5px solid #dedede;
  border-bottom: 1px solid #dedede; }
  .f-section__head--line::before {
    content: "";
    position: absolute;
    top: -5px;
    left: 0;
    width: 120px;
    height: 5px;
    background-color: #20208c; }

.f-section__title {
  width: calc(100% - 96px);
  font-size: 22px;
  font-weight: bold; }

.f-section__button {
  position: absolute;
  top: 24px;
  right: 10px; }

.f-section__button-top {
  padding-bottom: 30px; }

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

.f-section__text--important {
  display: inline-block;
  padding: 10px 50px;
  font-size: 16px;
  font-weight: bold;
  color: #cc0d21;
  text-align: center;
  border: 1px solid #cc0d21; }

.f-section__text--important-short {
  display: inline-block;
  padding: 10px 18px;
  font-size: 16px;
  font-weight: bold;
  color: #cc0d21;
  text-align: center;
  border: 1px solid #cc0d21; }

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

.f-section__text--attention {
  font-weight: bold;
  color: #cc0d21;
  text-align: center; }

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

/* hover追加 */
.f-section__link:hover {
  opacity: 0.6; }

.f-section__inner--large {
  width: calc(100% - 310px); }

.f-section__inner--small {
  width: 310px;
  text-align: right; }

.f-section__name {
  margin-top: -5px;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5; }

.f-section__text--small {
  margin-top: 10px;
  font-size: 12px;
  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; }

.f-section__pr_icon_01_text {
  display: inline-block;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #e04c31; }

.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 {
  margin-top: 5px;
  margin-bottom: 15px; }

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

.f-section-access__list {
  display: flex;
  margin-top: -5px;
  margin-left: 10px; }

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

.f-section-access__description {
  width: calc(100% - 80px);
  line-height: 1.5; }

/*--------------------------------
2.12 status
--------------------------------*/
.f-status {
  margin-top: 4px;
  margin-bottom: 36px; }

.f-status__list {
  display: flex;
  justify-content: center;
  position: relative;
  padding-left: 0; }
  .f-status__list::after {
    content: "";
    position: absolute;
    top: 14px;
    left: 60px;
    width: calc(100% - 120px);
    height: 1px;
    background-color: #ccc;
    z-index: -1; }

.f-status__list--long {
  display: flex;
  justify-content: center;
  position: relative;
  padding-left: 0; }
  .f-status__list--long::after {
    content: "";
    position: absolute;
    top: 14px;
    left: 70px;
    width: calc(100% - 140px);
    height: 1px;
    background-color: #ccc;
    z-index: -1; }

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

.f-status__item--long {
  width: 175px;
  list-style: none;
  font-size: 12px;
  font-weight: bold;
  color: #ccc;
  text-align: center; }
  .f-status__item--long.is-done {
    color: #333; }
    .f-status__item--long.is-done .f-status__number {
      position: relative;
      color: transparent;
      background-color: #333; }
      .f-status__item--long.is-done .f-status__number::before {
        content: "";
        display: block;
        position: absolute;
        top: 7px;
        left: 7px;
        border-left: 2px solid #fff;
        border-bottom: 2px solid #fff;
        width: 7px;
        height: 4px;
        transform: rotate(-45deg); }
  .f-status__item--long.is-current {
    color: #20208c; }
    .f-status__item--long.is-current .f-status__number {
      position: relative;
      width: 26px;
      height: 26px;
      margin: 0 auto 12px;
      color: transparent;
      background-color: #20208c;
      border-radius: 26px; }
      .f-status__item--long.is-current .f-status__number::before {
        content: "";
        display: block;
        position: absolute;
        top: 8px;
        left: 8px;
        border-left: 2px solid #fff;
        border-bottom: 2px solid #fff;
        width: 9px;
        height: 5px;
        transform: rotate(-45deg); }

.f-status__number {
  display: block;
  width: 22px;
  height: 22px;
  margin: 4px auto 12px;
  padding-top: 5px;
  font-family: Helvetica, sans-serif;
  font-size: 13px;
  font-weight: bold;
  color: #fff;
  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: 12px 10px;
  font-size: 14px;
  font-weight: bold;
  background-color: #ededed;
  box-sizing: border-box; }

.f-facility-info__icon {
  width: 20px;
  margin-right: 10px; }

.f-facility-info__body {
  display: flex;
  justify-content: space-between;
  padding: 25px 10px 35px; }

.f-facility-info__image {
  width: 220px; }

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

.f-facility-info__inner {
  width: 697px; }

.f-facility-info__title {
  margin-bottom: 12px;
  font-size: 18px;
  font-weight: bold; }

.f-facility-info__text {
  font-size: 12px; }

.f-facility-info__list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 10px;
  line-height: 1.2; }

.f-facility-info__item {
  width: 138px;
  padding-top: 9px;
  padding-bottom: 9px;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.2;
  border-bottom: 1px solid #dedede; }

.f-facility-info__description {
  width: calc(100% - 138px);
  padding-top: 9px;
  padding-bottom: 9px;
  font-size: 13px;
  line-height: 1.2;
  border-bottom: 1px solid #dedede; }

.f-facility-info__description-checkin {
  width: calc(40% - 138px); }

.f-facility-info__description-checkout {
  width: calc(60% - 138px); }

/*--------------------------------
2.14 detail
--------------------------------*/
.f-detail__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 1px;
  padding: 15px 13px;
  font-size: 20px;
  font-weight: bold;
  color: #fff;
  background-color: #20208c; }
  .f-detail__head.js-accordion {
    cursor: pointer; }

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

.f-detail__body {
  padding: 25px 10px 45px; }

.f-detail-apply-form__body {
  padding: 25px 10px 0; }

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

.f-detail__link {
  color: #0065d6;
  text-decoration: none;
  transition: opacity 0.2s ease-out; }
  .f-detail__link:hover {
    opacity: 0.6;
    text-decoration: underline; }

.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--important {
  font-weight: bold;
  color: #cc0d21; }

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

.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-note__item--large-container {
  margin-bottom: 15px; }

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

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

.f-detail-via__item-attention {
  font-size: 12px;
  font-weight: normal; }

.f-detail-via__description {
  width: 100%;
  padding: 20px 25px;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-detail-via__description > .f-radio + .f-radio__label {
    margin-right: 30px; }

.f-detail-roundtrip__text--small {
  margin-top: 10px;
  margin-bottom: 15px;
  font-weight: bold; }

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

.f-detail-roundtrip__list {
  display: flex;
  margin-bottom: 15px; }

.f-detail-roundtrip__item {
  position: relative;
  width: 104px;
  min-height: 90px;
  padding-top: 20px;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background-color: #000;
  box-sizing: border-box; }

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

.f-detail-roundtrip__data {
  width: 371px;
  min-height: 90px;
  padding: 13px 25px 18px;
  font-weight: bold;
  color: #fff;
  background-color: #a0a0a0;
  box-sizing: border-box; }

.f-detail-term__wrap {
  display: flex;
  position: relative;
  margin-bottom: 20px;
  padding-top: 20px; }
  .f-detail-term__wrap::before {
    content: "";
    position: absolute;
    top: 0;
    left: 20px;
    width: calc(100% - 40px);
    height: 1px;
    background-color: #ccc; }

.f-detail-term {
  width: 50%;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box; }
  .f-detail-term + .f-detail-term {
    border-left: 1px solid #ccc; }

.f-detail-term__text {
  font-size: 12px;
  font-weight: bold;
  margin-left: 4px;
  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: 18px 10px 10px;
  font-size: 13px; }
  .f-detail-term__description:last-child {
    padding-bottom: 0; }

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

.f-detail-term__choice {
  margin-top: 18px;
  margin-bottom: 15px; }
  .f-detail-term__choice .f-select__wrap {
    min-width: 198px; }

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

.f-detail-select__body > .f-tab {
  padding-bottom: 15px; }
.f-detail-select__body .f-tab-three__content {
  border-bottom: 1px solid #dedede; }

.f-detail-select__data {
  height: 12px;
  margin-top: 20px;
  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: 0;
    left: 0;
    width: 13px;
    height: 13px;
    background: none;
    border: 2px solid #21A4Ea;
    border-radius: 13px;
    box-sizing: border-box; }

.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: -3px;
    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; }

.f-detail-select__text {
  display: flex;
  align-items: center;
  padding-left: 10px;
  padding-right: 10px;
  font-size: 12px;
  border-bottom: 1px solid #dedede; }

.f-detail-select__arrow {
  display: flex;
  justify-content: flex-end;
  position: relative;
  height: 30px; }
  .f-detail-select__arrow::before {
    content: '';
    position: absolute;
    bottom: 5px;
    left: 50%;
    width: 0;
    height: 0;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-top: 18px solid #e61b61;
    transform: translateX(-50%); }

.f-detail-request {
  display: flex;
  margin-bottom: 16px;
  padding: 18px 20px;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-detail-request__inner--large {
  width: 510px;
  border-right: 1px dashed #dedede; }
  .f-detail-request__inner--large .f-radio + .f-radio__label {
    margin-right: 0; }

.f-detail-request__inner--small {
  width: calc(100% - 510px);
  padding-top: 5px;
  padding-left: 27px; }

.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; }

.f-detail-info__item {
  width: 268px;
  padding: 15px 20px;
  font-weight: bold;
  line-height: 1.2;
  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 {
  width: calc(100% - 268px);
  padding-top: 15px;
  padding-bottom: 15px;
  line-height: 1.2;
  border-bottom: 1px solid #dedede; }

.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;
  transition: opacity 0.2s ease-out; }
  .f-detail-arrow__link:hover {
    opacity: 0.6;
    text-decoration: underline; }
  .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__item {
  padding-left: 1.4em;
  font-size: 12px;
  list-style: none;
  line-height: 1.5;
  text-indent: -1.4em; }

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

.f-detail-unit__text {
  line-height: 1.5; }

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

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

.f-detail-table__head {
  padding: 14px 16px;
  font-weight: bold;
  background-color: #ededed;
  border-top: 1px solid #dedede; }

.f-detail-table__list {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #dedede; }
  .f-detail-table__list + .f-detail-table__list {
    margin-top: 20px; }

.f-detail-table__item {
  width: 200px;
  padding: 13px;
  font-weight: bold;
  font-size: 12px;
  line-height: 1.5;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-table__item--simple {
  width: 136px;
  padding: 6px 16px;
  font-weight: bold;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-table__description {
  width: calc(100% - 200px);
  padding: 13px 25px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-table__description--simple {
  width: calc(100% - 136px);
  padding: 6px 16px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-detail-table-table__text--small {
  font-weight: bold;
  font-size: 12px; }

.f-detail-table-table__text--price {
  margin-left: 10px;
  margin-right: 20px;
  font-weight: bold;
  font-size: 22px; }

.f-detail-notice {
  margin-bottom: 30px; }

.f-detail-notice__text {
  color: #cc0d21;
  line-height: 1.5; }
  .f-detail-notice__text + .f-detail-notice__text {
    margin-top: 10px; }

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

.f-detail-marstime-inner {
  width: 470px;
  padding-top: 10px;
  padding-left: 10px; }

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

.f-detail-marstime-hour-inner {
  min-width: 0px; }

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

.f-detail-marstime-minute-inner {
  min-width: 0px; }

.f-detail-marsmark {
  text-align: right;
  font-size: 12px;
  margin-bottom: 10px; }

.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: 2px;
    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: 0px;
    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: 8px;
    left: 6px;
    width: 16px;
    height: 2px; }
  .f-detail-marsmark .Full:before {
    transform: rotate(-45deg); }
  .f-detail-marsmark .Full:after {
    transform: rotate(45deg); }

.f-detail-trainselect__container,
.f-detail-marsstatus__container {
  display: flex;
  justify-content: space-between;
  margin-bottom: 15px; }

.f-detail-marsstatus__badge {
  display: inline-block;
  height: 30px;
  line-height: 30px;
  padding: 10px;
  border-radius: 4px;
  color: white; }

.f-detail-marsstatus__text {
  display: inline-block;
  vertical-align: top;
  max-width: 360px;
  line-height: 21px;
  padding-left: 10px; }

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

.f-detail-path__text {
  display: none;
  margin-bottom: 20px; }

.f-detail-trains-headline {
  padding: 10px;
  margin-bottom: 10px;
  color: #20208c;
  border-radius: 4px;
  border: 1px solid #20208c; }

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

.f-detail-limit-normal .f-radio + .f-radio__label {
  display: block;
  align-items: center;
  position: relative;
  padding-left: 32px;
  line-height: 1.5;
  cursor: pointer;
  text-align: center; }

.f-detail-limit-normal .f-radio + .f-radio__label::before {
  left: 5px;
  background-color: transparent; }

.f-detail-limit-normal .f-radio + .f-radio__label::after {
  left: 11px !important; }

.f-detail-limit-normal .f-tab__text--small {
  display: inline-block;
  font-size: 11px;
  font-weight: bold;
  width: 100%; }

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

/*--------------------------------
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: 30px 10px 50px; }
  .f-note__body.is-close {
    display: none; }

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

.f-note__body--small {
  padding: 30px 10px 0; }
  .f-note__body--small.is-close {
    display: none; }

.f-note__body--exsmall {
  padding: 25px 10px 45px; }
  .f-note__body--exsmall.is-close {
    display: none; }

.f-note__text {
  line-height: 1.5; }
  .f-note__text + .f-note__text {
    margin-top: 10px; }

.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: 20px;
  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__link:hover {
    opacity: 0.5;
    text-decoration: underline; }

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

.f-note-info__item {
  position: relative;
  margin-bottom: 10px;
  padding-left: 18px;
  font-weight: bold; }
  .f-note-info__item::before {
    content: "";
    position: absolute;
    top: 7px;
    left: 0;
    width: 12px;
    height: 2px;
    background-color: #20208c; }

.f-note-info__item--strong {
  position: relative;
  margin-bottom: 10px;
  padding-left: 18px;
  font-weight: bold; }
  .f-note-info__item--strong::before {
    content: "";
    position: absolute;
    top: 7px;
    left: 0;
    width: 12px;
    height: 2px;
    background-color: #e61b61; }

.f-note-info__description {
  margin-bottom: 20px;
  line-height: 1.5; }

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

.f-note-caption__list {
  margin-top: 10px;
  margin-bottom: 10px; }

.f-note-caption__item {
  padding-left: 1.4em;
  list-style: none;
  line-height: 1.5;
  text-indent: -1.4em; }

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

/*--------------------------------
2.16 ballon
--------------------------------*/
.f-ballon {
  position: relative;
  width: 100%;
  margin-bottom: 30px;
  border: 1px solid #ccc;
  box-sizing: border-box; }
  .f-ballon::before {
    content: "";
    position: absolute;
    top: -13px;
    left: 50%;
    width: 0;
    height: 0;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-bottom: 13px solid #ccc;
    transform: translateX(-50%);
    z-index: 1; }
  .f-ballon::after {
    content: "";
    position: absolute;
    top: -11px;
    left: 50%;
    width: 0;
    height: 0;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-bottom: 13px solid #fff;
    transform: translateX(-50%);
    z-index: 2; }

.f-ballon__head {
  display: flex;
  align-items: center;
  padding: 16px 20px;
  cursor: pointer; }

.f-ballon__title {
  width: calc(100% - 25px);
  font-weight: bold;
  text-align: center; }

.f-ballon__body {
  display: none; }

/*--------------------------------
2.17 confirm
--------------------------------*/
.f-confirm__body {
  margin-bottom: 40px; }

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

.f-confirm__text {
  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 {
  margin-left: 10px;
  font-weight: bold; }

.f-confirm-price-table {
  width: 100%;
  border-top: 1px solid #dedede;
  border-collapse: collapse; }

.f-confirm-price-table__row-total {
  background-color: #fff9f0; }
  .f-confirm-price-table__row-total .f-confirm-price-table__data {
    padding: 20px 18px; }

.f-confirm-price-table__head {
  width: 176px;
  padding-left: 20px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.7;
  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-price-table__data {
  padding: 14px 18px;
  line-height: 1.5;
  vertical-align: middle;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-price-table__data:last-child {
    border-right: none; }
  .f-confirm-price-table__data .f-button-hint {
    margin-top: 1px; }

.f-confirm-price-table__cell--small {
  width: 60px;
  padding: 14px 10px;
  font-weight: bold;
  background-color: #ededed;
  box-sizing: border-box; }

.f-confirm-price_table__text {
  font-weight: normal; }

.f-confirm-price-table__text--total {
  display: inline-block;
  width: 173px;
  font-weight: bold; }

.f-confirm-price-table__text--small {
  font-weight: bold;
  font-size: 14px;
  color: #cc0d21; }

.f-confirm-price-table__text--base {
  color: #333; }

.f-confirm-price-table__text--price {
  margin-left: 10px;
  margin-right: 20px;
  font-weight: bold;
  font-size: 22px;
  color: #cc0d21; }

.f-confirm-price-table__text--attention {
  color: #cc0d21; }

.f-confirm-price-table__list {
  display: flex;
  justify-content: space-between; }

.f-confirm-price-table__item {
  font-weight: bold; }

.f-confirm-price-table__description {
  text-align: right; }

.f-confirm-price__list + .f-confirm-price__list {
  margin-top: 15px; }

.f-confirm-price__inner {
  margin-top: 15px;
  margin-bottom: 20px; }

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

.f-confirm-schedule__list {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #dedede; }
  .f-confirm-schedule__list + .f-detail-table__list {
    margin-top: 20px; }

.f-confirm-schedule__item {
  width: 177px;
  padding: 15px 12px;
  font-weight: bold;
  font-size: 14px;
  line-height: 1.3;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-schedule__description {
  width: calc(100% - 177px);
  padding: 15px 20px;
  font-size: 14px;
  line-height: 1.3;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-schedule-table {
  width: 100%;
  margin-top: 15px;
  border-top: 1px solid #dedede;
  box-sizing: border-box;
  border-collapse: collapse; }

.f-confirm-schedule-table__row .f-confirm-schedule-table__head:first-child,
.f-confirm-schedule-table__row .f-confirm-schedule-table__head-data {
  width: 177px; }
.f-confirm-schedule-table__row .f-confirm-schedule-table__head:last-child,
.f-confirm-schedule-table__row .f-confirm-schedule-table__data:last-child {
  width: 190px; }

.f-confirm-schedule-table__head {
  padding: 16px;
  font-weight: bold;
  text-align: left;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-schedule-table__head:last-child {
    border-right: none; }

.f-confirm-schedule-table__head-data {
  padding: 18px;
  line-height: 1.5;
  vertical-align: top;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-schedule-table__data {
  padding: 18px;
  line-height: 1.5;
  vertical-align: top;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-schedule-table__data:last-child {
    border-right: none; }

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

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

.f-confirm-schedule__text--day {
  width: 70px;
  height: 24px;
  margin-bottom: 5px;
  padding-top: 2px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background-color: #20208c;
  box-sizing: border-box; }

.f-confirm-schedule__text--date {
  white-space: nowrap; }

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

.f-confirm-schedule__timeline-wrap {
  position: relative;
  margin-top: 7px;
  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 1px;
  background-size: 6px 18px; }
  .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 {
  line-height: 1.5; }

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

.f-confirm-schedule__text-train {
  display: inline-block;
  min-width: 12.5em; }

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

.f-confirm-schedule__arrow {
  position: relative;
  padding-left: 20px;
  font-size: 12px;
  line-height: 1.6; }
  .f-confirm-schedule__arrow::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    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 {
  display: flex;
  align-items: center;
  position: relative;
  padding-left: 22px;
  line-height: 1.5; }
  .f-confirm-schedule__box::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 16px;
    height: 13px;
    background: url("../images/icon/ico_facility01.png") no-repeat 0 0;
    background-size: 16px 13px;
    transform: translateY(-50%); }

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

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

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

.f-confirm-schedule__text--strong {
  font-weight: bold; }

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

.f-confirm-schedule-plan {
  margin-left: 22px; }
  .f-confirm-schedule-plan .f-accordion-button__head,
  .f-confirm-schedule-plan .f-accordion-button__body {
    max-width: 524px; }

.f-confirm-schedule-plan__list {
  display: flex;
  flex-wrap: wrap;
  max-width: 524px;
  margin-top: 15px;
  margin-bottom: 15px;
  border-top: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-schedule-plan__item {
  width: 118px;
  padding-top: 5px;
  padding-bottom: 5px;
  font-weight: bold;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-schedule-plan__description {
  width: calc(100% - 118px);
  padding-top: 5px;
  padding-bottom: 5px;
  font-size: 13px;
  line-height: 1.52;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-schedule-plan__description.is-checkin {
    padding-top: 15px; }

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

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

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

.f-confirm-payment__item {
  list-style: none; }

.f-confirm-payment__link {
  display: block;
  position: relative;
  width: 100%;
  margin-top: 10px;
  padding-top: 48px;
  padding-bottom: 20px;
  list-style: none;
  color: #333;
  text-decoration: none;
  text-align: center;
  border: 1px solid #ccc;
  box-sizing: border-box;
  transition: opacity 0.2s ease-out;
  cursor: pointer; }
  .f-confirm-payment__link:hover {
    opacity: 0.6; }
  .f-confirm-payment__link::before {
    content: "";
    position: absolute;
    top: 25px;
    left: 50%;
    transform: translateX(-50%); }
  .f-confirm-payment__link: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__link: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__link: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__link:nth-child(4)::before {
    width: 12px;
    height: 12px;
    background: url("../images/icon/ico_tel01.png") no-repeat 0 0;
    background-size: 12px 12px; }

.is-unsupported .f-confirm-payment__link {
  color: #a0a0a0;
  background-color: #ededed;
  border: none;
  pointer-events: none; }
  .is-unsupported .f-confirm-payment__link:first-child::before {
    background: url("../images/icon/ico_card02.png") no-repeat 0 0;
    background-size: 18px 12px; }
  .is-unsupported .f-confirm-payment__link:nth-child(2)::before {
    background: url("../images/icon/ico_bank02.png") no-repeat 0 0;
    background-size: 16px 14px; }
  .is-unsupported .f-confirm-payment__link:nth-child(3)::before {
    background: url("../images/icon/ico_store02.png") no-repeat 0 0;
    background-size: 17px 12px; }
  .is-unsupported .f-confirm-payment__link: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-apply__text-important {
  margin-bottom: 25px;
  font-weight: bold;
  color: #cc0d21; }

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

.f-confirm-store__item {
  width: 230px;
  padding: 7px 16px;
  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 {
    padding: 16px;
    font-size: 14px;
    background-color: #ededed; }

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

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

.f-confirm-store-plan__list {
  display: flex;
  flex-wrap: wrap;
  width: 100%; }

.f-confirm-store-plan__item {
  width: 230px;
  padding: 7px 16px;
  font-weight: bold;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-store-plan__description {
  width: calc(100% - 230px);
  padding: 7px 16px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

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

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

.f-confirm-cancel-table {
  width: 100%;
  border-top: 1px solid #dedede;
  border-collapse: collapse; }

.f-confirm-cancel-table__head {
  padding: 16px;
  font-weight: bold;
  font-size: 14px;
  line-height: 1.3;
  text-align: left;
  vertical-align: top;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-cancel-table__head:last-child {
    border-right: none; }

.f-confirm-cancel-table__row .f-confirm-cancel-table__data:first-child {
  width: 160px;
  text-align: left; }
.f-confirm-cancel-table__row .f-confirm-cancel-table__data:nth-child(2) {
  width: 220px; }
.f-confirm-cancel-table__row .f-confirm-cancel-table__data:nth-child(n +5):nth-last-child(n + 2) {
  width: 134px; }
.f-confirm-cancel-table__row .f-confirm-cancel-table__data:last-child {
  width: 126px; }

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

.f-confirm-cancel__text--important {
  margin-bottom: 25px;
  padding-top: 18px;
  padding-bottom: 18px;
  font-weight: bold;
  font-size: 20px;
  border: 1px solid #cc0d21;
  text-align: center; }

.f-confirm-cancel__text--attention {
  font-weight: bold;
  color: #cc0d21; }

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

.f-confirm-choice {
  margin-bottom: 25px; }

.f-confirm-choice__text {
  margin-bottom: 25px;
  line-height: 1.5; }

.f-confirm-choice__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between; }

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

.f-confirm-choice__caption {
  font-size: 14px;
  padding-bottom: 15px; }

.f-confirm-choice-table {
  width: 100%;
  border-top: 1px solid #dedede;
  border-collapse: collapse; }

.f-confirm-choice-table__head {
  width: 90px;
  padding: 15px;
  font-weight: bold;
  line-height: 2;
  text-align: left;
  vertical-align: top;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-choice-table__data {
  padding: 15px 20px;
  line-height: 2;
  vertical-align: middle;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-choice-table__data-last {
  width: 200px;
  padding: 15px 20px;
  line-height: 2;
  vertical-align: middle;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-confirm-choice__list {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 160px; }

.f-confirm-choice__item {
  width: 60px;
  padding-bottom: 2px;
  line-height: 1.7; }

.f-confirm-choice__description {
  width: calc(100% - 60px);
  line-height: 1.7;
  text-align: right; }

.f-confirm-choice__text-price {
  margin-right: 5px;
  font-size: 18px; }

.f-confirm-choice__text--important {
  font-size: 14px;
  color: #cc0d21;
  line-height: 1.5; }

.f-confirm-total__title {
  margin-top: 34px;
  margin-bottom: 25px;
  padding: 17px 12px;
  font-weight: bold;
  font-size: 16px;
  color: #fff;
  background-color: #333; }

.f-confirm-total-table {
  width: 100%;
  border-top: 1px solid #dedede;
  border-collapse: collapse; }
  .f-confirm-total-table + .f-confirm-total-table {
    margin-top: 30px; }

.f-confirm-total-table__head {
  padding: 18px 25px;
  text-align: left;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-total-table__head:last-child {
    border-right: none; }

.f-confirm-total-table__row .f-confirm-total-table__head:first-child {
  width: 200px;
  padding: 18px 15px; }

.f-confirm-total-table__data {
  padding: 18px 25px;
  text-align: right;
  line-height: 1.3;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-confirm-total-table__data:last-child {
    border-right: none; }

.f-confirm-total-table__data--left {
  padding: 18px 25px;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

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

.f-confirm__button-bottom {
  margin-top: 30px;
  margin-bottom: 80px; }
  .f-confirm__button-bottom > .f-button-back {
    margin-top: 80px;
    margin-bottom: 14px; }

/* 支払方法 */
.f-confirm-payment__item {
  position: relative;
  margin-top: 10px; }
  .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-payment__item .f-confirm-payment__link {
    margin: 0; }
    .f-confirm-payment__item .f-confirm-payment__link::before {
      content: none; }

.f-confirm-payment__item.is-unsupported {
  background-color: #ededed; }
  .f-confirm-payment__item.is-unsupported .f-confirm-payment__link {
    background-color: transparent; }

/* 要素の個数に応じて％を書き換える */
.f-confirm-payment__list .f-confirm-payment__item {
  width: 49%; }

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

/*--------------------------------
2.18 plan
--------------------------------*/
.f-plan__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 28px 10px;
  border-top: 1px solid #dedede; }

.f-plan__title {
  margin-bottom: 15px;
  font-weight: bold;
  font-size: 20px;
  color: #20208c; }

.f-plan__subtitle {
  font-size: 12px; }

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

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

.f-plan__pr_icon_01_text {
  display: inline-block;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #e04c31; }

.f-plan__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__list {
  display: flex;
  flex-wrap: wrap;
  margin-top: -20px; }

.f-plan__item {
  width: 126px;
  padding-top: 28px;
  padding-bottom: 20px;
  font-weight: bold;
  border-bottom: 1px solid #ededed; }
  .f-plan__item:nth-last-child(2) {
    border-bottom: none; }

.f-plan__item-wda_aniversary {
  width: 150px;
  margin: auto 0;
  font-weight: bold;
  border-bottom: 1px solid #ededed; }
  .f-plan__item-wda_aniversary:nth-last-child(2) {
    border-bottom: none; }

.f-plan__hint {
  display: inline;
  position: relative;
  padding-right: 20px;
  font-weight: bold; }
  .f-plan__hint .f-button-hint {
    position: absolute;
    top: 1px;
    right: -3px;
    padding-top: 2px; }

.f-plan__description {
  width: calc(100% - 126px);
  padding-top: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #ededed; }
  .f-plan__description:last-child {
    border-bottom: none; }

.f-plan__description-wda_aniversary {
  width: calc(100% - 150px);
  padding-top: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #ededed; }
  .f-plan__description-wda_aniversary:last-child {
    border-bottom: none; }

.f-plan-info {
  margin-bottom: 45px; }

.f-plan-info__head {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100px;
  padding: 20px 10px;
  font-size: 20px;
  font-weight: bold;
  color: #000;
  line-height: 1;
  background-color: #f8f8f8;
  box-sizing: border-box;
  border-top: 4px solid #20208c; }

.f-plan-info__body {
  display: flex;
  justify-content: space-between;
  padding: 15px 10px 30px; }

.f-plan-info__carousel {
  width: 375px; }

.f-plan-info__inner {
  width: 540px; }

.f-plan-info__label {
  margin-top: 10px;
  margin-left: 10px;
  margin-right: 10px; }

.f-plan-info__list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  line-height: 1.2;
  margin-top: -10px; }

.f-plan-info__item {
  width: 138px;
  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-plan-info__item:nth-last-child(2) {
    padding-top: 13px;
    border-bottom: none; }

.f-plan-info__description {
  width: calc(100% - 138px);
  padding-top: 8px;
  padding-bottom: 8px;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-plan-info__description:last-child {
    border-bottom: none; }

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

.f-plan-info__text {
  margin-top: 5px; }

.f-plan-info__banner {
  width: 60px;
  margin-right: 8px; }

.f-plan-info__banner-image {
  width: 100%; }

.f-plan-note {
  padding: 20px;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

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

.f-plan-note__text {
  line-height: 1.5; }

.f-plan-detail__body {
  display: flex;
  justify-content: space-between;
  margin-bottom: 35px; }

.f-plan-detail__inner {
  width: 720px; }

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

.f-plan-detail__figure + .f-plan-detail__figure {
  margin-top: 30px; }

.f-plan-detail__picture {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  margin: 0 auto; }

.f-plan-detail__caption {
  margin-top: 10px;
  font-size: 12px; }

.f-plan-detail__text {
  align-items: center;
  width: 100%;
  padding: 20px;
  line-height: 1.5;
  background-color: #f8f8f8;
  border-radius: 6px;
  box-sizing: border-box; }

.f-plan-confirm__basic {
  margin-top: 25px; }

.f-plan-confirm__list {
  display: flex;
  border-top: 1px solid #ededed; }

.f-plan-confirm__item {
  width: 126px;
  padding-top: 20px;
  padding-bottom: 20px;
  font-weight: bold;
  border-bottom: 1px solid #ededed; }

.f-plan-confirm__description {
  width: calc(100% - 126px);
  padding-top: 15px;
  padding-right: 24px;
  border-bottom: 1px solid #ededed; }

.f-plan-confirm__inner {
  display: flex;
  align-items: center; }

.f-plan-confirm__text-between {
  margin: 10px 20px; }

.f-plan-confirm__container {
  margin-left: 5px;
  margin-right: 15px; }

.f-plan-confirm__select .f-select {
  min-width: 90px; }

.f-plan-confirm__text {
  min-width: 150px; }

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

.f-plan-confirm__text--light {
  margin-right: 10px;
  font-size: 11px;
  color: #a0a0a0; }

.f-plan-confirm__text--small {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 12px; }

.f-plan-confirm__text--right {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 12px;
  text-align: right; }

.f-plan-confirm__radio .f-radio__label {
  margin-bottom: 15px;
  padding-right: 35px;
  box-sizing: border-box; }

.f-plan-requirement:last-child {
  margin-bottom: 45px; }

.f-plan-requirement__text-capacity {
  margin-left: 20px; }

.f-plan-requirement__text--attention {
  color: #cc0d21; }

.f-plan-requirement__inner {
  display: flex;
  align-items: center;
  white-space: nowrap; }
  .f-plan-requirement__inner + .f-plan-requirement__inner {
    margin-top: 25px; }

.f-plan-requirement__title {
  display: flex;
  align-items: center;
  height: 20px;
  margin-right: 25px;
  padding-left: 10px;
  font-weight: bold;
  border-left: 4px solid #20208C; }

.f-plan-requirement__icon {
  position: relative;
  top: 8px;
  width: 12px;
  margin-right: 2px; }

.f-plan-requirement__list {
  display: flex;
  align-items: center; }

.f-plan-requirement__item {
  font-weight: bold; }

.f-plan-requirement__description {
  display: flex;
  align-items: center; }

.f-plan-requirement__label {
  margin-right: 8px; }

.f-plan-requirement__select {
  margin-left: 25px; }
  .f-plan-requirement__select .f-select {
    min-width: 90px; }

.f-plan-requirement__text--strong {
  font-weight: bold; }

.f-plan-requirement__background {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 362px;
  margin-right: 20px;
  padding: 15px 15px 15px 20px;
  background-color: #ededed;
  border-radius: 6px;
  box-sizing: border-box; }
  .f-plan-requirement__background .f-select__wrap {
    height: 30px; }
  .f-plan-requirement__background .f-select {
    min-width: 90px; }

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

.f-plan-requirement-caption__list {
  margin-top: 10px;
  margin-bottom: 10px;
  padding-left: 0; }

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

.f-plan-requirement__text-caption {
  padding-top: 20px;
  padding-bottom: 20px;
  font-size: 12px;
  border-top: 1px solid #dedede; }

.f-plan-requirement__select--long .f-select__wrap {
  width: 218px; }

.f-plan-money-table {
  width: 930px; }

.f-plan-money-table__head {
  width: 222px;
  height: 46px;
  padding: 16px;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.3;
  text-align: center;
  vertical-align: middle;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-plan-money-table__head:first-child {
    width: 140px; }
  .f-plan-money-table__head:last-child {
    width: 146px;
    border-right: none; }

.f-plan-money-table__data {
  padding: 16px;
  vertical-align: middle;
  text-align: center;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-plan-money-table__data:nth-child(5) {
    border-right: none; }

.f-plan-money-table__right {
  text-align: right; }

.f-plan-money__text--strong {
  font-weight: bold; }

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

.f-plan-accordion {
  margin-bottom: 20px;
  border-radius: 4px;
  border: 2px solid #20208C;
  box-shadow: 0 3px 0 #d6d6d6; }

.f-plan-accordion__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 18px 20px;
  text-align: center;
  border: none;
  box-sizing: border-box;
  cursor: pointer; }

.f-plan-accordion__title {
  width: calc(100% - 25px);
  padding-left: 20px;
  font-weight: bold;
  font-size: 20px;
  color: #20208C;
  text-align: center; }

.f-plan-accordion__icon {
  position: relative;
  top: 1px;
  width: 19px;
  margin-right: 10px; }

.f-plan-accordion__body {
  display: none;
  position: relative;
  padding: 30px 60px; }
  .f-plan-accordion__body::before {
    content: "";
    position: absolute;
    top: 0;
    left: 20px;
    width: calc(100% - 40px);
    height: 2px;
    background-color: #20208c; }

.f-plan-accordion__select {
  display: flex;
  align-items: center;
  justify-content: center; }

.f-plan-accordion__select-text {
  margin-right: 60px;
  font-weight: bold; }

.f-plan-accordion__text--right {
  margin-bottom: 20px;
  text-align: right; }

.f-plan-calendar__wrap {
  border-top: 1px solid #ededed; }

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

.f-plan-calendar__header {
  width: 33.4%; }

.f-plan-calendar__prev {
  position: relative;
  padding-left: 18px;
  color: #0065d6;
  text-decoration: none;
  transition: opacity 0.2s ease-out;
  cursor: pointer; }
  .f-plan-calendar__prev::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #a0a0a0;
    border-left: 2px solid #a0a0a0;
    transform: rotate(45deg) translateY(-50%); }
  .f-plan-calendar__prev:hover {
    opacity: 0.6;
    text-decoration: underline; }

.f-plan-calendar__current {
  flex-grow: 1;
  font-weight: bold;
  font-size: 18px;
  text-align: center; }

.f-plan-calendar__next {
  position: relative;
  padding-right: 18px;
  text-align: right;
  color: #0065d6;
  text-decoration: none;
  transition: opacity 0.2s ease-out; }
  .f-plan-calendar__next::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 6px;
    height: 6px;
    border-top: 2px solid #a0a0a0;
    border-right: 2px solid #a0a0a0;
    transform: rotate(45deg) translateY(-50%); }
  .f-plan-calendar__next:hover {
    opacity: 0.6;
    text-decoration: underline; }

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

.f-plan-calendar-table__head {
  width: 132px;
  height: 40px;
  padding-left: 5px;
  font-size: 12px;
  text-align: center;
  font-weight: bold;
  line-height: 1.3;
  vertical-align: middle;
  background-color: #f8f8f8;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }

.f-plan-calendar-table__data {
  position: relative;
  height: 120px;
  padding: 10px;
  line-height: 1.3;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box;
  background-clip: padding-box; }

.f-plan-calendar-table__data:hover {
  background: rgba(255, 255, 255, 0.6); }

.f-plan-calendar-table__data.f-plan-calendar-table__day-select:hover {
  background: #FFF2F7; }

.f-plan-calendar-table__text-day {
  height: 18px;
  font-family: Helvetica, sans-serif; }

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

.f-plan-calendar-table__text-sat {
  color: #2BA8EA; }

.f-plan-calendar-table__day-select {
  background-color: #ffeaf1;
  background-clip: padding-box; }

.f-plan-calendar-table__disabled {
  color: #a0a0a0;
  background-color: #f8f8f8;
  background-clip: padding-box;
  pointer-events: none; }

.f-plan-calendar-table__text-child {
  display: flex;
  position: absolute;
  top: 12px;
  right: 12px;
  font-size: 10px;
  cursor: pointer;
  transition: all 0.2s ease-out; }
  .f-plan-calendar-table__text-child:hover {
    opacity: 0.6;
    text-decoration: none; }
    .f-plan-calendar-table__text-child:hover + .f-tooltip {
      display: block; }

.f-plan-calendar-table__text-price {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  font-weight: bold;
  border: none; }

.f-plan-calendar-table__text-status {
  height: 20px;
  color: #0065d6;
  text-align: center; }

.f-plan-calendar-table__day-select .f-plan-calendar-table__text-price,
.f-plan-calendar-table__day-select .f-plan-calendar-table__text-status {
  color: #e61b61; }

.f-plan-calendar-table__disabled .f-plan-calendar-table__text-price,
.f-plan-calendar-table__disabled .f-plan-calendar-table__text-status {
  color: #a0a0a0; }

.f-plan-calendar-table__attention {
  position: relative;
  top: 2px;
  width: 10px;
  height: 10px;
  margin-right: 2px; }

.f-plan-calendar__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 20px;
  padding-left: 12px; }

.f-plan-calendar__list-link {
  display: flex;
  white-space: nowrap; }

.f-plan-calendar__item-link {
  list-style: none;
  line-height: 14px; }
  .f-plan-calendar__item-link + .f-plan-calendar__item-link {
    position: relative;
    margin-left: 5px;
    padding-left: 10px; }
    .f-plan-calendar__item-link + .f-plan-calendar__item-link::before {
      content: "";
      position: absolute;
      top: 50%;
      left: 0;
      width: 1px;
      height: 12px;
      background-color: #333;
      transform: translateY(-45%); }

.f-plan-calendar__link {
  color: #0065d6;
  text-decoration: none;
  transition: opacity 0.2s ease-out; }
  .f-plan-calendar__link:hover {
    opacity: 0.6;
    text-decoration: underline; }

.f-plan-remarks {
  margin-top: 40px; }

.f-plan-remarks__head {
  padding: 16px;
  font-weight: bold;
  font-size: 16px;
  background-color: #ededed; }

.f-plan-remarks__body {
  margin-bottom: 20px;
  padding: 20px 16px;
  border-bottom: 1px solid #ededed; }

.f-plan-remarks__inner + .f-plan-remarks__inner {
  margin-top: 20px; }

.f-plan__button-top {
  margin-bottom: 60px; }

.f-plan__button-text {
  margin-top: 36px;
  font-weight: bold;
  text-align: center; }

.f-plan__button-inner {
  margin-top: 20px;
  text-align: center; }

.f-plan__button-flex {
  display: flex;
  justify-content: space-between;
  width: 950px;
  margin-left: auto;
  margin-right: auto; }

.f-plan-schedule-table {
  width: 100%; }

.f-plan-schedule__head {
  padding: 16px;
  font-weight: bold;
  text-align: left;
  background-color: #ededed;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-plan-schedule__head:first-child {
    width: 80px; }
  .f-plan-schedule__head:nth-child(3) {
    width: 288px;
    border-right: none; }

.f-plan-schedule__data {
  padding: 16px;
  line-height: 1.5;
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  box-sizing: border-box; }
  .f-plan-schedule__data:last-child {
    border-right: none; }

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

.f-plan-schedule__image {
  position: relative;
  top: 8px;
  width: 17px; }

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

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

.f-plan-schedule__list {
  margin-top: 15px; }

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

.f-plan-travel-guide-info-note__text {
  line-height: 1.5;
  border-bottom: 1px solid #ededed; }

.f-plan-note_body {
  height: 120px;
  padding: 20px 10px 20px;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }

.f-plan-note_remarks {
  padding-left: 20px;
  padding-right: 20px;
  padding-top: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid #dedede;
  line-height: 1.5; }

.f-plan-company {
  margin-top: 45px;
  padding: 20px;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  background-color: #f8f8f8; }

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

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

.f-plan__button-bottom {
  margin-top: 50px;
  margin-bottom: 80px; }

.f-plan-related {
  margin-left: 10px;
  margin-right: 10px; }
  .f-plan-related + .f-plan-related {
    margin-top: 47px; }

.f-plan-related__head {
  margin-bottom: 20px;
  padding: 18px 12px;
  font-weight: bold;
  background-color: #ededed;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  box-sizing: border-box; }

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

.f-plan-related__inner {
  width: 310px;
  height: 108px;
  border: 1px solid #ccc;
  box-sizing: border-box; }

.f-plan-related__link {
  display: block;
  padding: 10px;
  color: #333;
  text-decoration: none;
  transition: opacity 0.2s ease-out; }
  .f-plan-related__link:hover {
    opacity: 0.5; }

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

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

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

.f-plan-related__copy {
  width: calc(100% - 90px);
  font-weight: bold;
  font-size: 11px;
  color: #20208c;
  line-height: 1.3; }

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

.f-plan-related__item {
  font-size: 9px; }

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

.f-plan-calendar__prev,
.f-plan-calendar__next {
  padding: 0;
  cursor: default; }
  .f-plan-calendar__prev::before,
  .f-plan-calendar__next::before {
    content: none; }
  .f-plan-calendar__prev:hover,
  .f-plan-calendar__next:hover {
    opacity: 1; }

.f-plan-calendar__prev a,
.f-plan-calendar__next a {
  position: relative;
  color: #0065d6;
  text-decoration: none;
  transition: opacity 0.2s ease-out;
  cursor: pointer; }
  .f-plan-calendar__prev a:hover,
  .f-plan-calendar__next a:hover {
    opacity: 0.6; }

.f-plan-calendar__prev a {
  padding-left: 30px; }
  .f-plan-calendar__prev a::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 10px;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #a0a0a0;
    border-left: 2px solid #a0a0a0;
    transform: rotate(45deg) translateY(-50%); }

.f-plan-calendar__next a {
  padding-right: 20px;
  cursor: pointer; }
  .f-plan-calendar__next a::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #a0a0a0;
    border-right: 2px solid #a0a0a0;
    -webkit-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%); }

/*--------------------------------
2.19 carousel
--------------------------------*/
.f-carousel__wrap {
  position: relative;
  width: 100%;
  overflow: hidden; }

.f-carousel__wrap-controls {
  position: relative;
  width: 100%; }

.f-carousel__image {
  height: 282px;
  margin: 0 auto; }

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

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

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

.f-carousel__arrows-round .slick-arrow {
  display: block;
  position: absolute;
  top: 45px;
  width: 30px;
  height: 30px;
  background-color: rgba(0, 0, 0, 0.4);
  border: none;
  border-radius: 30px;
  color: transparent;
  outline: none;
  box-sizing: border-box; }

.f-carousel__arrows-round .slick-prev {
  left: -15px; }

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

.f-carousel__arrows-round .slick-next {
  right: -5px; }

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

.f-carousel__inner {
  position: relative; }

.f-carousel__text {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 12px;
  font-size: 12px;
  color: #fff;
  background-color: rgba(0, 0, 0, 0.7);
  box-sizing: border-box; }

.f-carousel__thumbnail {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: 10px;
  padding-left: 5px;
  padding-right: 8px;
  vertical-align: middle; }
  .f-carousel__thumbnail .slick-slide {
    margin-left: 5px;
    margin-right: 5px;
    overflow: hidden;
    white-space: nowrap; }
  .f-carousel__thumbnail .slick-current {
    position: relative;
    box-sizing: border-box; }
    .f-carousel__thumbnail .slick-current::before {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(255, 255, 255, 0.5); }
    .f-carousel__thumbnail .slick-current::after {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      border: 1px solid #e61b61;
      box-sizing: border-box; }
  .f-carousel__thumbnail .slick-list {
    padding: 0 !important; }

.f-carousel__thumbnail-image {
  width: 80px;
  box-sizing: border-box;
  vertical-align: middle; }

.f-carousel__thumbnail-picture {
  height: 61px;
  margin: 0 auto; }

/*--------------------------------
2.20 tooltip
--------------------------------*/
.f-tooltip {
  display: none;
  position: absolute;
  top: -82px;
  left: 0;
  width: 185px;
  height: 78px;
  padding-top: 7px;
  padding-left: 12px;
  padding-right: 12px;
  background-color: #fff;
  border: 1px solid #20208c;
  box-sizing: border-box; }
  .f-tooltip::before {
    content: "";
    position: absolute;
    bottom: -13px;
    left: 50%;
    width: 0;
    height: 0;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-top: 13px solid #20208c;
    transform: translateX(-50%);
    z-index: 1; }
  .f-tooltip::after {
    content: "";
    position: absolute;
    bottom: -11px;
    left: 50%;
    width: 0;
    height: 0;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-top: 13px solid #fff;
    transform: translateX(-50%);
    z-index: 2; }

.f-tooltip__title {
  margin-bottom: 5px;
  font-size: 10px;
  text-align: center; }

.f-tooltip__list {
  display: flex;
  justify-content: space-between;
  padding-top: 3px;
  padding-bottom: 3px; }
  .f-tooltip__list + .f-tooltip__list {
    border-top: 1px dashed #ededed; }

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

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

.f-plan-tool-tip-center__text {
  font-size: 11px;
  position: absolute;
  width: 100%;
  text-align: center;
  color: #000; }

.f-plan-tool-tip-left__text {
  font-size: 11px;
  position: absolute;
  margin-bottom: 2px;
  padding-bottom: 2px;
  width: 89%;
  top: 26px;
  text-align: left;
  border-bottom: #000 dashed 1px; }

.f-plan-tool-tip-right__text {
  font-size: 11px;
  font-weight: bold;
  color: #000;
  position: absolute;
  width: 85%;
  text-align: right; }

.f-plan-tool-tip-B_left__text {
  font-size: 11px;
  position: absolute;
  margin-top: 5px;
  margin-bottom: 1px;
  width: 85%;
  top: 40px;
  text-align: left; }

.f-plan-tool-tip-B_right__text {
  font-size: 11px;
  font-weight: bold;
  color: #000;
  position: absolute;
  width: 85%;
  text-align: right; }

/*--------------------------------
2.21 modal
--------------------------------*/
.f-modal {
  position: relative;
  width: 380px;
  min-height: 180px;
  margin: 0 auto;
  padding: 20px 25px 90px;
  background-color: #fff;
  box-sizing: border-box;
  z-index: 150; }

.f-modal__text {
  font-size: 13px;
  line-height: 1.5; }
  .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%; }

.f-error-modal {
  display: none;
  position: fixed;
  width: 380px;
  min-height: 180px;
  margin: 0 auto;
  padding: 20px 25px 80px;
  background-color: #fff;
  box-sizing: border-box;
  z-index: 150; }

.f-error-modal-close {
  color: #333;
  width: 44px;
  height: 44px;
  line-height: 44px;
  position: absolute;
  right: 0;
  top: 0;
  text-decoration: none;
  text-align: center;
  opacity: 0.65;
  padding: 0 0 18px 10px;
  font-style: normal;
  font-size: 28px;
  font-family: Arial, Baskerville, monospace;
  user-select: none; }

button.f-error-modal-close {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  -webkit-appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  box-shadow: none;
  touch-action: manipulation; }

.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-hint {
  position: relative;
  width: 620px;
  margin: 0 auto;
  padding: 30px;
  background-color: #fff;
  box-sizing: border-box;
  z-index: 150; }
  .f-modal-hint .f-detail-unit__title {
    margin-bottom: 18px; }

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

.f-modal__list {
  margin-top: 15px; }

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

.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;
  align-items: center;
  justify-content: space-between;
  height: 50px;
  padding-left: 15px;
  padding-right: 15px;
  background-color: #20208c;
  box-sizing: border-box; }

.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 60px 70px;
  background-color: #fff; }

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

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

.f-modal-gallery__heading {
  display: flex;
  align-items: center;
  height: 20px;
  margin-bottom: 20px;
  padding-left: 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;
  height: 281px;
  background-color: #ededed; }

.f-modal-gallery__picture {
  height: 282px;
  margin: 0 auto; }

.f-modal-gallery__caption {
  margin: 5px 0 20px 0;
  font-size: 12px; }

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

/*add20191108　modal　.modal-hint01_brandname_popupmodal from NTA*/
.modal-hint01_brandname_popupmodal p.f-modal__title {
  margin: 0 0 10px 0;
  padding: 0 10px 0; }

.modal-hint01_brandname_popupmodal p.f-modal__title img {
  margin-left: 10px; }

.modal-hint01_brandname_popupmodal p.f-modal__text {
  margin-bottom: 30px;
  padding: 0; }

.childNum a {
  text-decoration: none;
  padding-left: 10px; }

.popupChild {
  border: 2px solid #20208c;
  position: absolute;
  width: 295px;
  background: #FFFFFF;
  z-index: 100; }

.popupChild .inner {
  padding: 8px 10px; }
  .popupChild .inner table {
    margin: 0 auto; }

.popupChild td {
  padding-bottom: 2px; }

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

.popupChild .attention {
  font-size: 85%;
  padding-top: 10px;
  padding-bottom: 10px;
  color: #FF0000;
  vertical-align: top; }

.popupChild .close {
  text-align: center;
  clear: both;
  padding-top: 5px; }
  .popupChild .close a {
    text-decoration: none; }

/*--------------------------------
2.22 card
--------------------------------*/
.f-card__wrap {
  display: flex;
  justify-content: space-between; }

.f-card {
  margin-left: 10px;
  margin-right: 10px;
  background-color: #fff; }
  .f-card + .f-card {
    margin-top: 47px; }

.f-card--small {
  display: flex;
  align-items: center;
  width: 310px;
  height: 120px;
  padding: 0 10px;
  background-color: #fff;
  border: 1px solid #ccc;
  box-sizing: border-box; }

.f-card--exsmall {
  display: flex;
  width: 295px;
  border: 1px solid #ccc;
  box-sizing: border-box; }

.f-card__head {
  margin-bottom: 20px;
  padding: 18px 12px;
  font-weight: bold;
  background-color: #ededed;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  box-sizing: border-box; }

.f-card__head--check {
  position: relative;
  margin-bottom: 20px;
  padding: 16px 12px 16px 35px;
  font-weight: bold;
  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(-50%); }

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

.f-card__inner {
  width: 310px;
  min-height: 108px;
  border: 1px solid #ccc;
  box-sizing: border-box; }

.f-card__inner-small {
  display: flex; }

.f-card__link {
  display: block;
  width: 100%;
  height: 100%;
  padding: 10px;
  color: #333;
  text-decoration: none;
  transition: opacity 0.2s ease-out;
  box-sizing: border-box; }
  .f-card__link:hover {
    opacity: 0.5; }

.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--exsmall .f-card__block::after {
  right: 3px; }

.f-card__icon {
  position: relative;
  width: 25px;
  padding-right: 8px;
  padding-bottom: 8px;
  font-family: Helvetica, sans-serif;
  font-weight: bold;
  font-size: 12px;
  text-align: center;
  z-index: 1; }
  .f-card__icon::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -3px;
    width: 26px;
    height: 35px;
    background: url("../images/icon/ico_pointer_number01.png") no-repeat 0 0;
    background-size: 26px 35px;
    transform: translateY(-50%);
    z-index: -1; }

@-moz-document url-prefix() {
  .f-card__icon {
    padding-bottom: 7px; } }
.f-card__image {
  width: 80px;
  margin-right: 10px; }

.f-card__picture {
  width: 100%; }

.f-card__copy {
  width: calc(100% - 90px);
  font-weight: bold;
  font-size: 11px;
  color: #20208c;
  line-height: 1.3; }

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

.f-card__item {
  margin-left: -10px;
  font-size: 10px;
  transform: scale(0.85); }

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

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

.f-card__detail--small {
  display: flex;
  flex-grow: 1; }

.f-card__info {
  width: 170px; }

.f-card__text {
  margin-top: 10px;
  padding-left: 6em;
  font-size: 11px;
  line-height: 1.5;
  text-indent: -6em; }

.f-card__text--small {
  margin-top: 10px;
  padding-left: 6em;
  font-size: 10px;
  line-height: 1.5;
  text-indent: -6em; }

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

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

.f-card__name {
  margin-bottom: 5px;
  font-weight: bold;
  color: #20208c;
  line-height: 1.5; }

.f-card__name-history {
  margin-top: -5px;
  margin-bottom: 3px;
  font-weight: bold;
  color: #20208c;
  line-height: 1.5; }

.f-card__name--small {
  margin-bottom: 5px;
  font-weight: bold;
  font-size: 12px;
  color: #20208c;
  line-height: 1.5; }

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

.f-card__place-history {
  margin-bottom: 7px;
  margin-left: 0;
  font-size: 11px;
  color: #a0a0a0; }

.f-card__stars {
  font-weight: bold;
  font-size: 11px;
  white-space: nowrap; }
  .f-card__stars .f-star--small {
    margin-bottom: 1px; }
  .f-card__stars .f-star--exsmall {
    margin-left: 3px; }

.f-card__stars--small {
  font-weight: bold;
  font-size: 10px;
  white-space: nowrap; }
  .f-card__stars--small .f-star--exsmall {
    margin-left: 3px; }

/*--------------------------------
2.23 search
--------------------------------*/
.f-search-attention {
  display: flex;
  margin-left: 10px;
  margin-right: 10px;
  margin-bottom: 20px;
  border: 1px solid #cc0d21; }

.f-search-attention__head {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 90px;
  font-weight: bold;
  color: #fff;
  background-color: #cc0d21; }

.f-search-attention__body {
  width: calc(100% - 90px);
  padding: 18px;
  color: #cc0d21;
  line-height: 1.5;
  box-sizing: border-box; }

.f-search-attention__text--strong {
  margin-bottom: 1px;
  font-weight: bold; }

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

.f-search__head {
  display: flex;
  align-items: flex-end;
  padding-bottom: 18px;
  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__icon {
  position: relative;
  padding-left: 30px;
  font-weight: bold; }
  .f-search__icon::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 20px;
    height: 20px;
    background: url("../images/icon/ico_search01.png") no-repeat 0 0;
    background-size: 20px 20px;
    transform: translateY(-50%); }

.f-search__picture {
  width: 100%; }

.f-search__number {
  width: 170px;
  font-weight: bold;
  text-align: right; }

.f-search__number-important {
  margin-left: 10px;
  margin-right: 5px;
  font-weight: bold;
  font-size: 26px;
  color: #cc0d21; }

.f-search__body {
  margin-top: 15px; }
  .f-search__body input:disabled + span {
    color: #CCCCCC; }
  .f-search__body input:disabled + label {
    color: #CCCCCC; }

.f-search__flex {
  display: flex; }

.f-search__inner {
  width: calc(100% - 320px); }

.f-search-nights__wrap {
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid #ededed; }

.f-search-nights {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 5px;
  background-color: #f5f5f5;
  border-radius: 4px;
  box-sizing: border-box; }

.f-search-nights__text {
  font-size: 13px; }

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

.f-search-nights__text--small {
  margin-left: 25px;
  font-size: 11px; }

.f-search-map-click {
  width: 320px;
  margin-left: 20px; }

.f-search-map-click__text {
  margin-bottom: 10px;
  font-size: 13px; }

.f-search-map-click__list {
  padding: 0px 5px;
  margin-bottom: 10px;
  font-size: 90%;
  line-height: normal; }

.f-search-map-click__item {
  position: relative;
  font-weight: bold;
  list-style: none; }
  .f-search-map-click__item + .f-search-map-click__item {
    padding-left: 20px; }
    .f-search-map-click__item + .f-search-map-click__item::before {
      content: ">";
      position: absolute;
      top: 1px;
      left: 7px;
      width: 5px;
      height: 5px;
      font-weight: bold;
      color: #333; }

.f-search-map-click__label {
  margin-bottom: 11px;
  font-weight: bold; }

.f-search-map-click__link {
  color: #0065d6;
  text-decoration: none; }

.f-search-map-click__image {
  width: 320px; }

.f-search-term {
  display: flex; }

.f-seach-term__small {
  width: 280px;
  margin-right: 30px; }
  .f-seach-term__small .f-search__item:not(:last-child) {
    border-bottom: none; }
  .f-seach-term__small .f-search__descirption--short {
    border-bottom: none; }

.f-search-term__large .f-select__wrap,
.f-search-term__large .f-select {
  width: 190px;
  padding-right: 0; }

.f-search-term__list {
  display: flex;
  align-items: center; }

.f-search-term__item {
  margin-right: 5px;
  font-weight: bold;
  white-space: nowrap; }

.f-search-term__descirption {
  display: flex;
  align-items: center; }

.f-search-term__text--small {
  margin-left: 8px;
  margin-right: 10px;
  font-size: 11px;
  color: #a0a0a0;
  white-space: nowrap; }

.f-search__list {
  display: flex;
  flex-wrap: wrap;
  margin-top: -15px; }

.f-search__list--long {
  display: flex;
  flex-wrap: wrap;
  margin-top: 15px;
  border-top: 1px solid #ededed; }

.f-search__item {
  width: 78px;
  padding-top: 24px;
  font-weight: bold; }
  .f-search__item:not(:last-child) {
    border-bottom: 1px solid #ededed; }

.f-search__item--short {
  width: 80px;
  padding-right: 30px;
  padding-top: 23px;
  font-weight: bold;
  border-bottom: 1px solid #ededed;
  box-sizing: border-box; }

.f-search__item--exshort {
  width: 80px;
  padding-left: 20px;
  padding-top: 23px;
  font-weight: bold;
  border-bottom: 1px solid #ededed;
  box-sizing: border-box; }

.f-search__item--long {
  width: 105px;
  padding-top: 21px;
  font-weight: bold;
  border-bottom: 1px solid #ededed; }

.f-search__item-stay-nights {
  width: 65px;
  padding-top: 24px;
  padding-left: 15px;
  font-weight: bold; }
  .f-search__item-stay-nights:not(:last-child) {
    border-bottom: 1px solid #ededed; }

.f-search__descirption {
  width: calc(100% - 78px);
  padding-top: 15px;
  padding-bottom: 15px; }
  .f-search__descirption:not(:last-child) {
    border-bottom: 1px solid #ededed; }
  .f-search__descirption .f-input-calendar__wrap {
    width: 200px; }

.f-search__descirption-dp {
  width: 300px;
  padding-top: 18px;
  padding-bottom: 18px; }
  .f-search__descirption-dp:not(:last-child) {
    border-bottom: 1px solid #ededed; }
  .f-search__descirption-dp .f-input-calendar__wrap {
    width: 214px; }

.f-search__descirption-stay-nights {
  width: 100px;
  padding-top: 18px;
  padding-bottom: 18px; }
  .f-search__descirption-stay-nights:not(:last-child) {
    border-bottom: 1px solid #ededed; }

.f-search__descirption--short {
  width: 200px;
  padding-top: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid #ededed; }
  .f-search__descirption--short .f-select {
    min-width: 200px; }

.f-search__item--noline {
  width: 105px;
  padding-top: 24px;
  font-weight: bold; }

.f-search__item--noline-long {
  width: 110px;
  padding-top: 24px;
  font-weight: bold; }

.f-search__descirption--noline {
  width: 148px;
  padding-top: 18px; }
  .f-search__descirption--noline .f-select {
    min-width: 148px; }

.f-search__descirption--noline-long {
  width: 195px;
  padding-top: 18px; }
  .f-search__descirption--noline-long .f-select {
    min-width: 148px; }

.f-search__descirption--long {
  width: calc(100% - 105px);
  padding-top: 13px;
  padding-bottom: 8px;
  border-bottom: 1px solid #ededed; }
  .f-search__descirption--long:last-child {
    padding-bottom: 13px; }
  .f-search__descirption--long .f-checkbox__text {
    margin-bottom: 5px; }

.f-search__descirption-pax {
  width: 250px;
  padding-top: 13px;
  padding-bottom: 13px;
  border-bottom: 1px solid #ededed; }

.f-search__descirption-number-of-rooms {
  width: calc(100% - 460px);
  padding-top: 13px;
  padding-bottom: 13px;
  border-bottom: 1px solid #ededed; }

.f-search__item-keyword {
  width: 105px;
  margin-bottom: 30px;
  padding-top: 32px;
  font-weight: bold; }

.f-search__descirption-keyword {
  width: calc(100% - 105px);
  margin-bottom: 30px;
  padding-top: 13px; }

.f-search__list-plan {
  display: flex;
  flex-wrap: wrap;
  margin-top: -15px;
  margin-bottom: -15px; }

.f-search__item-plan {
  width: 105px;
  padding-top: 25px;
  font-weight: bold; }
  .f-search__item-plan:not(:nth-last-child(4)) {
    border-bottom: 1px solid #ededed; }

.f-search__item-plan--long {
  width: 96px;
  padding-top: 25px;
  padding-right: 25px;
  font-weight: bold;
  text-align: right;
  box-sizing: border-box; }
  .f-search__item-plan--long:not(:nth-last-child(2)) {
    border-bottom: 1px solid #ededed; }

.f-search__descirption-plan {
  width: 305px;
  padding-top: 18px;
  padding-bottom: 18px; }
  .f-search__descirption-plan:not(:nth-last-child(3)) {
    border-bottom: 1px solid #ededed; }

.f-search__descirption-plan-pax {
  width: 250px;
  padding-top: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid #ededed; }

.f-search__descirption-plan--long {
  width: 400px;
  padding-top: 18px;
  padding-bottom: 18px; }
  .f-search__descirption-plan--long:not(:last-child) {
    border-bottom: 1px solid #ededed; }

.f-search__descirption-plan--long-dp {
  width: 190px;
  padding-top: 18px;
  padding-bottom: 18px; }
  .f-search__descirption-plan--long-dp:not(:last-child) {
    border-bottom: 1px solid #ededed; }

.f-search__descirption-plan--departure {
  width: 168px;
  padding-top: 18px;
  padding-bottom: 18px; }
  .f-search__descirption-plan--departure:not(:last-child) {
    border-bottom: 1px solid #ededed; }

.f-search__select--long {
  width: 200px; }

.f-search__select--long-dp {
  width: 125px; }

.f-search__select {
  width: 148px; }

.f-search__radio {
  display: inline-block;
  margin-right: 30px; }

.f-search-accordion {
  border: 2px solid #20208c;
  border-radius: 6px;
  box-shadow: 0 2px 0 #d6d6d6; }

.f-search-accordion__head {
  display: flex;
  justify-content: space-between;
  padding: 18px;
  cursor: pointer; }

.f-search-accordion__title {
  width: calc(100% - 22px);
  padding-left: 22px;
  font-weight: bold;
  font-size: 20px;
  color: #20208c;
  text-align: center; }

.f-search-accordion__body {
  display: none;
  padding: 20px 20px 10px;
  border-top: 2px solid #20208c; }

.f-search-requirement__head {
  margin-bottom: 10px;
  padding: 10px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background-color: #20208c;
  box-sizing: border-box; }

.f-search-requirement_inner {
  margin-bottom: 10px;
  padding: 15px 20px;
  background-color: #eff5ff; }

.f-search-requirement__title {
  padding-bottom: 15px;
  font-weight: bold;
  color: #20208c; }

.f-search-requirement__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding: 12px 15px;
  background-color: #fff; }
  .f-search-requirement__list + .f-search-requirement__list {
    margin-top: 10px; }

.f-search-requirement__item {
  position: relative;
  width: 118px;
  font-weight: bold;
  font-size: 12px;
  color: #20208c;
  line-height: 1.5; }

.f-search-requirement__description {
  width: calc(100% - 118px); }

.f-search-requirement__flex {
  display: flex; }

.f-search-requirement__half {
  width: 430px;
  margin-bottom: 10px;
  padding: 15px;
  background-color: #eff5ff; }
  .f-search-requirement__half:nth-child(odd) {
    margin-right: 10px; }
  .f-search-requirement__half .f-checkbox__text {
    min-width: 130px; }

.f-search-keywords__wrap {
  display: flex; }

.f-search-keywords {
  width: 441px;
  display: flex; }

.f-search-keywords__radio {
  width: 340px;
  margin-top: 12px;
  margin-left: 20px; }
  .f-search-keywords__radio .f-radio__label:not(:last-child) {
    margin-right: 20px; }

.f-search-keywords__radio-dp {
  width: 340px;
  margin-top: -4px;
  margin-left: 20px; }
  .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-selected {
  margin-left: 10px;
  margin-right: 10px; }

.f-search-selected__head {
  padding-top: 10px;
  padding-bottom: 10px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background-color: #a0a0a0; }

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

.f-search-selected__list {
  display: flex;
  font-size: 13px; }

.f-search-selected__description {
  margin-right: 30px;
  margin-bottom: 15px;
  font-weight: bold;
  font-size: 13px; }

.f-search-selected__inner {
  display: flex;
  width: 100%;
  margin-top: 5px;
  padding-top: 12px;
  border-top: 1px dashed #ccc;
  box-sizing: border-box; }

.f-search-selected__detail {
  display: flex;
  flex-wrap: wrap;
  width: calc(100% - 140px);
  margin-top: 3px;
  padding-right: 15px; }

.f-search-selected__text {
  display: flex;
  margin-top: 5px;
  margin-bottom: 5px;
  margin-right: 30px;
  font-size: 13px;
  color: #20208c; }

.f-search-selected__button {
  position: relative;
  top: -1px;
  width: 16px;
  margin-left: 5px;
  transition: opacity 0.2s ease-out; }
  .f-search-selected__button:hover {
    opacity: 0.6; }

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

.f-search-tab__flex {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding-left: 10px;
  padding-right: 10px;
  padding-bottom: 20px; }

.f-search-tab__text {
  font-size: 13px;
  line-height: 1.5; }

.f-search-sort {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 12px;
  padding-left: 10px;
  padding-bottom: 12px;
  border-top: 1px solid #ededed;
  border-bottom: 1px solid #ededed; }

.f-search-sort--noline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-left: 10px; }

.f-search-sort__list {
  display: flex;
  align-items: center; }

.f-search-sort__item {
  margin-right: 30px;
  font-weight: bold; }

.f-search-sort__description {
  display: flex; }

.f-search-sort_button {
  display: flex;
  align-items: center;
  position: relative;
  width: 110px;
  height: 34px;
  padding-left: 25px;
  background-color: #f5f5f5;
  border-radius: 6px;
  box-sizing: border-box;
  transition: opacity 0.2s ease-out;
  cursor: pointer; }
  .f-search-sort_button + .f-search-sort_button {
    margin-left: 20px; }
  .f-search-sort_button::after {
    content: "";
    position: absolute;
    top: 12px;
    right: 20px;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #333;
    border-right: 2px solid #333;
    transform: rotate(45deg); }
  .f-search-sort_button.is-active {
    font-weight: bold;
    color: #fff;
    background-color: #20208c; }
    .f-search-sort_button.is-active::after {
      border-bottom: 2px solid #fff;
      border-right: 2px solid #fff; }
  .f-search-sort_button:hover {
    opacity: 0.6; }

.f-search-sort_button_reccomend {
  display: flex;
  align-items: center;
  position: relative;
  width: 110px;
  height: 34px;
  padding-left: 12px;
  background-color: #f5f5f5;
  border-radius: 6px;
  box-sizing: border-box;
  transition: opacity 0.2s ease-out;
  cursor: pointer; }
  .f-search-sort_button_reccomend + .f-search-sort_button {
    margin-left: 20px; }
  .f-search-sort_button_reccomend::after {
    content: "";
    position: absolute;
    top: 12px;
    right: 12px;
    width: 6px;
    height: 6px;
    border-bottom: 2px solid #333;
    border-right: 2px solid #333;
    transform: rotate(45deg); }
  .f-search-sort_button_reccomend.is-active {
    font-weight: bold;
    color: #fff;
    background-color: #20208c; }
    .f-search-sort_button_reccomend.is-active::after {
      border-bottom: 2px solid #fff;
      border-right: 2px solid #fff; }
  .f-search-sort_button_reccomend:hover {
    opacity: 0.6; }

.f-search-sort__text {
  width: 430px; }

.f-search-facility {
  margin-top: 36px; }

.f-search-facility__wrap {
  margin-top: 30px; }

.f-search-facility__number {
  display: flex;
  align-items: flex-end;
  margin-left: 10px;
  margin-right: 10px;
  margin-bottom: 20px;
  font-size: 18px; }

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

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

.f-search-facility__head {
  display: flex;
  padding: 20px 10px;
  background-color: #f8f8f8;
  border-top: 4px solid #20208c; }

.f-search-facility__button {
  width: 108px; }

.f-search-facility__title {
  width: calc(100% - 108px);
  padding-right: 10px;
  font-weight: bold;
  font-size: 20px;
  line-height: 1.5; }

.f-search-facility__subtitle {
  display: inline-block;
  margin-left: 20px;
  font-size: 12px;
  color: #333;
  line-height: 1.5; }

.f-search-facility__link {
  color: #20208c;
  text-decoration: none;
  transition: opacity 0.2s ease-out; }
  .f-search-facility__link:hover {
    opacity: 0.6; }

.f-search-facility__lead {
  font-weight: bold;
  font-size: 20px;
  line-height: 1.5; }

.f-search-facility__body {
  padding-top: 20px;
  padding-left: 10px;
  padding-right: 10px; }

.f-search-facility__flex {
  display: flex; }

.f-search-facility__image {
  width: 310px;
  text-align: center; }

.f-search-facility__picture {
  height: 233px;
  max-width: 310px; }

.f-search-facility__info {
  width: calc(100% - 310px);
  padding-left: 30px;
  box-sizing: border-box; }

.f-search-facility__list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 15px;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc; }

.f-search-facility__item {
  width: 140px;
  padding-top: 8px;
  padding-bottom: 8px;
  font-weight: bold;
  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% - 140px);
  padding-top: 8px;
  padding-bottom: 8px;
  line-height: 1.5; }
  .f-search-facility__description:not(:last-child) {
    border-bottom: 1px dashed #ccc; }

.f-search-access__wrap {
  display: flex;
  flex-wrap: wrap;
  padding-bottom: 15px;
  border-bottom: 1px dashed #ccc;
  margin-bottom: 10px; }

.f-search-access {
  min-width: 310px;
  padding-left: 7em;
  padding-top: 3px;
  line-height: 1.5;
  text-indent: -7em;
  box-sizing: border-box; }

.f-search-access__list {
  display: flex; }

.f-search-access__item {
  width: 95px;
  margin-top: 3px;
  font-weight: bold;
  line-height: 1.5; }

.f-search-access__description {
  width: calc(100% - 95px);
  line-height: 1.5; }

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

.f-search-review {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  padding-top: 10px;
  padding-bottom: 20px;
  border-bottom: 1px dashed #ccc; }

.f-search-review__stars {
  font-weight: bold; }
  .f-search-review__stars .f-star--small {
    margin-left: 10px; }

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

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

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

.f-search-facility__label {
  margin-top: 15px; }

.f-search-facility__label--large {
  margin-top: -10px;
  margin-bottom: 15px; }

.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; }

.f-pr_icon_01_text {
  display: inline-block;
  list-style: none;
  text-align: center;
  padding: 6px 9px;
  color: #e04c31; }

.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-plan {
  margin-top: 25px; }

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

.f-search-plan__head-inner {
  display: flex;
  justify-content: flex-start; }

.f-search-plan__title {
  display: flex;
  align-items: center;
  width: 136px;
  height: 24px;
  margin-right: 20px;
  padding-left: 10px;
  font-weight: bold;
  font-size: 16px;
  border-left: 4px solid #20208C;
  border-right: 1px solid #dedede;
  box-sizing: border-box; }

.f-search-plan__title-noflex {
  display: flex;
  align-items: center;
  width: 136px;
  height: 24px;
  margin-right: 20px;
  padding-left: 10px;
  font-weight: bold;
  font-size: 16px;
  border-left: 4px solid #20208C;
  box-sizing: border-box; }

.f-search-plan__text {
  width: 550px;
  margin-top: 5px;
  padding-left: 8.7em;
  text-indent: -8.7em;
  box-sizing: border-box; }

.f-search-plan__text--strong {
  margin-right: 5px;
  font-weight: bold; }

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

.f-search-plan__detail {
  position: relative; }

.f-search-plan__link {
  display: block;
  position: relative;
  margin-top: 15px;
  padding: 25px 44px 25px 20px;
  color: #333;
  text-decoration: none;
  border: 1px solid #ccc;
  box-sizing: border-box;
  transition: opacity 0.2s ease-out; }
  .f-search-plan__link::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 24px;
    height: 100%;
    background-color: #20208c; }
  .f-search-plan__link::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 12px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }
  .f-search-plan__link:hover {
    opacity: 0.6; }

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

.f-search-plan__flex {
  display: flex; }

.f-search-plan__flex--large {
  width: 65%; }

.f-search-plan__flex--small {
  width: 35%;
  text-align: right; }

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

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

.f-search-plan__info {
  width: calc(100% - 160px);
  padding-left: 20px;
  box-sizing: border-box; }

.f-search-plan__lead {
  width: 560px;
  margin-top: -5px;
  margin-bottom: 20px;
  font-weight: bold;
  font-size: 16px;
  color: #20208c;
  line-height: 1.5; }

.f-search-plan__flex-banner {
  display: flex;
  justify-content: space-between;
  margin-top: 5px; }

.f-search-plan__lead--large {
  width: 560px;
  min-height: 32px;
  margin-bottom: 18px;
  font-weight: bold;
  font-size: 16px;
  color: #20208c;
  line-height: 1.5; }

.f-search-plan__banner {
  display: flex;
  width: 84px;
  justify-content: space-between; }
  .f-search-plan__banner .f-button-hint {
    margin-top: 3px; }

.f-search-plan__flex-label {
  display: flex;
  flex-wrap: wrap; }
  .f-search-plan__flex-label .f-label {
    margin-right: 20px; }

.f-search-plan__text--small {
  margin-bottom: 10px;
  font-size: 12px;
  color: #5c5c5c; }

.f-search-plan__text-code {
  margin-bottom: 10px;
  font-size: 14px;
  color: #5c5c5c; }

.f-search-plan__text-info {
  margin-top: 15px;
  font-size: 14px;
  color: #5c5c5c; }

.f-search-plan__text--important {
  padding-top: 5px;
  font-weight: bold;
  font-size: 22px;
  color: #cc0d21; }

.f-search-plan__favorite {
  position: absolute;
  top: 20px;
  right: 44px; }

.f-search-plan__detail:hover .f-search-plan__favorite {
  opacity: 0.6; }

.f-search-plan__button {
  display: flex;
  justify-content: center;
  margin-top: 26px; }

.f-search-map {
  margin-top: 20px;
  margin-left: 10px;
  margin-right: 10px; }

.f-search-map__image {
  width: 100%;
  height: 630px;
  padding-top: 100px;
  padding-left: 240px;
  padding-right: 230px;
  background: url("../images/img_map01.png") no-repeat 0 0;
  background-size: 950px 630px;
  box-sizing: border-box; }

/* map carousel */
.f-map-carousel {
  cursor: pointer; }

.f-search-popup-container {
  cursor: auto;
  height: 0;
  position: absolute;
  /* The max width of the popup window. */
  width: 480px; }

.f-search-popup-anchor {
  /* Position the div a fixed distance above the tip. */
  position: absolute;
  width: 100%;
  bottom: 15px;
  left: 0; }
  .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%;
  min-height: 350px;
  padding: 20px;
  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;
  align-items: center;
  justify-content: space-between; }

.f-search-balloon__block {
  margin-top: 10px; }

.f-search-balloon__image {
  width: 140px;
  height: 108px; }

.f-search-balloon__detail {
  display: flex;
  align-items: center;
  width: calc(100% - 140px);
  padding-left: 20px;
  box-sizing: border-box; }

.f-search-balloon__name {
  margin-top: -5px;
  margin-bottom: 10px;
  font-weight: bold;
  font-size: 18px;
  color: #20208c;
  line-height: 1.5; }

.f-search-balloon__stars {
  font-weight: bold;
  font-size: 16px; }
  .f-search-balloon__stars .f-star--medium {
    margin-left: 15px; }

.f-search-balloon__text {
  margin-top: 18px;
  padding-bottom: 18px;
  border-bottom: 1px dashed #ccc; }

.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: 30px; }

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

.f-search-balloon__description {
  font-weight: bold;
  font-size: 20px;
  color: #cc0d21; }

.f-search-balloon__picture,
.f-search-map__icon {
  width: 100%; }

.f-search-favorite {
  text-align: center; }

.f-search-favorite__explain {
  width: 448px;
  margin: 20px auto;
  padding: 13px 15px 10px;
  border: 2px solid #ccc;
  box-sizing: border-box; }

.f-search-favorite__text--zero {
  font-weight: bold;
  color: #a0a0a0; }

.f-search-favorite__text--strong {
  margin-bottom: 12px;
  font-weight: bold;
  font-size: 16px;
  color: #ff8b17; }

.f-search-favorite__text {
  font-size: 13px;
  line-height: 1.6; }

.f-search-favorite__text--attention {
  color: #cc0d21; }

.f-search-favorite__button {
  display: flex;
  justify-content: center; }

.f-search-map-plan {
  margin-top: 35px;
  margin-left: 10px; }

.f-search-map-plan__head {
  display: flex;
  align-items: center;
  height: 20px;
  margin-bottom: 15px;
  padding-left: 10px;
  font-weight: bold;
  border-left: 4px solid #20208C;
  font-size: 16px; }

.f-search-map-plan__body {
  padding-top: 10px; }

.f-search-card__list {
  margin-top: 24px;
  margin-bottom: 30px; }

.f-search-special {
  margin-top: -5px;
  margin-bottom: 30px; }

.f-search-special__image {
  width: 100%;
  margin-bottom: 15px; }

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

.f-search-special__detail {
  margin-left: 10px;
  margin-right: 10px;
  padding-bottom: 8px; }

.f-search-special__text {
  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 {
  width: 351px;
  height: 186px;
  margin: 80px auto 10px;
  padding-top: 24px;
  text-align: center;
  border: 1px solid #20208c;
  box-sizing: border-box; }

.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: 34px;
  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-map__attention-icon {
  width: 40px;
  margin-bottom: 16px; }

.f-search-info__body {
  display: flex;
  justify-content: space-between;
  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: 45px; }

.f-search-info__text {
  line-height: 1.5; }
  .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__modal {
  text-align: right; }

.f-search-info__link {
  display: inline-block;
  position: relative;
  margin-top: 20px;
  padding-left: 20px;
  text-align: right;
  text-decoration: none; }
  .f-search-info__link:visited {
    color: #0065d6; }
  .f-search-info__link::before {
    content: "";
    position: absolute;
    top: 2px;
    left: 0;
    width: 13px;
    height: 12px;
    background: url("../images/icon/ico_photo01.png") no-repeat 0 0;
    background-size: 13px 12px; }

.f-search-info__button-map {
  margin-top: 2px; }

.f-search-info__button {
  margin-top: 20px; }

.f-search-room__list {
  display: flex;
  flex-wrap: wrap;
  width: 260px; }

.f-search-room__item {
  width: 160px;
  line-height: 1.5; }

.f-search-room__description {
  width: 100px;
  line-height: 1.5;
  text-align: right; }

.f-search__shisetsu-list {
  text-align: center; }

.f-search__loading-image {
  margin-top: 30px;
  width: 30px; }

.f-search__hit-num-loading-image {
  width: 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.24 star
--------------------------------*/
.f-star--large {
  position: relative;
  display: inline-block;
  width: 94px;
  height: 17px;
  margin-left: 10px;
  font-size: 19px;
  letter-spacing: 1px; }

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

.f-star--medium {
  position: relative;
  display: inline-block;
  width: 84px;
  height: 16px;
  font-size: 17px;
  letter-spacing: 1px; }

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

.f-star--small {
  position: relative;
  display: inline-block;
  width: 70px;
  height: 12px;
  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: 14px; }

.f-star--exsmall {
  position: relative;
  display: inline-block;
  width: 56px;
  height: 10px;
  margin-left: 8px;
  font-size: 11px;
  letter-spacing: 1px; }

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

.f-star--large::before,
.f-star--medium:before,
.f-star--small:before,
.f-star--exsmall:before {
  color: #dedede; }

.f-star--large::after,
.f-star--medium:after,
.f-star--small:after,
.f-star--exsmall: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.25 pagination
--------------------------------*/
.f-pagination__wrap {
  margin-top: 70px; }

.f-pagination {
  display: flex;
  align-items: center;
  justify-content: center; }

.f-pagination__item {
  margin-left: 3px;
  margin-right: 3px;
  list-style: none; }
  .f-pagination__item.is-current .f-pagination__link {
    background-color: #ededed;
    pointer-events: none; }

.f-pagination__link {
  display: block;
  width: 26px;
  height: 26px;
  padding-top: 6px;
  font-family: Helvetica, sans-serif;
  font-size: 13px;
  color: #333;
  text-align: center;
  text-decoration: none;
  border: 1px solid #ededed;
  border-radius: 4px;
  box-sizing: border-box;
  transition: opacity 0.1s ease-out;
  cursor: pointer; }
  .f-pagination__link:hover {
    opacity: 0.6; }

.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: 34px;
  height: 34px;
  margin-right: 20px;
  color: #fff;
  list-style: none;
  background-color: #20208c;
  border-radius: 4px;
  box-sizing: border-box;
  transition: opacity 0.1s ease-out;
  cursor: pointer; }
  .f-pagination__prev::after {
    content: "";
    position: absolute;
    top: 48%;
    left: 13px;
    width: 5px;
    height: 5px;
    border-bottom: 2px solid #fff;
    border-left: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }
  .f-pagination__prev:hover {
    opacity: 0.6; }

.f-pagination__next {
  position: relative;
  width: 34px;
  height: 34px;
  margin-left: 20px;
  color: #fff;
  list-style: none;
  background-color: #20208c;
  border-radius: 4px;
  box-sizing: border-box; }
  .f-pagination__next::after {
    content: "";
    position: absolute;
    top: 48%;
    left: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg) translateY(-50%); }
  .f-pagination__next:hover {
    opacity: 0.6; }

/*--------------------------------
2.26 feature
--------------------------------*/
.f-feature__body {
  margin: 20px 10px; }

.f-feature__list {
  display: flex;
  flex-wrap: wrap;
  font-size: 13px;
  border-top: 1px solid #ededed;
  border-bottom: 1px solid #ededed; }

.f-feature__item {
  width: 110px;
  padding: 8px 10px;
  font-weight: bold;
  line-height: 1.5;
  background-color: #ededed;
  box-sizing: border-box; }

.f-feature__description {
  width: 365px;
  padding: 8px 10px;
  line-height: 1.5;
  box-sizing: border-box; }

.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__image {
  margin-bottom: 47px; }

.f-feature__picture {
  width: 100%; }

.f-feature__text {
  line-height: 1.5; }

.f-feature__caption {
  margin-top: -5px;
  margin-bottom: 20px;
  line-height: 1.5; }

.f-feature-price {
  display: flex;
  align-items: center;
  margin-bottom: 5px;
  font-size: 16px; }

.f-feature-price__list {
  display: flex;
  margin-left: 15px; }

.f-feature-price__item {
  margin-right: 15px;
  line-height: 1.5; }

.f-feature-price__description {
  font-weight: bold;
  line-height: 1.5; }

.f-feature-price__text--important {
  font-weight: bold;
  color: #cc0d21;
  margin-right: 40px; }

.f-feature-note {
  margin-top: 20px;
  padding-left: 1.2em;
  font-size: 12px;
  line-height: 1.5;
  text-indent: -1.2em; }

.f-feature-include__item {
  margin-top: 30px;
  padding: 12px 16px;
  font-weight: bold;
  font-size: 16px;
  background-color: #ededed; }

.f-feature-include__description {
  padding: 5px 16px;
  border-bottom: 1px solid #ccc; }

.f-feature__select {
  display: flex; }

.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: 65px;
  font-weight: bold; }

.f-feature__flex {
  margin-bottom: 20px; }
  .f-feature__flex .f-detail__text--small {
    margin-top: 10px; }

.f-feature-calendar__current {
  flex-grow: 1;
  font-weight: bold;
  font-size: 20px;
  text-align: center; }

.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-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; }

.f-feature-choice {
  padding: 24px 20px;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede; }
  .f-feature-choice > .f-radio + .f-radio__label {
    margin-right: 40px; }

.f-feature-radio__wrap {
  display: flex;
  align-items: center;
  margin-bottom: 5px; }
  .f-feature-radio__wrap .f-radio__label {
    width: 278px; }

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

.f-feature__button {
  margin-bottom: 60px;
  text-align: center; }

.f-feature__button-bottom {
  margin-top: 60px;
  margin-bottom: 20px; }

.f-feature-via__description {
  width: 100%;
  padding: 20px 25px;
  box-sizing: border-box; }
  .f-feature-via__description > .f-radio + .f-radio__label {
    margin-right: 30px; }

/*--------------------------------
2.27 attention
--------------------------------*/
.f-attention {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 80px;
  margin-bottom: 20px;
  padding-left: 10px;
  padding-right: 10px;
  background-color: #20208c;
  box-sizing: border-box; }

.f-attention__text {
  font-weight: bold;
  font-size: 26px;
  color: #fff; }

.f-attention__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 145px;
  height: 40px;
  font-weight: bold;
  font-size: 13px;
  color: #fff;
  text-decoration: none;
  border: 1px solid #fff;
  border-radius: 4px;
  transition: opacity 0.2s ease-out; }
  .f-attention__button:hover {
    opacity: 0.5; }

/*--------------------------------
2.28 slick
--------------------------------*/
/* 写真スライダー */
.slick-arrow,
.slick-slide {
  cursor: pointer; }

/*new_osusumeplan_recomend 20200116 from NTA*/
div.f-card div.f-card__body div.f-card__inner a:hover {
  opacity: 0.5; }
div.f-card div.f-card__body div.f-card__inner p.side_tool_list_photo {
  width: 80px;
  height: 60px;
  display: block;
  float: left;
  padding: 10px; }
div.f-card div.f-card__body div.f-card__inner p.side_tool_list_photo a img {
  width: 100%;
  height: auto; }
div.f-card div.f-card__body div.f-card__inner div.side_tool_list_info {
  float: left;
  width: 200px;
  padding-top: 10px; }
div.f-card div.f-card__body div.f-card__inner div.side_tool_list_info div.side_tool_list_info_in {
  font-size: 11px;
  margin-bottom: 12px;
  height: 60px; }
div.f-card div.f-card__body div.f-card__inner div.side_tool_list_info div.side_tool_list_info_in p.title {
  margin-bottom: 2%; }
div.f-card div.f-card__body div.f-card__inner div.side_tool_list_info div.side_tool_list_info_in p.title a,
div.f-card div.f-card__body div.f-card__inner div.side_tool_list_info div.side_tool_list_info_in p.text {
  line-height: 1.3;
  /*text-decoration:none!important;*/
  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.f-card div.f-card__body div.f-card__inner div.side_tool_list_info div.side_tool_list_info_in p.text {
  margin: -40px 0 0; }
div.f-card div.f-card__body div.f-card__inner div.side_tool_list_info p.price {
  text-align: right; }
div.f-card div.f-card__body div.f-card__inner div.side_tool_list_info p.price span {
  font-weight: bold;
  color: #cc0d21; }

/*new_osusumeplan_recomend 20200116 from NTA*/
/*-----------
2.30 information 緊急文言、年末年始文言など
-----------*/
#attention_message {
  border: 2px solid red;
  margin: 3px 0;
  padding: 6px;
  color: red;
  font-size: 13px;
  margin-bottom: 20px; }

#attention_message span {
  font-weight: bold; }

/*-----------
2.31 map
-----------*/
#Map, #NTA_JR2_Map {
  position: relative;
  overflow: hidden;
  width: 300px;
  height: 211px;
  margin: 0;
  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.32 hotel 施設の説明
-------------------*/
.hotelDetailBody {
  padding-top: 15px;
  margin-bottom: 30px; }

.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;
  float: right; }

.hotelDetailBody .photos .photo {
  margin-bottom: 7px; }

table.detailTable {
  border: 1px solid #CCCCCC;
  margin-bottom: 15px; }

table.detailTable th {
  background: #efeeff;
  font-weight: normal;
  text-align: left;
  padding: 7px 10px;
  border: 1px solid #CCCCCC;
  white-space: nowrap; }

table.detailTable td {
  font-weight: normal;
  text-align: left;
  padding: 7px 10px;
  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: 2px 5px;
  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; }

/*# sourceMappingURL=dp-jr_common.css.map */
