@charset "UTF-8";
/*! destyle.css v3.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400&display=swap");
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0; }

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -webkit-tap-highlight-color: transparent;
  /* 3*/ }

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

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

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0; }

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0; }

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none; }

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold; }

dd {
  margin-left: 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 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit; }

/**
 * 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: inherit;
  /* 2 */ }

address {
  font-style: inherit; }

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

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  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: inherit;
  /* 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; }

/* Replaced content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
svg,
img,
embed,
object,
iframe {
  vertical-align: bottom; }

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  /* 1 */
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
  /* 2 */ }

/**
 * Reset radio and checkbox appearance to preserve their look in iOS.
 */
[type="checkbox"] {
  -webkit-appearance: checkbox;
  appearance: checkbox; }

[type="radio"] {
  -webkit-appearance: radio;
  appearance: radio; }

/**
 * Correct cursors for clickable elements.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  cursor: pointer; }

button:disabled,
[type="button"]:disabled,
[type="reset"]:disabled,
[type="submit"]:disabled {
  cursor: default; }

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:-moz-focusring {
  outline: auto; }

select:disabled {
  opacity: inherit; }

/**
 * Remove padding
 */
option {
  padding: 0; }

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0; }

legend {
  padding: 0; }

/**
 * 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; }

/**
 * 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 outline style in Safari.
 */
[type="search"] {
  outline-offset: -2px;
  /* 1 */ }

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

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

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer; }

/* 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; }

/*
 * Remove outline for editable content.
 */
[contenteditable]:focus {
  outline: auto; }

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table {
  border-color: inherit;
  /* 1 */ }

caption {
  text-align: left; }

td,
th {
  vertical-align: top;
  padding: 0; }

th {
  text-align: left;
  font-weight: bold; }

@media print {
  body,
  .content-wrapper {
    width: 1000px;
    max-width: 100%; } }
body,
html {
  width: 100%;
  height: 100%;
  position: relative; }

html {
  font-size: 17px; }
  @media screen and (max-width: 960px) {
    html {
      font-size: 14px; } }

body {
  margin: 0;
  font-size: 1rem; }

body#en {
  font-family: Roboto, "Segoe UI", "Helvetica Neue", sans-serif; }

body#cn {
  font-family: "Noto Sans SC", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif; }

body#tw {
  font-family: "Noto Sans TC", "PingFang TC", "Hiragino Sans CNS", "Microsoft JhengHei", sans-serif; }

body#ko {
  font-family: "Noto Sans KR", "Apple SD Gothic Neo", Gulim, "Malgun Gothic", sans-serif; }

.fw300 {
  font-weight: 300; }

.fw400 {
  font-weight: 400; }

.fw500 {
  font-weight: 500; }

.fw600 {
  font-weight: 600; }

.fw700 {
  font-weight: 700; }

.container {
  display: block;
  max-width: 100%;
  margin: 0 auto;
  overflow: hidden; }

p, div, ul, li, dl, dt, dd, em, i {
  padding: 0;
  margin: 0; }

ul li {
  list-style: none; }

dl dt {
  font-weight: normal; }

a {
  transition: background-color .3s linear;
  outline: none; }
  a:hover, a:focus, a:active {
    text-decoration: none;
    outline: none; }
  @media screen and (max-width: 960px) {
    a {
      transition: none;
      transition: 0; } }

h1,
h2,
h3,
h4,
h5,
h6 {
  padding: 0;
  margin: 0;
  font-weight: inherit; }

#loadingWrap {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.9);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100000; }

#loading {
  width: 3rem;
  height: 3rem;
  border-top: 0.5em solid rgba(255, 255, 255, 0.3);
  border-right: 0.5em solid rgba(255, 255, 255, 0.3);
  border-bottom: 0.5em solid rgba(255, 255, 255, 0.3);
  border-left: 0.5em solid rgba(255, 255, 255, 0);
  animation: loaderAnime 1s infinite linear;
  border-radius: 50%;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  z-index: 200000; }

@keyframes loaderAnime {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(360deg); } }
.loadingNone {
  animation: loadingAnime 1s forwards;
  display: none; }

@keyframes loadingAnime {
  0% {
    opacity: 1; }
  99% {
    opacity: 0; }
  100% {
    opacity: 0;
    display: none; } }
select,
input,
textarea {
  display: block;
  width: 100%;
  padding: 8px 10px;
  font-size: 14px;
  line-height: 1.42857143;
  color: #555555;
  background-color: #ffffff;
  background-image: none;
  border: 1px solid #cccccc;
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s; }

