@charset "UTF-8";
/* Scss Document */
/* 変数 */
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 */
html {
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/**
 * Remove default margin.
 */
body {
  margin: 0; }

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block; }

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */ }

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none; }

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent; }

/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted; }

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold; }

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic; }

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000; }

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%; }

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

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0; }

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  /*overflow: hidden;*/ }

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px; }

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0; }

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto; }

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em; }

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */ }

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible; }

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none; }

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */ }

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default; }

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal; }

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  box-sizing: content-box;
  /* 2 */ }

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto; }

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold; }

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

td,
th {
  padding: 0; }

html {
  font-size: 62.5%; }

html body {
  font-family: 'Arial', "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  color: #333;
  background-color: #FEFEFE;
  font-weight: 500;
  font-size: 1.6rem; }
  html body * {
    box-sizing: border-box; }

p, ul, ol, dl, table, pre {
  margin-bottom: 1.6rem;
  margin-top: 0; }

h1, h2, h3, h4, h5, h6 {
  font-weight: bold;
  margin-top: 1.6rem;
  margin-bottom: 1.6rem; }

h1 {
  font-size: 38.4px;
  font-size: 3.84rem;
  line-height: 1.15385; }

h2 {
  font-size: 32px;
  font-size: 3.2rem;
  line-height: 1.15385; }

h3 {
  font-size: 27.2px;
  font-size: 2.72rem;
  line-height: 1.25; }

h4 {
  font-size: 22.4px;
  font-size: 2.24rem; }

h5 {
  font-size: 19.2px;
  font-size: 1.92rem; }

h6 {
  font-size: 16px;
  font-size: 1.6rem; }

table {
  border-top: 1px solid gray;
  border-right: 1px solid gray;
  empty-cells: show;
  width: 100%;
  border-spacing: 0;
  margin: 0 auto 1em; }
  table caption {
    text-align: left; }
  table thead th {
    white-space: nowrap;
    background-color: #F4CD00;
    text-align: center; }
  table tbody th {
    white-space: nowrap;
    background-color: #FCFCF2;
    text-align: center; }
  table th, table td {
    border-bottom: 1px solid gray;
    border-left: 1px solid gray;
    padding: .5em; }
    table th ul.noformat,
    table th dl.noformat, table td ul.noformat,
    table td dl.noformat {
      margin: 0;
      padding: 0;
      list-style: none; }
    table th dl dt, table td dl dt {
      margin-top: 1.6rem; }
  table th {
    white-space: nowrap; }

