@charset "UTF-8";
/**
 * Font
 */
/**
 * Variables
 */
.container_wrapper {
  position: relative;
  width: 100%;
  padding: 20px 0; }

#main a {
  color: #888; }

#main a:hover {
  color: #505050;
  text-decoration: underline; }

.content {
  background: #fff;
  margin: 0 0 40px;
  color: #505050; }

.table {
  display: table;
  table-layout: fixed; }

#main_text .cell {
  width: 50%;
  display: table-cell;
  vertical-align: top; }

/* Title  */
.ttl_top {
  padding: 0 10px 15px; }

.breadcrumbs {
  position: relative;
  display: inline-block;
  font-size: 0.9em; }

h1 {
  clear: both;
  background: #F6F3F6; }

h3 {
  margin: 0.5em 0 -0.5em;
  font-size: 1.6em;
  display: inline-block; }

h4 {
  margin: 0 0 15px 0;
  font-size: 1.3em; }

hr {
  background: #000;
  width: 100%;
  height: 1px;
  border: none; }

#top {
  margin: 0; }

#ttl {
  position: relative; }

.vid {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; }

.vid iframe {
  position: absolute;
  width: 100% !important;
  height: 100% !important;
  top: 0;
  left: 0; }

.writer {
  position: absolute;
  right: 10px;
  bottom: 0;
  padding: 5px 10px;
  font-size: 1.4em; }

.top_txt {
  padding: 40px;
  margin: 0 0 40px; }

.sec_ttl {
  text-align: center;
  padding: 40px;
  color: #646464; }

.sec_ttl.is-gray {
  color: #424242;
  background: #F6F3F6; }

/* Main */
#main_area {
  margin: 0 0 40px; }

.headline {
  font-size: 2em; }

.sec_ttl h2 {
  font-size: 3.2em; }

.lead {
  font-size: 1.5em; }

.txt_box {
  padding: 40px 0 0; }

.txt_box p {
  padding: 0 40px 40px; }

.single_box {
  padding: 0 40px; }

.single_box + .img_area {
  padding: 0 40px 40px; }

.single_box p {
  padding: 0 0 40px; }

.single_box.is-transparent {
  background: #f6f3f6; }

.single_box.is-transparent p {
  padding: 0; }

.img_box {
  width: 50%;
  margin: 0 0 20px 40px; }

.img_box img {
  padding: 0 0 20px; }

.txt_box h3 {
  margin: 0 0 15px 40px;
  display: block; }

.gr {
  display: block;
  width: 43%;
  width: calc(50% - 80px);
  padding: 4px 10px;
  font-size: 1em;
  background: #D6D3D6; }

.vertical {
  width: 25%; }

.cont_area--alt {
  padding: 24px 0 0; }

.cont_area--alt:first-child {
  padding: 40px 0 0; }

.cont_area--alt:last-child {
  padding: 24px 0 40px; }

.cont_area--alt.img_r h3 {
  margin: 0 0 15px 40px; }

.cont_area--alt.img_l h3 {
  margin: 0 40px 15px 0; }

.cont_area--alt span.cont_area--alt__image {
  width: 49%; }

.cont_area--alt p {
  padding: 0 40px; }

.cont_area--alt p.img_area {
  margin: 0 0 40px;
  padding: 0; }

.cont_area--alt.img_r span {
  float: right;
  margin: 0 0 16px 2%; }

.cont_area--alt.img_l span {
  float: left;
  margin: 0 2% 16px 0; }

.frame_area {
  background: #fff;
  border: 20px solid #e9e6e9;
  padding: 40px; }

.frame_area .img_box, .frame_area .txt_box {
  width: 49%;
  margin: 0;
  padding: 0; }

.frame_area.is-vertical .img_box {
  width: 33.3%;
  margin: 0.3em 2% 1.2em 0; }

.frame_area.is-vertical .txt_box {
  width: 100%;
  float: none; }

.frame_area h2 {
  margin: 0 0 40px;
  text-align: center; }

.frame_area.is-vertical h2 {
  margin: 0 0 36px; }

.frame_area img {
  padding: 0; }

.frame_area p {
  padding: 0;
  margin: 0 0 20px; }

.frame_area ul {
  margin: 0 0 20px; }

.frame_area li {
  display: block;
  padding: 4px 20px;
  margin: 0 0 10px;
  background: #e9e6e9;
  border-radius: 16px;
  -webkit-border-radius: 16px;
  -moz-border-radius: 16px; }

.frame_area.is-wrapped {
  background-color: #fff; }

.frame_area.is-wrapped .img_box {
  margin: 0.3em 2% 0 0; }

.frame_area.is-wrapped .img_box img {
  margin: 0 0 1.2em; }

.frame_area.is-wrapped .txt_box {
  width: 100%; }

.frame_area.is-wrapped li {
  display: inline-block;
  width: 48%; }

.frame_area.is-largeSpaces .img_box {
  padding: 0 20px;
  width: 33%; }

.frame_area.is-largeSpaces .img_box img {
  max-width: 240px;
  margin: auto; }

.frame_area.is-largeSpaces .txt_box {
  width: 66%; }

.frame_area.is-largeSpaces .txt_box h2 {
  text-align: left; }

.video_link {
  position: relative;
  cursor: pointer;
  background-color: #000;
  background-image: url(/themes/discoverkyoto/images/play_btn.svgz);
  background-repeat: no-repeat;
  background-position: center; }

.video_link img {
  transition: opacity 0.2s; }

.video_link:hover img {
  opacity: 0.6; }

.video_link:after {
  content: '笆ｶ';
  width: 17px;
  height: 18px;
  padding: 6px 6px 6px 7px;
  position: absolute;
  bottom: 10px;
  right: 10px;
  display: inline-block;
  background-color: rgba(0, 0, 0, 0.4);
  color: #fff;
  text-align: center;
  vertical-align: middle;
  line-height: 1;
  font-size: 18px;
  pointer-events: none; }

.video_link:hover:after {
  display: none; }

#viewer {
  width: 90%;
  margin: 20px;
  padding: 20px;
  max-width: 980px;
  min-width: 480px;
  border-radius: 10px;
  overflow: hidden;
  background-color: #222;
  position: fixed;
  z-index: 11; }

#viewer .close {
  top: 0;
  right: 0; }

#v_container {
  position: relative;
  width: 100%;
  padding-top: 56.25%; }

#v_container iframe {
  position: absolute;
  top: 0px;
  right: 0px;
  width: 100% !important;
  height: 100% !important; }