.form-select {
  width: 100%;
  display: block;
  position: relative;
  margin: 0 !important; }

.form-input {
  max-width: 100%;
  display: inline-block;
  position: relative; }

.full {
  width: 100%; }

.half {
  width: 50%; }
  @media screen and (max-width: 960px) {
    .half {
      width: 100%; } }

.one-third {
  width: 30%; }
  @media screen and (max-width: 960px) {
    .one-third {
      width: 100%; } }

.two-third {
  width: 60%; }
  @media screen and (max-width: 960px) {
    .two-third {
      width: 100%; } }

.minimal {
  width: 4em; }

.form-select::before,
.form-select::after {
  content: "";
  width: 0;
  height: 0;
  display: block;
  position: absolute;
  right: 8px;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  z-index: 9999; }

.form-select::before {
  border-top-color: #999;
  top: 45%; }

/*.form-select::after {
    border-bottom:5px solid #999;
    top:6px;
}*/
.form-wrap p {
  display: inline-block;
  padding-left: 0.8rem;
  margin: 0.2rem auto;
  position: relative; }
.form-wrap .table {
  display: table;
  color: inherit;
  width: 100%;
  table-layout: auto; }
  @media screen and (max-width: 960px) {
    .form-wrap .table {
      display: block; } }
  .form-wrap .table .form-group {
    display: table-row; }
    @media screen and (max-width: 960px) {
      .form-wrap .table .form-group {
        display: block; } }
    .form-wrap .table .form-group > div {
      display: table-cell;
      vertical-align: top;
      padding: 0.8rem 1rem; }
      @media screen and (max-width: 960px) {
        .form-wrap .table .form-group > div {
          padding: 0 0 1em 0;
          display: block; } }
      .form-wrap .table .form-group > div .child {
        margin: 0;
        padding: 0;
        display: block; }
        .form-wrap .table .form-group > div .child input {
          background-color: #EEE; }
          .form-wrap .table .form-group > div .child input::placeholder {
            color: #000000;
            opacity: 1; }
      .form-wrap .table .form-group > div.label1 {
        width: 12em; }
        @media screen and (max-width: 960px) {
          .form-wrap .table .form-group > div.label1 {
            width: 100%;
            padding-bottom: 0.3em !important; } }
        .form-wrap .table .form-group > div.label1 label {
          display: inline-block; }
      .form-wrap .table .form-group > div.label2 {
        width: 3em;
        padding: 0.8rem 1rem 0.8rem 0; }
      .form-wrap .table .form-group > div.right {
        text-align: right; }
    .form-wrap .table .form-group span {
      vertical-align: middle;
      display: inline-block;
      color: #FFF;
      font-weight: 500;
      font-size: 0.7rem;
      padding: 0 0.5rem;
      margin: 0 0.5rem 0.2rem 0; }
      .form-wrap .table .form-group span.red {
        background-color: #BA3333; }
      .form-wrap .table .form-group span.gray {
        background-color: #707070; }

/* チェックボックス */
input[type=checkbox] {
  display: none; }

.checkbox {
  cursor: pointer;
  display: inline-block;
  padding: 0 20px 0 32px;
  margin: 5px 0;
  position: relative;
  line-height: 1.8; }

.checkbox::before {
  content: '';
  display: block;
  height: 25px;
  width: 25px;
  left: 0;
  position: absolute;
  background-color: #ffffff;
  border: 1px solid #cccccc;
  border-radius: 4px;
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s; }

.checkbox::after {
  border-right: 3px solid red;
  border-bottom: 3px solid red;
  content: '';
  display: block;
  height: 14px;
  width: 8px;
  left: 9px;
  opacity: 0;
  position: absolute;
  top: 4px;
  transform: rotate(45deg); }

input[type=checkbox]:checked + .checkbox::after {
  opacity: 1; }

/* ラジオボタン */
input[type=radio] {
  display: none; }

.radio {
  cursor: pointer;
  display: inline-block;
  position: relative;
  padding: 0 10px 0 30px;
  margin: 5px 0;
  position: relative;
  line-height: 1.8; }

.radio::before {
  background: #fff;
  border: 1px solid #cccccc;
  border-radius: 50%;
  content: '';
  display: block;
  height: 22px;
  width: 22px;
  position: absolute;
  left: 0;
  top: 4px; }

.radio::after {
  background: #CBBB55;
  border-radius: 50%;
  content: '';
  display: block;
  height: 12px;
  width: 12px;
  position: absolute;
  left: 5px;
  top: 9px;
  opacity: 0; }

input[type=radio]:checked + .radio::after {
  opacity: 1; }

.btn_wrap {
  display: block;
  width: 100%;
  text-align: center;
  margin-top: 2rem; }

button.btn {
  display: block;
  background-color: white;
  border: 1px solid #CCC;
  padding: 0.8em;
  width: 15em;
  text-align: center;
  max-width: 100%;
  margin: auto;
  margin-top: 2em;
  border-radius: 5px;
  font-size: 1rem;
  color: #666;
  transition: 1s; }
  button.btn:hover, button.btn:focus {
    color: #000; }
  button.btn.large {
    padding: 1em;
    width: 25em;
    font-size: 1.1em; }
  button.btn.style1 {
    display: inline-block;
    text-align: center;
    color: #FFF;
    background: #CBBB55;
    font-weight: 600;
    font-size: 1rem;
    max-width: 100%;
    width: auto;
    margin: 0;
    border: 2px solid #CBBB55;
    padding: 0.3em 1em;
    box-sizing: border-box;
    position: relative; }
    button.btn.style1:hover {
      background-color: #FFF;
      color: #CBBB55; }

/*===================================
//ローディング
===================================*/
#loading2 {
  position: fixed;
  width: 100%;
  height: 100%;
  background: #000;
  z-index: 999999;
  text-align: center; }

.loading-logo {
  display: block;
  position: absolute;
  margin: auto; }

.loading-logo img {
  width: 100%; }

.aka {
  position: absolute;
  margin: auto;
  left: 48%;
  right: 52%;
  top: 48%;
  bottom: 52%;
  width: 60px;
  height: 60px;
  animation: bound-anim 2s infinite ease-in-out;
  z-index: 9999999; }

.ao {
  position: absolute;
  margin: auto;
  left: 52%;
  right: 48%;
  top: 52%;
  bottom: 48%;
  width: 30px;
  height: 30px;
  animation: bound-anim 1.5s infinite ease-in-out;
  z-index: 9999999; }

@keyframes bound-anim {
  0%,100% {
    opacity: 0;
    transform: scale(1); }
  50% {
    opacity: 1;
    transform: scale(2); } }
#loading-circle {
  display: block;
  width: 80px;
  height: 80px;
  border-top: 0.5em solid rgba(0, 0, 0, 0.05);
  border-right: 0.5em solid rgba(0, 0, 0, 0.05);
  border-bottom: 0.5em solid rgba(0, 0, 0, 0.05);
  border-left: 0.5em solid rgba(0, 0, 0, 0.1);
  animation: loaderAnime 1s infinite linear;
  border-radius: 50%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  z-index: 9999999; }

@keyframes loaderAnime {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(360deg); } }
/*========= 画面遷移のためのCSS ===============*/
/*画面遷移アニメーション*/
.loadingbg {
  display: none; }

/*bodyにappearクラスがついたら出現*/
/*body.appear .loadingbg{
display: block;
content: "";
position:fixed;
z-index: 999;
width: 100%;
height: 100vh;
top: 0;
left: 0;
transform: scaleX(0);
background-color: #222;
animation-name:PageAnime;
animation-duration:1.2s;
animation-timing-function:ease-in-out;
animation-fill-mode:forwards;
}*/
@keyframes PageAnime {
  0% {
    transform-origin: left;
    transform: scaleX(0); }
  50% {
    transform-origin: left;
    transform: scaleX(1); }
  50.001% {
    transform-origin: right; }
  100% {
    transform-origin: right;
    transform: scaleX(0); } }
/*画面遷移の後現れるコンテンツ設定*/
#wrapper {
  overflow: hidden;
  opacity: 0;
  /*はじめは透過0に*/ }

/*bodyにappearクラスがついたら出現*/
body.appear #wrapper {
  animation-name: PageAnimeAppear;
  animation-duration: 1s;
  animation-delay: 0.8s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes PageAnimeAppear {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
.moveTrigger {
  opacity: 0; }

/*===================================
//滑らかに出現
===================================*/
.smoothText {
  overflow: hidden; }

.smoothText.anime {
  animation-name: smoothText;
  animation-duration: 0.5s;
  animation-delay: 0.1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes smoothText {
  from {
    transform: translate3d(0, 100%, 0) skewY(12deg);
    opacity: 0; }
  to {
    transform: translate3d(0, 0, 0) skewY(0);
    opacity: 1; } }
/*===================================
//フェードイン
===================================*/
.fade-in.anime {
  animation-name: fadeInAnime;
  animation-duration: 2s;
  animation-delay: 0.1s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes fadeInAnime {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
/*===================================
//スライドイン下から
===================================*/
.slide-down.anime {
  animation-name: slideDown;
  animation-duration: 1s;
  animation-delay: 0;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes slideDown {
  from {
    transform: translateY(100px);
    opacity: 0; }
  to {
    transform: translateY(0);
    opacity: 1; } }
/*===================================
//スライドイン下から
===================================*/
.slide-up.anime {
  animation-name: slideUp;
  animation-duration: 1s;
  animation-delay: 0;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes slideUp {
  from {
    transform: translateY(100px);
    opacity: 0; }
  to {
    transform: translateY(0);
    opacity: 1; } }
/*===================================
//スライドイン左から
===================================*/
.slide-left.anime {
  animation-name: slideLeft;
  animation-duration: 1s;
  animation-delay: 0;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes slideLeft {
  from {
    transform: translateX(-100px);
    opacity: 0; }
  to {
    transform: translateX(0);
    opacity: 1; } }
/*===================================
//スライドイン右から
===================================*/
.slide-right.anime {
  animation-name: slideRight;
  animation-duration: 1s;
  animation-delay: 0;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes slideRight {
  from {
    transform: translateX(100px);
    opacity: 0; }
  to {
    transform: translateX(0);
    opacity: 1; } }
/*===================================
//じわっ
===================================*/
h3.blur {
  opacity: 0;
  transition: 1.5s;
  transform: scale(1.05); }

p.blur {
  opacity: 0; }

h3.blur.anime {
  animation-name: blurAnime;
  animation-duration: 1.5s;
  animation-delay: 0.1s;
  animation-fill-mode: forwards;
  transform: scale(1);
  opacity: 0; }

p.blur.anime {
  animation-name: blurAnime;
  animation-duration: 1.5s;
  animation-delay: 0.5s;
  animation-fill-mode: forwards;
  opacity: 0; }

@keyframes blurAnime {
  from {
    filter: blur(10px);
    opacity: 0; }
  to {
    filter: blur(0);
    opacity: 1; } }
/*===================================
//背景色が伸びて出現
===================================*/
.bgextend.anime {
  animation-name: bgextendAnimeBase;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  /*　はみ出た色要素を隠す　*/
  opacity: 0;
  z-index: 1; }

@keyframes bgextendAnimeBase {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
/*中の要素*/
.bgextend.anime p {
  animation-name: bgextendAnimeSecond;
  animation-duration: 1s;
  animation-delay: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
  position: relative;
  z-index: -1; }

@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
/*左から右*/
.bgextend.anime::before {
  animation-name: bgextendAnime;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #FFFA00;
  /*伸びる背景色の設定*/ }

@keyframes bgextendAnime {
  0% {
    transform-origin: left;
    transform: scaleX(0); }
  50% {
    transform-origin: left;
    transform: scaleX(1); }
  50.001% {
    transform-origin: right; }
  100% {
    transform-origin: right;
    transform: scaleX(0); } }
#tab_wrapper {
  width: 100%;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap; }

ul#tab {
  flex-basis: 36%;
  margin: 0 auto 2rem 0; }
  @media screen and (max-width: 960px) {
    ul#tab {
      display: none; } }

.form-select {
  display: none; }
  @media screen and (max-width: 960px) {
    .form-select {
      display: block; } }

ul#tab li {
  margin-bottom: 5px;
  width: 100%; }

ul#tab li a {
  display: block;
  width: 100%;
  padding: 8px 20px;
  line-height: 1.4em;
  text-decoration: none;
  background-color: #F5F5F5; }

ul#tab li a.active,
ul#tab li a:hover {
  color: #FFF;
  background-color: #004EBE; }

#tab_contents {
  flex-basis: 60%;
  margin: 0; }
  @media screen and (max-width: 960px) {
    #tab_contents {
      flex-basis: 100%; } }

#panel {
  width: 100%; }

#panel h4 {
  background-color: #004EBE;
  color: #FFF;
  padding: 0.2em 1em; }

#panel img.city_ph {
  float: right;
  margin-top: 20px; }

#panel p.city_bun {
  float: left;
  margin: 20px 0 0 0;
  width: 400px; }