table.sub {
  border: 0px none;
  font-size: 90%;
  border-collapse: separate;
  border-spacing: 1px; }
  table.sub thead th {
    background-color: transparent;
    color: #004EA2;
    border-bottom: 1px solid #004EA2; }
  table.sub th, table.sub td {
    border-bottom-style: dotted;
    border-left: 0px none; }

col.c3 {
  width: 40%; }

.bt {
  vertical-align: top; }

section {
  margin: 2em 1em 3em; }

.nodisp {
  display: none; }

.clear {
  clear: both; }

.clear-fix::after {
  content: "";
  display: block;
  clear: both; }

._u-pull-left {
  float: left; }

._u-pull-center {
  margin-left: auto;
  margin-right: auto;
  text-align: center; }

.sub {
  font-size: 80%; }

img[src$=".svg"] {
  margin-left: 2px;
  margin-right: 2px; }

img.s_resp[src$=".svg"] {
  width: 100%; }

img[src$="pdf.svg"] {
  width: 32px;
  height: 32px;
  max-width: 32px; }

img._u-pull-left {
  margin-right: .5em;
  margin-bottom: .5em; }

img._u-pull-right {
  margin-left: .5em;
  margin-bottom: .5em; }

img.f_center_img {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: .5em; }

img.full {
  width: 100%; }

img.thum {
  border-radius: 5px;
  width: 30%; }

._u_text_center {
  text-align: center; }
  ._u_text_center img {
    margin: 0 auto; }

._u_text_left {
  text-align: left; }

address img {
  display: none; }

a {
  transition: color .1s ease-out; }

a:link {
  color: darkblue; }

a:visited {
  color: purple; }

a:hover,
a:active {
  color: blue; }

a.btn-style {
  padding: 0;
  margin: .5em;
  text-align: center;
  border: 1px solid #dadada;
  color: #333;
  display: inline-block;
  line-height: 1.5;
  padding: .5em 1em;
  margin: 0 auto;
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  transition: background .2s ease-out; }
  a.btn-style.special {
    font-size: 120%;
    font-weight: bold; }
    a.btn-style.special:link, a.btn-style.special:visited {
      background-color: #F578C6; }
    a.btn-style.special:hover, a.btn-style.special:active {
      background-color: #F549BF; }
  a.btn-style:before {
    content: "≪";
    font-size: 70%; }
  a.btn-style:after {
    content: "≫";
    font-size: 70%; }
  a.btn-style:link, a.btn-style:visited {
    background-color: #FEFBFC; }
  a.btn-style:hover, a.btn-style:active {
    background-color: beige; }
  a.btn-style img {
    vertical-align: middle; }
  a.btn-style.block-btn {
    display: block; }

a.h_btn-style {
  padding: .3em 1em;
  border: 1px solid #ccc;
  background: #f1e767;
  background: -webkit-gradient(linear, left top, left bottom, from(#fdfbfb), to(#ebedee));
  background: -webkit-linear-gradient(top, #fdfbfb 0%, #ebedee 100%);
  background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
  -webkit-box-shadow: inset 1px 1px 1px #fff;
  box-shadow: inset 1px 1px 1px #fff;
  color: #212529;
  border-radius: 0.5rem;
  text-decoration: none; }
  a.h_btn-style:hover, a.h_btn-style:active {
    background: -webkit-gradient(linear, left bottom, left top, from(#fdfbfb), to(#ebedee));
    background: -webkit-linear-gradient(bottom, #fdfbfb 0%, #ebedee 100%);
    background: linear-gradient(to top, #fdfbfb 0%, #ebedee 100%);
    text-decoration: underline; }

ul.index,
dl.index {
  display: inline-flex;
  flex-wrap: wrap;
  margin: 0;
  margin-bottom: 1em;
  padding: 0;
  list-style: none; }
  ul.index:last-child,
  dl.index:last-child {
    margin-bottom: 0; }
  ul.index dt,
  dl.index dt {
    flex-basis: 100%; }
  ul.index li, ul.index dd,
  dl.index li,
  dl.index dd {
    white-space: nowrap;
    margin-left: 1em; }
    ul.index li:before, ul.index dd:before,
    dl.index li:before,
    dl.index dd:before {
      content: "> "; }
    ul.index li:hover, ul.index li:active, ul.index dd:hover, ul.index dd:active,
    dl.index li:hover,
    dl.index li:active,
    dl.index dd:hover,
    dl.index dd:active {
      text-decoration: none; }

ul.index.nolist li:before {
  content: none; }

.page_top {
  position: fixed !important;
  bottom: 5px;
  right: -200px;
  z-index: 2000; }
  .page_top a {
    display: block;
    padding: 10px;
    background-color: #000000;
    background: rgba(0, 0, 0, 0.8);
    color: #FFFFFF !important;
    border-radius: 5px;
    border: 0 none;
    font-size: 80%;
    transition: all .2s ease-out; }
    .page_top a:link, .page_top a:visited {
      color: #FFFFFF !important; }
    .page_top a:hover {
      text-decoration: none;
      color: #FFFFFF !important;
      text-shadow: 0 0 5px #fff, 0 0 15px #3C6CD0, 0 0 20px #5EB2FF, 0 0 25px #5EB2FF, 0 0 30px #5EB2FF;
      background: rgba(0, 0, 0, 0.8); }
    .page_top a:active {
      color: #FFFFFF !important; }

#wrap_header {
  width: 100%; }
  #wrap_header header {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    padding: 0 1em; }
    #wrap_header header #logo {
      margin: 0;
      margin-top: .5em;
      padding: 0; }
      #wrap_header header #logo img {
        width: 40%; }
    #wrap_header header .sub_text {
      font-size: 80%;
      margin: 0;
      padding: 0;
      margin-bottom: 1em; }
    #wrap_header header #h_btn {
      text-align: right;
      position: absolute;
      right: 3em;
      top: 1em; }
      #wrap_header header #h_btn li {
        list-style: none;
        display: inline-block; }
        #wrap_header header #h_btn li a {
          padding: .3em 1em;
          border: 1px solid #ccc;
          background: #f1e767;
          background: -webkit-gradient(linear, left top, left bottom, from(#fdfbfb), to(#ebedee));
          background: -webkit-linear-gradient(top, #fdfbfb 0%, #ebedee 100%);
          background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
          -webkit-box-shadow: inset 1px 1px 1px #fff;
          box-shadow: inset 1px 1px 1px #fff;
          color: #212529;
          border-radius: 0.5rem;
          text-decoration: none; }
          #wrap_header header #h_btn li a:hover {
            background: -webkit-gradient(linear, left bottom, left top, from(#fdfbfb), to(#ebedee));
            background: -webkit-linear-gradient(bottom, #fdfbfb 0%, #ebedee 100%);
            background: linear-gradient(to top, #fdfbfb 0%, #ebedee 100%);
            text-decoration: underline; }
        #wrap_header header #h_btn li.exit a {
          color: #000000;
          background-color: #DDDDDD;
          pointer-events: none;
          cursor: default;
          text-decoration: none;
          color: white; }

#home #catch {
  background-color: transparent; }

#catch {
  position: relative;
  background-color: #F4CD00; }
  #catch #catch_tit {
    position: absolute;
    z-index: 1000;
    left: 1em;
    top: 15%;
    width: 28%; }
    #catch #catch_tit img {
      width: 100%; }
  #catch #catch_img {
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    max-width: 100%;
    height: auto;
    position: relative;
    z-index: 10; }
  #catch h1 {
    text-align: center;
    margin: 0;
    padding: 1em; }

#catch_btn {
  top: 0.5em;
  right: 1em; }

.seminar #catch_btn {
  display: none; }

#home #catch_btn {
  bottom: 1em;
  margin: 0 auto;
  padding: 0;
  top: auto;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  width: 80%;
  max-width: 1000px; }
  #home #catch_btn li {
    flex: 1 0 40%;
    margin: 0 5%;
    padding: 0;
    max-width: 400px;
    height: auto;
    max-height: 200px; }
    #home #catch_btn li a {
      width: 100%;
      font-size: 150%;
      padding: 0 0 40%;
      text-align: left;
      border-width: 3px;
      background-position: center center;
      background-repeat: no-repeat;
      background-size: cover;
      font-weight: bold;
      position: relative;
      border-color: #F4CD00;
      text-shadow: 1px 1px 0 #F4CD00, -1px -1px 0 #F4CD00, -1px 1px 0 #F4CD00, 1px -1px 0 #F4CD00, 0px 1px 0 #F4CD00, -1px 0 #F4CD00, -1px 0 0 #F4CD00, 1px 0 0 #F4CD00; }
      #home #catch_btn li a span {
        display: block;
        position: absolute;
        background-color: rgba(244, 205, 0, 0.7);
        top: 0;
        left: 0;
        padding-left: .5em;
        width: 100%;
        color: 333; }
      #home #catch_btn li a:link, #home #catch_btn li a:visited {
        text-decoration: underline; }
        #home #catch_btn li a:link span, #home #catch_btn li a:visited span {
          color: #333; }
      #home #catch_btn li a:hover, #home #catch_btn li a:active {
        text-decoration: none; }
        #home #catch_btn li a:hover span, #home #catch_btn li a:active span {
          color: #333; }
    #home #catch_btn li.internship_btn a {
      background-image: url("../general_st/image/internship.jpg"); }
    #home #catch_btn li.movie_btn a {
      background-image: url("../general_st/image/seminar_movie.jpg"); }
    #home #catch_btn li.seminar_btn a {
      background-image: url("../general_st/image/seminar2.jpg");
      text-shadow: 1px 1px 0 #E52998, -1px -1px 0 #E52998, -1px 1px 0 #E52998, 1px -1px 0 #E52998, 0px 1px 0 #E52998, -1px 0 #E52998, -1px 0 0 #E52998, 1px 0 0 #E52998; }
      #home #catch_btn li.seminar_btn a span {
        background-color: rgba(229, 41, 152, 0.7);
        color: white; }
      #home #catch_btn li.seminar_btn a:link, #home #catch_btn li.seminar_btn a:visited {
        border-color: #E52998; }
      #home #catch_btn li.seminar_btn a:hover, #home #catch_btn li.seminar_btn a:active {
        border-color: #E52998; }