/* Gallery */
#gallery {
  padding: 40px 0;
  background: #fff; }

#gallery h2 {
  padding: 0 40px; }

.gallery_package {
  position: relative;
  width: 100%;
  margin: 2% 0 0; }

.gallery_package:after {
  content: "";
  display: block;
  clear: both; }

.gallery_package h3, .rec_ttl {
  position: absolute;
  width: 100%;
  bottom: 0;
  left: 0;
  color: #fff;
  padding: 2% 4%;
  margin: 0;
  line-height: 1.5;
  background: rgba(0, 0, 0, 0.1);
  background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.3), black);
  background: -ms-linear-gradient(top, rgba(0, 0, 0, 0.3), black);
  background: -o-linear-gradient(top, rgba(0, 0, 0, 0.3), black);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.3), black);
  filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorStr=#22000000, endColorStr=#FF000000);
  -ms-filter: "progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorStr=#22000000, endColorStr=#FF000000)"; }

.thumbs {
  position: relative;
  width: 100%; }

.thumbs li.package_wrapper {
  position: relative;
  width: 49.4%;
  margin: 0;
  float: left;
  cursor: pointer;
  overflow: hidden; }

.thumbs li {
  position: relative;
  width: 23%;
  margin: 0 0 2.29% 2.29%;
  float: left;
  overflow: hidden;
  cursor: pointer; }

.more_img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: block;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  font-size: 3em;
  text-align: center;
  pointer-events: none;
  line-height: 0; }

.more_img span {
  vertical-align: middle; }

.more_img:before {
  display: inline-block;
  content: "";
  width: 0;
  height: 100%;
  vertical-align: middle; }

#modal-overlay {
  z-index: 10;
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 120%;
  background: rgba(0, 0, 0, 0.6);
  cursor: pointer; }

#gallery_box {
  position: fixed;
  width: 90%;
  top: 0;
  left: 0;
  margin: 20px;
  padding: 5px 1% 1%;
  max-width: 1048px;
  min-width: 560px;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  overflow: hidden;
  opacity: 0;
  background-color: #333;
  z-index: 11; }

#gallery_ttl {
  position: relative;
  height: 1.8em;
  font-size: 1.2em;
  padding: 5px;
  color: #fff; }

#rec_link {
  position: relative;
  margin: 0 0 0 20px;
  font-size: 0.8em;
  color: #fff !important;
  padding: 0 3px;
  background: #666; }

.close {
  position: absolute;
  width: 28px;
  height: 28px;
  color: #fff;
  font-size: 1.2em;
  top: 5px;
  right: 5px;
  text-align: center;
  cursor: pointer;
  z-index: 1; }

#gallery_box_wrapper {
  opacity: 0; }

#gallery_main {
  position: relative;
  width: 100%; }