#panel p.city_url {
  clear: both;
  text-align: right;
  margin: 0px;
  padding-top: 10px; }

dl.company_list {
  border-bottom: 1px solid rgba(0, 0, 0, 0.2); }

dl.company_list dt {
  width: 100%;
  padding: 6px 20px;
  font-size: 1.2em;
  font-weight: bold;
  background-color: #004EBE;
  color: #FFF; }

dl.company_list dd a {
  width: 100%;
  padding: 6px 20px;
  display: block;
  text-decoration: none;
  background-color: #FFF;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-bottom: 0; }

dl.company_list dd a:hover {
  background-color: #F5F5F5; }

/*タブメニュー　メニュー上*/
#tab_wrapper2 {
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box; }

ul#tab2 {
  width: 100%;
  margin: 0 0 1rem 0;
  padding: 0;
  display: flex;
  justify-content: flex-start;
  align-content: stretch;
  flex-wrap: wrap; }
  @media screen and (max-width: 960px) {
    ul#tab2 {
      display: none; } }

ul#tab2 li {
  flex-basis: 25%;
  padding: 0.3%;
  margin: 0; }

ul#tab2 li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 1em 0.3em;
  font-weight: 600;
  line-height: 1.4em;
  text-decoration: none;
  text-align: center;
  color: #FFF;
  background-color: #049D95;
  border-radius: 6px;
  opacity: 0.8; }