#catch_btn {
  position: absolute;
  z-index: 800;
  text-align: center; }
  #catch_btn li {
    list-style: none;
    margin: .5em auto .5em; }
    #catch_btn li a {
      display: block;
      padding: .3em 1em;
      border: 1px solid #ccc;
      background: #f1e767;
      background: -webkit-gradient(linear, left top, left bottom, from(#fdfbfb), to(#ebedee));
      background: -webkit-linear-gradient(top, #fdfbfb 0%, #ebedee 100%);
      background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
      -webkit-box-shadow: inset 1px 1px 1px #fff;
      box-shadow: inset 1px 1px 1px #fff;
      color: #212529;
      border-radius: 0.5rem;
      text-decoration: none; }
      #catch_btn li a:hover {
        background: -webkit-gradient(linear, left bottom, left top, from(#fdfbfb), to(#ebedee));
        background: -webkit-linear-gradient(bottom, #fdfbfb 0%, #ebedee 100%);
        background: linear-gradient(to top, #fdfbfb 0%, #ebedee 100%);
        text-decoration: underline; }

#pan_list {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  font-size: 80%; }
  #pan_list ul {
    list-style: none; }
    #pan_list ul li {
      display: inline; }
    #pan_list ul li:nth-child(n+2)::before {
      content: ">"; }

.desc {
  display: none; }

.sub_btn {
  margin: 1px 0 2em;
  padding: 0;
  list-style: none;
  width: calc(100% - 2px);
  display: flex; }
  .sub_btn li {
    flex: 1 0 16.6%;
    margin: 0;
    position: relative;
    border-right: 1px solid #BD8C21;
    box-sizing: border-box; }
    .sub_btn li:last-child {
      border-right: 0px none; }
    .sub_btn li a {
      display: block;
      font-size: 80%;
      color: #333;
      text-align: center;
      padding: .5em .5em; }
      .sub_btn li a:link, .sub_btn li a:visited {
        background-color: #F5F8F5;
        text-decoration: none; }
      .sub_btn li a:hover, .sub_btn li a:active {
        background-color: beige;
        text-decoration: underline; }
      .sub_btn li a::before {
        content: "≫"; }

.company .sub_btn li.company a:link,
.company .sub_btn li.company a:visited,
.business .sub_btn li.business a:link,
.business .sub_btn li.business a:visited,
.seminar .sub_btn li.seminar a:link,
.seminar .sub_btn li.seminar a:visited,
.recruit .sub_btn li.recruit a:link,
.recruit .sub_btn li.recruit a:visited,
.flow .sub_btn li.flow a:link,
.flow .sub_btn li.flow a:visited,
.welfare .sub_btn li.welfare a:link,
.welfare .sub_btn li.welfare a:visited {
  background-color: beige;
  text-decoration: underline; }

#home .sub_btn {
  display: none; }

#home #main {
  width: 80%;
  margin-top: 2em; }
  #home #main .main_btn li {
    flex: 1 0 44%;
    margin: 0 3% 1em; }
  #home #main #contents {
    width: 100%; }