#gallery_img_wrapper:-webkit-full-screen {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%; }

#gallery_img_wrapper:-moz-full-screen {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%; }

#gallery_img_wrapper:-ms-fullscreen {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%; }

#gallery_img_wrapper:fullscreen {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%; }

#gallery_imgs {
  position: relative;
  width: 100%;
  height: 100%; }

#gallery_img_wrapper {
  text-align: center; }

#prev img, #next img, #full img {
  vertical-align: middle;
  max-width: 100%;
  max-height: 100%; }

.imgs, #prev, #next, #full {
  z-index: 6; }

#gallery_main_img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: none; }

#gallery_img_container {
  position: relative;
  width: 100%;
  height: 100%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center; }

#gallery_img_container img {
  display: none; }

#gallery_recs {
  margin: 3% 10%;
  z-index: 7;
  display: none;
  background: #333; }

#gallery_recs:after {
  content: '';
  display: block;
  clear: left; }

#gallery_recs .wrap {
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  overflow: auto; }

#gallery_recs li {
  position: relative;
  float: left;
  width: 45.9%;
  padding-top: 30.6%;
  margin: 2%;
  cursor: pointer; }

#gallery_box .alert {
  width: 100%;
  height: 100%;
  padding: 45% 0 0;
  color: #fef263;
  font-size: 1.5em;
  background: #333; }

#gallery_txt {
  position: relative;
  width: 100%;
  margin: 10px 0;
  height: 4.5em; }

#gallery_txt p {
  position: absolute;
  color: #fff;
  top: 0;
  left: 0;
  display: none; }

.photo_ttl {
  display: block;
  font-size: 1.2em; }

.cbtn {
  text-align: center;
  font-size: 24px;
  padding: 0 10px;
  color: #fff;
  opacity: 0.4;
  cursor: pointer; }

.cbtn:hover {
  opacity: 0.8; }

.carousel_list {
  width: 100%;
  overflow: hidden; }

.clearfix:after {
  display: block;
  clear: both;
  height: 0px;
  visibility: hidden;
  content: "."; }

#gallery_thumb {
  width: 500%; }

#gallery_thumb li {
  position: relative;
  float: left;
  width: 1.82%;
  padding-top: 1.82%;
  margin: 0 0.2% 0 0;
  opacity: 1.0;
  filter: alpha(opacity=100);
  cursor: pointer; }

#gallery_thumb li:first-child {
  opacity: 0.5;
  filter: alpha(opacity=50); }

#gallery_thumb li:last-child {
  margin: 0; }

#gallery_thumb li div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-size: contain; }

#gallery_thumb .rec div {
  vertical-align: middle;
  color: #fff;
  background: #444;
  text-align: center; }

#gallery_thumb .rec div:before {
  content: "";
  width: auto;
  height: 100%;
  display: inline-block;
  vertical-align: middle; }

#gallery_thumb .rec span {
  vertical-align: middle; }

#carousel_area {
  position: relative;
  padding-top: 12%;
  overflow: hidden; }

#pointer {
  width: 100%;
  margin: 5px auto 0;
  text-align: center; }

#pointer li {
  display: inline-block;
  margin: 0 5px;
  font-size: 13px;
  color: #fff;
  opacity: 0.4;
  cursor: pointer; }

#pointer .cur {
  opacity: 0.8; }

#prev, #next {
  position: absolute;
  top: 0;
  width: 30%;
  height: 100%;
  color: #fff;
  opacity: 0;
  cursor: pointer; }

#prev img, #next img {
  position: absolute;
  top: 48%;
  width: 28px; }

#prev img {
  left: 10px; }

#next img {
  right: 10px; }

#prev {
  left: 0; }

#next {
  right: 0; }

#full {
  position: absolute;
  width: 28px;
  top: 10px;
  right: 10px;
  opacity: 0;
  cursor: pointer; }

/* link */
.spot_ttl {
  position: absolute;
  width: 100%;
  bottom: 0;
  left: 0;
  color: #fff;
  padding: 10px;
  line-height: 1.5;
  background: rgba(0, 0, 0, 0.1);
  background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.3), black);
  background: -ms-linear-gradient(top, rgba(0, 0, 0, 0.3), black);
  background: -o-linear-gradient(top, rgba(0, 0, 0, 0.3), black);
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.3), black);
  filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorStr=#22000000, endColorStr=#FF000000);
  -ms-filter: "progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorStr=#22000000, endColorStr=#FF000000)"; }

.spot_ttl h3 {
  margin: 0 0 5px; }

.feature_ttl {
  position: absolute;
  top: 10px;
  left: 0;
  color: #fff;
  background: #d7003a;
  padding: 5px 20px; }