@media screen and (max-width: 960px) {
  ul#tab2.num li a {
    padding: 0.5em 0.2em;
    font-size: 0.7rem;
    border-radius: 5px 5px 0 0; } }

ul#tab2 li a:hover {
  opacity: 1.0; }

ul#tab2 li a.active {
  background-color: #049D95;
  opacity: 1.0; }

#panel2 {
  clear: both; }

#panel2 li {
  border: 3px solid #049D94;
  box-sizing: border-box;
  margin: 0;
  padding: 0; }

#panel2 li div {
  padding: 0;
  margin: 0; }

#panel2 img {
  display: block;
  width: 100%; }

#panel .co39::after,
#panel .co41::after,
#panel .co42::after,
#panel .co43::after,
#panel .co44::after,
#panel .co45::after,
#panel .co46::after,
#panel .co48::after,
#panel .co49::after,
#panel .co50::after,
#panel .co51::after,
#panel .co53::after,
#panel .co54::after,
#panel .co56::after,
#panel .co57::after,
#panel .co58::after,
#panel .co60::after,
#panel .co61::after,
#panel .co62::after,
#panel .co63::after,
#panel .co67::after,
#panel .co69::after,
#panel .co72::after,
#panel .co74::after,
#panel .co76::after,
#panel .co83::after,
#panel .co88::after,
#panel .co89::after,
#panel .co92::after,
#panel .co95::after,
#panel .co96::after,
#panel .co97::after,
#panel .co99::after,
#panel .co101::after,
#panel .co104::after,
#panel .co110::after,
#panel .co111::after,
#panel .co112::after,
#panel .co117::after,
#panel .co118::after,
#panel .co120::after,
#panel .co121::after,
#panel .co127::after,
#panel .co128::after,
#panel .co131::after,
#panel .co133::after,
#panel .co135::after,
#panel .co138::after,
#panel .co141::after,
#panel .co142::after,
#panel .co147::after,
#panel .co149::after,
#panel .co157::after,
#panel .co159::after,
#panel .co160::after,
#panel .co162::after,
#panel .co163::after,
#panel .co166::after,
#panel .co167::after,
#panel .co172::after,
#panel .co175::after,
#panel .co177::after,
#panel .co178::after,
#panel .co179::after,
#panel .co181::after,
#panel .co187::after,
#panel .co189::after,
#panel .co190::after,
#panel .co191::after,
#panel .co195::after,
#panel .co196::after,
#panel .co199::after,
#panel .co201::after,
#panel .co202::after,
#panel .co206::after,
#panel .co208::after,
#panel .co210::after,
#panel .co212::after,
#panel .co214::after,
#panel .co215::after,
#panel .co219::after,
#panel .co220::after,
#panel .co221::after,
#panel .co224::after,
#panel .co226::after,
#panel .co227::after,
#panel .co229::after,
#panel .co231::after,
#panel .co234::after {
  content: "インターンシップ情報あり";
  display: inline-block;
  background: #FFF;
  line-height: 1;
  border-radius: 3px;
  border: 1px solid #DDDDDD;
  padding: 4px;
  font-size: 0.75em;
  margin-left: 1.5em; }