#main {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto 2em; }
  #main .main_btn {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0;
    margin-top: 3em;
    padding: 0; }
    #main .main_btn li {
      list-style: none;
      margin-bottom: 1em;
      flex: 1 0 44%;
      margin: 0 2% 1em;
      /*&.concept_btn a {
      	background-image: url("../general_st/image/concept_btn.png");
      }
      &.business_btn a,
      &.flow_btn a,
      &.seminar_btn a {
      	background-image: url("../general_st/image/business_btn.png");
      }
      &.application_btn a {
      	background-image: url("../general_st/image/application_btn.png");
      }
      &.sanatorium_btn a {
      	background-image: url("../general_st/image/sanatorium_btn.png");
      }*/
      /*a::after {
      	content: "";
      	display: block;
      	clear: both;
      }*/ }
      #main .main_btn li a {
        display: block;
        color: #333;
        font-weight: bold;
        text-decoration: none;
        width: 100%;
        /*background-repeat: no-repeat;
        background-position: left center;
        background-size: cover;*/
        padding: 0;
        text-align: center;
        /*img {
        	width: 30%;
        	max-width: 30%;
        	height: auto;
        	margin-right: 1em;
        	display: block;
        	float: left;
        }*/ }
        #main .main_btn li a section {
          padding: 0;
          margin: 0; }
          #main .main_btn li a section::after {
            content: "";
            display: block;
            clear: both; }
        #main .main_btn li a h2.naviline {
          margin: 0;
          margin-bottom: 1em;
          padding: .5em;
          font-size: 100%;
          background-color: azure; }
        #main .main_btn li a p {
          text-align: left;
          font-weight: normal; }
        #main .main_btn li a p.l_btn {
          padding: .3em 1em;
          border: 1px solid #ccc;
          box-shadow: inset 1px 1px 1px #fff;
          color: #212529;
          font-weight: bold;
          border-radius: 0.5rem;
          text-align: center;
          width: 9em;
          float: right;
          margin-right: 1em; }
          #main .main_btn li a p.l_btn::before {
            content: "≫"; }
        #main .main_btn li a:link, #main .main_btn li a:visited {
          background-color: #FEFBFC; }
        #main .main_btn li a:hover p.l_btn, #main .main_btn li a:active p.l_btn {
          background-color: beige; }
  #main #contents {
    width: 100%;
    max-width: 960px;
    margin: 0 auto; }
    #main #contents h2 {
      text-align: center; }
      #main #contents h2::after {
        content: "";
        display: block;
        margin: .5em auto 1em;
        height: 1px;
        width: 60%;
        background: -webkit-gradient(linear, left top, right bottom, from(#F7931E), to(#FF0));
        background: -moz-linear-gradient(left, #F7931E, #FF0);
        background: linear-gradient(left, #F7931E, #FF0); }
    #main #contents h3 {
      background-color: #EBEBEB;
      padding: .3em;
      border-radius: 3px; }

#wrap_footer {
  border-top: 3px solid #F4CD00;
  width: 100%; }
  #wrap_footer footer {
    width: 100%;
    max-width: 1200px;
    margin: 1em auto;
    padding: 0 1em;
    font-size: 90%; }
    #wrap_footer footer .recnavi2021 {
      float: right;
      border: 1px solid #CCC; }
    #wrap_footer footer .mynavi2021,
    #wrap_footer footer .mynavi2022,
    #wrap_footer footer .mynavi2023 {
      float: right;
      margin-right: 1em; }