#carousel_link_area {
  width: 100%;
  margin: 0; }

#carousel_link_area h3 {
  padding: 0 5%;
  margin: 0 0 10px; }

.item_list {
  position: relative;
  padding: 0 5% 60px;
  width: 100%;
  overflow: hidden; }

#carousel_link_area ul {
  position: relative; }

.carousel {
  position: relative;
  padding: 0 0 4px;
  width: 100%; }

.load {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  text-align: center; }

.load:before {
  position: relative;
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle; }

.load img {
  position: relative;
  left: 0;
  width: 48px;
  height: 48px;
  vertical-align: middle;
  display: inline-block; }

.link_arrow {
  width: 44px;
  vertical-align: middle;
  cursor: pointer;
  opacity: 0.4;
  transition: opacity 200ms; }

.link_arrow:hover {
  opacity: 1;
  transition: opacity 200ms; }

.link_arrow img {
  display: inline-block;
  width: 14px;
  margin: 0 8px; }

.prev {
  text-align: right; }

.next {
  text-align: left; }

#carousel_link_area .noflip {
  width: 100%;
  padding: 0 60px;
  margin: 0 auto 40px; }

.carousel_list ul {
  width: 1020%; }

.carousel_list li {
  position: relative;
  background-color: #fff;
  float: left;
  width: 3.137%;
  margin: 0 0.196% 0 0; }

.item_list li:last-child {
  margin: 0; }

.pointer {
  width: 100%;
  margin: 0 auto 16px;
  text-align: center; }

.pointer li {
  display: inline-block;
  margin: 0 5px;
  font-size: 15px;
  color: #624A69;
  opacity: 0.4;
  cursor: pointer; }

.pointer .cur {
  opacity: 0.8; }

.lazyload, .lazyloading {
  opacity: 0; }

.lazyloaded {
  opacity: 1;
  transition: opacity 200ms; }

.move {
  margin: 0 0 80px; }

.link_btn {
  width: 20%;
  text-align: center; }

.link_btn > * {
  padding: 20px 0;
  background: #fff; }

.link_btn a {
  display: block;
  color: #505050;
  transition: 200ms; }

.link_btn a:hover {
  display: block;
  color: #fff;
  background: #624A69;
  transition: 200ms; }

.nolink {
  opacity: 0.5; }

.reco {
  margin: 0 0 40px; }

.reco_list li {
  width: 32%;
  margin: 0 2% 2% 0; }

.no_margin {
  margin: 0 0 2% !important; }

#to_top {
  position: fixed;
  right: 20px;
  bottom: 20px;
  display: none;
  opacity: 0.4; }

#to_top a {
  display: block;
  width: 60px;
  height: 60px;
  font-size: 24px;
  line-height: 1;
  padding: 18px 0 0;
  text-align: center;
  color: #fff;
  background: #B290BF; }

.fixed#to_top {
  position: absolute;
  right: 20px;
  bottom: 90px; }

/**
 * For "Kyoto Idioms"
 */
.kyoto-voice-idiom {
  background: #fff;
  border: 20px solid #e9e6e9;
  padding: 40px; }
  .kyoto-voice-idiom-wrapper {
    background: #F6F3F6;
    padding-bottom: 40px; }
    .kyoto-voice-idiom-wrapper:last-child {
      padding-bottom: 0; }
  .kyoto-voice-idiom-heading {
    margin-bottom: 40px;
    text-align: center; }
    .kyoto-voice-idiom-heading__main {
      font-style: bolder; }
    .kyoto-voice-idiom-heading__sub {
      font-size: 18px; }
  .kyoto-voice-idiom-image-content {
    display: flex;
    padding: 0 40px; }
    .kyoto-voice-idiom-image-content__image {
      flex: 1; }
    .kyoto-voice-idiom-image-content__text {
      flex: 1;
      margin-left: 20px; }
      .kyoto-voice-idiom-image-content__text p {
        margin-top: 20px; }
        .kyoto-voice-idiom-image-content__text p:first-child {
          margin-top: 0; }
        .kyoto-voice-idiom-image-content__text p strong {
          font-style: bolder; }
      .kyoto-voice-idiom-image-content__text ul {
        margin-top: 10px; }
        .kyoto-voice-idiom-image-content__text ul li {
          display: block;
          padding: 4px 20px;
          margin: 0 0 10px;
          background: #e9e6e9;
          border-radius: 16px;
          -webkit-border-radius: 16px;
          -moz-border-radius: 16px;
          font-weight: bold; }
  .kyoto-voice-idiom-main-text {
    margin-top: 40px; }

/*# sourceMappingURL=kyoto_voice.css.map */