.sanatorium_img img {
  width: auto;
  height: auto;
  max-height: 180px;
  margin-right: 1em;
  position: relative; }

.evaluation {
  display: flex;
  flex-direction: row-reverse;
  justify-content: center; }

.evaluation input[type='radio'] {
  display: none; }

.evaluation label {
  position: relative;
  padding: 10px 10px 0;
  color: gray;
  cursor: pointer;
  font-size: 45px; }

.evaluation label .text {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  text-align: center;
  font-size: 12px;
  color: gray; }

.evaluation label:hover,
.evaluation label:hover ~ label,
.evaluation input[type='radio']:checked ~ label {
  color: #ffcc00; }

.hide {
  display: none; }

.s_block {
  padding: 1em;
  margin-bottom: 0;
  margin-top: 0; }

.s_block:not(:last-child)::after {
  content: url("../general_st/image/s_arrow.svg");
  display: block;
  width: 40%;
  margin: 1em auto 0; }

.s_headline {
  font-size: 150%;
  background-color: #FEFFDA;
  display: inline-block; }

.s_headline::before {
  content: "【"; }

.s_headline::after {
  content: "】"; }

.s_day {
  width: 8em; }

.s_term {
  width: 8em; }

@media print {
  #h_btn,
  #catch_btn,
  .main_btn {
    display: none !important; }

  #home .main_btn {
    display: block !important; }

  #catch h1 {
    padding-top: 0;
    padding-bottom: 0; } }
@media screen and (max-width: 980px) {
  #main .main_btn li {
    flex: 1 0 44%;
    margin: 0 3% 1em; } }
@media screen and (max-width: 780px) {
  #home #catch_btn li a {
    font-size: 100%; } }
@media screen and (max-width: 640px) {
  .sub_btn {
    flex-wrap: wrap; }
    .sub_btn li {
      flex: 1 0 33%;
      margin: 0; }
      .sub_btn li:nth-child(3) {
        border-right: 0px none; }
      .sub_btn li:nth-child(4), .sub_btn li:nth-child(5), .sub_btn li:nth-child(6) {
        border-top: 1px solid #BD8C21; }

  #main .main_btn li {
    flex: 1 0 94%;
    margin: 0 3% 1em; }

  .sanatorium_img img {
    display: block;
    margin: 0 auto 1em;
    width: 100%;
    max-width: 100%;
    height: auto;
    max-height: none; }

  #home #catch_btn li a span {
    position: static; }

  .s_day {
    width: inherit; }

  .s_term {
    width: inherit; } }
@media screen and (max-width: 600px) {
  #wrap_header header .sub_text {
    margin-bottom: 0; }
  #wrap_header header #h_btn {
    position: static;
    display: flex;
    justify-content: center;
    margin: 0;
    margin-top: .5em;
    padding: 0;
    width: 100%;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto; }
    #wrap_header header #h_btn li {
      flex: 1 0 44%;
      margin: 0 3% 1em;
      text-align: center; }
      #wrap_header header #h_btn li a {
        padding-left: .5em;
        padding-right: .5em; }

  #home #catch_btn {
    padding-left: 0;
    padding-right: 0; }

  #catch_btn {
    position: static;
    display: flex;
    justify-content: center;
    padding: 0; }
    #catch_btn li {
      flex: 1 0 44%;
      margin: 0 3% 1em; }
      #catch_btn li a {
        padding-left: .5em;
        padding-right: .5em; }

  #wrap_footer footer .recnavi2021 {
    float: none;
    margin: 1em auto;
    text-align: center;
    display: block;
    border: 0px none; }
    #wrap_footer footer .recnavi2021 img {
      border: 1px solid #CCC; }
  #wrap_footer footer .mynavi2021 {
    float: none;
    margin: 1em auto;
    text-align: center;
    display: block;
    border: 0px none; } }
@media screen and (max-width: 540px) {
  #home #catch_btn {
    width: 100%; } }
@media screen and (max-width: 500px) {
  #main .main_btn li a {
    background-image: none !important;
    padding: .5em;
    text-align: center; }

  ul.index li, ul.index dd,
  dl.index li,
  dl.index dd {
    white-space: normal; }

  table thead th,
  table tbody th {
    white-space: normal; }
  table .recnavi2021 {
    width: 100%;
    max-width: 240px;
    height: auto; }
  table .mynavi2021,
  table .mynavi2022,
  table .mynavi2023 {
    width: 100%;
    max-width: 240px;
    height: auto; } }
@media screen and (max-width: 420px) {
  #wrap_header header #logo {
    text-align: center; }
    #wrap_header header #logo img {
      width: 80%; }

  #home #catch_btn {
    display: block;
    position: static; }
    #home #catch_btn li {
      width: 80%;
      margin: .5em auto .5em; } }
/* SSLフォーム用 */
#main.ssl dl {
  margin: 0;
  padding: 0;
  border-bottom: 1px solid lightgray;
  margin-bottom: 1em;
  padding-bottom: .5em; }
  #main.ssl dl dt, #main.ssl dl dd {
    margin: 0;
    padding: .3em; }
  #main.ssl dl dt span {
    font-size: 80%;
    color: darkred; }
#main.ssl > dl:last-child,
#main.ssl > label:last-child > dl,
#main.ssl fieldset > dl:last-child,
#main.ssl fieldset > label:last-child dl {
  margin-bottom: 0;
  border-bottom: 0px none; }
#main.ssl form input[type="text"], #main.ssl form select, #main.ssl form textarea {
  width: 100%;
  padding: .3em;
  border-radius: 3px;
  margin-bottom: .3em; }
#main.ssl form input[type="submit"] {
  margin: 0 auto;
  padding: 1em 2em;
  display: block;
  font-size: 120%;
  margin-bottom: 2em; }
#main.ssl form fieldset {
  margin-bottom: 2em;
  padding: 1em; }
  #main.ssl form fieldset input[type="submit"] {
    margin-bottom: 0; }
#main.ssl form label {
  cursor: pointer; }
#main.ssl form .index li:before {
  content: ""; }

.relat {
  padding-right: 2em;
  position: relative; }

.required,
.nonrequired {
  background-color: #FF3333;
  border-radius: 3px;
  bottom: 3px;
  color: #FFFFFF;
  display: block;
  font-size: 70%;
  line-height: 1.2;
  padding: 2px;
  position: absolute;
  right: 0; }

legend span {
  color: darkred;
  font-size: 80%;
  font-weight: bold; }

#privacy_box {
  border: 1px solid #CCCCCC;
  box-sizing: border-box;
  font-size: 80%;
  height: 15em;
  line-height: 1.3;
  margin-bottom: 20px;
  overflow: auto;
  padding: 10px; }
  #privacy_box section:last-child {
    margin-bottom: 0; }
    #privacy_box section:last-child p:last-child {
      margin-bottom: 0; }

#p_info_check {
  background-color: #FFFFFF;
  border: 1px solid #999999;
  position: relative; }

#consent_box {
  text-align: center;
  margin: 0;
  background-color: antiquewhite; }
  #consent_box label {
    display: block;
    width: 100%;
    height: 100%;
    padding: .5em 0; }
  #consent_box .formErrorContent {
    margin: 0 auto; }

.error {
  border: 1px dotted #F66;
  background-color: #FFE6F4;
  padding: 2px;
  margin-bottom: 20px; }
  .error p {
    margin: .3em 1em; }

@media screen and (min-width: 640px) {
  #main.ssl {
    padding: 1em; }
    #main.ssl h1 {
      padding: 1em;
      font-size: 4rem;
      color: white; }
      #main.ssl h1 span {
        font-size: 2.5rem; }
    #main.ssl dl {
      display: flex; }
      #main.ssl dl dt {
        flex: 1;
        min-width: 11em;
        margin-top: .3em; }
      #main.ssl dl dd {
        flex: 3; }
      #main.ssl dl dd.faddress {
        display: flex;
        flex-wrap: nowrap; }
        #main.ssl dl dd.faddress #addnum,
        #main.ssl dl dd.faddress #r_addnum {
          flex: 1;
          min-width: 6em;
          margin-left: .5em;
          margin-right: .5em; }
        #main.ssl dl dd.faddress #addken {
          flex: 4; }
      #main.ssl dl dd.fbirth {
        display: flex;
        flex-wrap: nowrap;
        justify-content: flex-start; }
        #main.ssl dl dd.fbirth label {
          display: block;
          flex: 1;
          max-width: 6em; }
          #main.ssl dl dd.fbirth label #byear, #main.ssl dl dd.fbirth label #bmonth, #main.ssl dl dd.fbirth label #bday,
          #main.ssl dl dd.fbirth label #month_1st, #main.ssl dl dd.fbirth label #day_1st,
          #main.ssl dl dd.fbirth label #month_2nd, #main.ssl dl dd.fbirth label #day_2nd,
          #main.ssl dl dd.fbirth label #month_3rd, #main.ssl dl dd.fbirth label #day_3rd {
            max-width: 5em; }
      #main.ssl dl dd.funi {
        display: flex;
        flex-wrap: nowrap; }
        #main.ssl dl dd.funi .un {
          flex: 3; }
        #main.ssl dl dd.funi .uy {
          flex: 1;
          margin-left: .5em;
          min-width: 8em; }
          #main.ssl dl dd.funi .uy #uniyear {
            min-width: 5em;
            width: calc(100% - 3em); } }
@media screen and (max-width: 639px) {
  #main.ssl {
    padding: 0; }
    #main.ssl h1 {
      padding: .5em;
      font-size: 3rem;
      color: white; }
      #main.ssl h1 span {
        font-size: 2rem; }
    #main.ssl dl dt br {
      display: none; }
    #main.ssl dl dd.faddress #addnum,
    #main.ssl dl dd.faddress #r_addnum {
      max-width: calc(100% - 1em);
      width: 6em; }
    #main.ssl dl dd.fbirth input {
      width: calc(100% - 1em); }
    #main.ssl dl dd.funi #uniyear {
      width: calc(100% - 3em); }

  .s_block:not(:last-child)::after {
    width: 80%; } }
.sp {
  border: 5px solid #C3C3C3;
  padding: .5em 1em; }

.emps a {
  display: block;
  width: 100%;
  height: 100%;
  padding: .5em;
  border-width: 5px;
  border-style: solid;
  color: darkred;
  transition: all .1s ease-out;
  text-decoration: none;
  color: #333; }
.emps a:link,
.emps a:visited {
  border-color: lightsalmon; }
.emps a:hover,
.emps a:active {
  border-color: chocolate; }

.t_emps {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 6000;
  text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF, -1px 1px 0 #FFF, 1px -1px 0 #FFF, 0px 1px 0 #FFF, -1px 0 #FFF, -1px 0 0 #FFF, 1px 0 0 #FFF; }

.exp {
  margin-top: 3em;
  border: 5px solid #FFA600;
  background-color: beige;
  padding: 1em; }

.ebtn {
  width: auto;
  display: inline-block;
  vertical-align: middle;
  margin: 0 auto; }

.b1 {
  margin-left: 1em; }
  .b1 img {
    border: 1px solid #8A8A8A; }

.pbtn {
  margin: 0 auto;
  /*display: inline-block;*/
  text-align: center; }
  .pbtn a {
    padding: .3em 1em;
    border: 1px solid #CCCCCC;
    background-color: white; }

.movie-wrap {
  text-align: center;
  margin: 0 auto 1em;
  position: relative;
  padding-bottom: 69.23%;
  height: 0;
  overflow: hidden; }
  .movie-wrap .iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

.espes a {
  font-size: 150%;
  border-width: 5px;
  border-style: solid;
  display: block;
  width: 100%;
  height: 100%;
  text-align: center;
  padding: 1em;
  text-decoration: none; }
  .espes a:link, .espes a:visited {
    border-color: #F4CD00;
    text-decoration: underline;
    background-color: beige; }
  .espes a:hover, .espes a:active {
    border-color: #F7D700;
    text-decoration: none;
    background-color: #FAFFAF; }

.espes2 a {
  font-size: 120%;
  border-width: 5px;
  border-style: solid;
  display: block;
  width: 100%;
  height: 100%;
  text-align: center;
  padding: 1em;
  text-decoration: none; }
  .espes2 a:link, .espes2 a:visited {
    color: #333;
    border-color: #CCCCCC;
    text-decoration: underline;
    background-color: white; }
  .espes2 a:hover, .espes2 a:active {
    color: #333;
    border-color: #CCCCCC;
    text-decoration: none;
    background-color: white; }
  .espes2 a h2 {
    margin-top: 0;
    margin-bottom: 0;
    background: none; }
  .espes2 a p {
    margin: 0 auto; }

#main #contents .espes2 a h2::after {
  margin: .5em auto;
  padding: 0; }

.top_n {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0; }
  .top_n li {
    flex: 0 1 48%;
    margin: 0 1%;
    padding: 0; }
    .top_n li a {
      box-sizing: border-box;
      display: block;
      width: 100%;
      font-size: 120%;
      text-align: center;
      border-width: 5px;
      border-style: solid;
      padding: .5em 0; }
      .top_n li a:link, .top_n li a:visited {
        border-color: #F4CD00;
        text-decoration: underline;
        background-color: beige; }
      .top_n li a:hover, .top_n li a:active {
        border-color: #F7D700;
        text-decoration: none;
        background-color: #FAFFAF; }

.officer_list dl,
.officer_list dt,
.officer_list dd {
  margin: 0;
  padding: 0; }
.officer_list dl {
  display: flex; }
.officer_list dt {
  padding-right: 0.5em;
  flex: 1; }
.officer_list dd {
  flex: 3; }

.ph_num dt {
  margin-top: 0; }
