@charset "UTF-8";
header,
main,
article {
  display: block; }

body {
  font-family: Circular, "Helvetica Neue", Helvetica, Arial, sans-serif; }

[lang="ja"] body {
  font-family: Circular, "Helvetica Neue", Helvetica, Arial, "\30D2\30E9\30AE\30CE\89D2\30B4   Pro", "Hiragino Kaku Gothic Pro", "\30E1\30A4\30EA\30AA", Meiryo,Osaka, "\FF2D\FF33   \FF30\30B4\30B7\30C3\30AF", "MS PGothic", "MS Gothic", "\FF2D\FF33   \30B4\30B7\30C3\30AF", sans-serif; }

* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font: inherit;
  color: inherit;
  line-height: inherit;
  word-wrap: break-word;
  overflow-wrap: break-word; }

html,
body {
  margin: 0;
  padding: 0; }

body {
  background: #fff;
  color: #000;
  font-size: 1em;
  line-height: 1.5;
  -webkit-tap-highlight-color: transparent;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased; }

@media (min-width: 801px) {
  body[data-font-size="large"] {
    font-size: 1.4em; }
  body[data-font-size="xlarge"] {
    font-size: 2em; } }

a img {
  vertical-align: middle; }

abbr {
  text-decoration: none; }

hr {
  display: none; }

.word-break-all {
  word-wrap: break-word;
  word-break: break-all; }

article h2 .title.lazy,
article h2 .sub.lazy,
.text-container.lazy {
  opacity: 0;
  -webkit-transform: translate(-30px, 0);
          transform: translate(-30px, 0); }
  article h2 .title.lazy.show,
  article h2 .sub.lazy.show,
  .text-container.lazy.show {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
    opacity: 1;
    -webkit-transition: opacity 0.3s linear 0.2s, -webkit-transform 0.6s ease-out 0.2s;
    transition: opacity 0.3s linear 0.2s, -webkit-transform 0.6s ease-out 0.2s;
    transition: opacity 0.3s linear 0.2s, transform 0.6s ease-out 0.2s;
    transition: opacity 0.3s linear 0.2s, transform 0.6s ease-out 0.2s, -webkit-transform 0.6s ease-out 0.2s; }
    article h2 .title.lazy.show.sub,
    article h2 .sub.lazy.show.sub,
    .text-container.lazy.show.sub {
      -webkit-transition-delay: 0.3s;
              transition-delay: 0.3s; }

.lazy {
  opacity: 0; }
  .lazy.show {
    opacity: 1; }

header {
  position: absolute;
  z-index: 1400;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  border-bottom: 1px solid rgba(204, 204, 204, 0.6);
  color: #000;
  font-weight: 700;
  cursor: default;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  text-transform: uppercase;
  line-height: 1.2; }
  header noscript .message {
    padding: 15px;
    border-bottom: 1px solid rgba(204, 204, 204, 0.6); }
  header noscript p {
    margin: 0;
    font-weight: normal;
    text-align: center;
    font-size: 0.9em;
    text-transform: none;
    line-height: 1.4;
    letter-spacing: 0.01em; }
  header .content {
    position: relative;
    padding-left: 160px; }
  header .site-name {
    position: absolute;
    top: 0;
    left: 0;
    width: 160px;
    height: 100%;
    margin: 0;
    background: #fff;
    border-right: 1px solid rgba(204, 204, 204, 0.6); }
    header .site-name a {
      display: block;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
    header .site-name img {
      display: block;
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%); }
      [data-font-size="large"] header .site-name img {
        -webkit-transform: translate(-50%, -50%) scale(1.2, 1.2);
                transform: translate(-50%, -50%) scale(1.2, 1.2); }
      [data-font-size="xlarge"] header .site-name img {
        -webkit-transform: translate(-50%, -50%) scale(1.4, 1.4);
                transform: translate(-50%, -50%) scale(1.4, 1.4); }
  header .actions {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    background: rgba(204, 204, 204, 0.2);
    font-size: 0.85em;
    border-bottom: 1px solid rgba(204, 204, 204, 0.6); }
    header .actions .item {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      padding: 0.9em 1.8em;
      border-left: 1px solid rgba(204, 204, 204, 0.6);
      line-height: 1em; }
      header .actions .item:first-child {
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        border-left: none;
        -webkit-box-flex: 1;
            -ms-flex: 1;
                flex: 1; }
      header .actions .item .title {
        display: inline-block;
        margin-right: 15px;
        font-size: 0.9em; }
      header .actions .item ul {
        display: inline-block;
        margin: 0;
        padding: 0;
        list-style-type: none; }
        header .actions .item ul li {
          display: inline-block;
          position: relative;
          vertical-align: baseline;
          color: #000; }
          header .actions .item ul li a {
            color: inherit;
            position: relative;
            text-decoration: none;
            color: #000; }
          header .actions .item ul li button {
            -webkit-appearance: none;
               -moz-appearance: none;
                    appearance: none;
            position: relative;
            font: inherit;
            padding: 0;
            border: none;
            background: transparent;
            line-height: 1.2em;
            color: #000;
            cursor: pointer; }
            header .actions .item ul li button:after {
              content: "";
              display: block;
              position: absolute;
              bottom: 0;
              left: 0;
              width: 100%;
              border-top: 1px solid #000; }
            header .actions .item ul li button:hover:after {
              border-top-width: 2px; }
            header .actions .item ul li button[tabindex="-1"] {
              cursor: default; }
              header .actions .item ul li button[tabindex="-1"]:after {
                border-bottom: none; }
          header .actions .item ul li a {
            cursor: pointer;
            border-bottom: 1px solid #000; }
            header .actions .item ul li a:hover {
              border-bottom-width: 2px; }
            header .actions .item ul li a[tabindex="-1"] {
              cursor: default; }
              header .actions .item ul li a[tabindex="-1"]:after {
                border-bottom: none; }
          header .actions .item ul li.current a,
          header .actions .item ul li.current button {
            cursor: default;
            border-bottom: none; }
            header .actions .item ul li.current a:after,
            header .actions .item ul li.current button:after {
              display: none; }
      header .actions .item.languages li, header .actions .item.font-sizes li {
        margin-left: 8px; }
        header .actions .item.languages li:first-child, header .actions .item.font-sizes li:first-child {
          margin-left: 0; }
      header .actions .item.font-sizes {
        display: none; }
        [data-font-size] header .actions .item.font-sizes {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex; }
  header #nav-open-btn {
    display: none; }
  header nav {
    position: relative;
    font-size: 0.9em; }
    header nav ul {
      position: relative;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-line-pack: stretch;
          align-content: stretch;
      margin: 0;
      padding: 0;
      list-style-type: none; }
      header nav ul li {
        -webkit-box-flex: 1;
            -ms-flex: 1;
                flex: 1;
        min-width: 80px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        position: relative;
        text-align: center;
        background-color: rgba(255, 255, 255, 0);
        border-left: 1px solid rgba(204, 204, 204, 0.6);
        color: #666;
        -webkit-transition: background-color 0.2s ease-out 0s;
        transition: background-color 0.2s ease-out 0s; }
        header nav ul li:first-child {
          border-left: none; }
        header nav ul li:before {
          content: "";
          display: block;
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 0;
          background: #666;
          -webkit-transition: height 0.2s ease-out 0s;
          transition: height 0.2s ease-out 0s; }
        header nav ul li:after {
          content: "";
          display: block;
          position: absolute;
          top: 27px;
          left: 50%;
          -webkit-transform: translate(-50%, -50%);
                  transform: translate(-50%, -50%);
          pointer-events: none; }
        header nav ul li[aria-disabled="true"],
        header nav ul li a {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          -webkit-box-pack: center;
              -ms-flex-pack: center;
                  justify-content: center;
          -webkit-box-align: stretch;
              -ms-flex-align: stretch;
                  align-items: stretch;
          padding: 45px 3px 13px; }
        header nav ul li a {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          -webkit-box-pack: center;
              -ms-flex-pack: center;
                  justify-content: center;
          -webkit-box-align: stretch;
              -ms-flex-align: stretch;
                  align-items: stretch;
          width: 100%;
          position: relative;
          background: rgba(0, 0, 0, 0);
          -webkit-transition: background 0.4s ease-out 0s;
          transition: background 0.4s ease-out 0s;
          color: #000;
          text-decoration: none; }
          header nav ul li a:hover {
            background: rgba(0, 0, 0, 0.05);
            -webkit-transition: background 0.2s ease-out 0s;
            transition: background 0.2s ease-out 0s; }
        header nav ul li .inpreparation {
          display: block;
          margin-top: 0.2em;
          font-size: 0.85em; }
        header nav ul li.current:before {
          height: 4px; }
        header nav ul li.current a {
          background: rgba(0, 0, 0, 0.05); }
        header nav ul li[data-dir="summit"]:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: 0 -169px;
          background-size: 275px 227px;
          width: 30px;
          height: 30px; }
        header nav ul li[data-dir="news"]:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -86px -169px;
          background-size: 275px 227px;
          width: 26px;
          height: 30px; }
        header nav ul li[data-dir="documents"]:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -40px -140px;
          background-size: 275px 227px;
          width: 30px;
          height: 26px; }
        header nav ul li[data-dir="events"]:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -220px -115.01px;
          background-size: 275px 227px;
          width: 28px;
          height: 28px; }
        header nav ul li[data-dir="photos"]:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -130px -140px;
          background-size: 275px 227px;
          width: 30px;
          height: 26px; }
        header nav ul li[data-dir="media"]:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -112px -169px;
          background-size: 275px 227px;
          width: 30px;
          height: 30px; }
        header nav ul li[data-dir="links"]:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -220px -143.01px;
          background-size: 275px 227px;
          width: 28px;
          height: 28px; }
  .position-fixed header {
    position: fixed;
    border-bottom: 1px solid rgba(204, 204, 204, 0.6);
    -webkit-box-shadow: 0 6px 24px rgba(0, 0, 0, 0.05);
            box-shadow: 0 6px 24px rgba(0, 0, 0, 0.05);
    -webkit-animation: position-fixed-anim 0.3s ease-out 0s forwards;
            animation: position-fixed-anim 0.3s ease-out 0s forwards; }
    .position-fixed header.hide {
      -webkit-animation: position-fixed-hide-anim 0.3s ease-out 0s forwards;
              animation: position-fixed-hide-anim 0.3s ease-out 0s forwards; }
    .position-fixed header .site-name {
      border-right: 1px solid rgba(204, 204, 204, 0.6); }
      .position-fixed header .site-name img {
        -webkit-transform: translate(-50%, -50%) scale(0.5, 0.5);
                transform: translate(-50%, -50%) scale(0.5, 0.5); }
        [data-font-size="large"] .position-fixed header .site-name img {
          -webkit-transform: translate(-50%, -50%) scale(0.7, 0.7);
                  transform: translate(-50%, -50%) scale(0.7, 0.7); }
        [data-font-size="xlarge"] .position-fixed header .site-name img {
          -webkit-transform: translate(-50%, -50%) scale(1, 1);
                  transform: translate(-50%, -50%) scale(1, 1); }
    .position-fixed header .actions {
      display: none; }
    [data-font-size="large"] .position-fixed header nav ul li {
      min-height: 80px; }
    [data-font-size="xlarge"] .position-fixed header nav ul li {
      min-height: 100px; }
    .position-fixed header nav ul li:before, .position-fixed header nav ul li:after {
      display: none; }
    .position-fixed header nav ul li[aria-disabled="true"],
    .position-fixed header nav ul li a {
      padding: 3px;
      min-height: 60px; }
  .youtube-playing header {
    pointer-events: none;
    opacity: 0;
    -webkit-transition: opacity 0.3s linear 0s;
    transition: opacity 0.3s linear 0s; }

@-webkit-keyframes position-fixed-anim {
  0% {
    -webkit-transform: translate(0, -100%);
            transform: translate(0, -100%); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } }

@keyframes position-fixed-anim {
  0% {
    -webkit-transform: translate(0, -100%);
            transform: translate(0, -100%); }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); } }

@-webkit-keyframes position-fixed-hide-anim {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  100% {
    -webkit-transform: translate(0, -100%);
            transform: translate(0, -100%); } }

@keyframes position-fixed-hide-anim {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0); }
  100% {
    -webkit-transform: translate(0, -100%);
            transform: translate(0, -100%); } }

@media (max-width: 800px) {
  header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    min-height: 80px;
    padding: 0;
    border-top: 2px solid #060607;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
    font-size: 0.75em; }
    header .content {
      width: 100%;
      padding: 0;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex; }
    header .site-name {
      -webkit-box-flex: 1;
          -ms-flex: 1;
              flex: 1;
      position: relative;
      z-index: 10;
      width: auto;
      height: auto;
      background: transparent;
      border-right: none; }
      header .site-name:before {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        width: 80px;
        height: 100%;
        background: #fff; }
      header .site-name img {
        z-index: 2;
        left: 12px;
        -webkit-transform: translate(0, -50%) scale(0.58, 0.58);
                transform: translate(0, -50%) scale(0.58, 0.58);
        -webkit-transform-origin: 0 center;
                transform-origin: 0 center; }
    header .actions {
      position: relative;
      z-index: 2;
      background: transparent;
      border-left: 1px solid rgba(204, 204, 204, 0.6);
      border-bottom: none;
      font-size: inherit; }
      header .actions .item {
        border: none;
        width: 100%;
        padding: 15px 0; }
        header .actions .item ul {
          margin: 0 auto;
          width: 100%;
          text-align: center; }
          header .actions .item ul li.current {
            display: none; }
          header .actions .item ul li a {
            border-bottom: none; }
      header .actions .item.languages li {
        padding: 0 30px;
        margin-left: 0; }
      header .actions .item.skip-link,
      header .actions .item.font-sizes {
        display: none; }
    header #nav-open-btn {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      position: relative;
      z-index: 2;
      text-align: center;
      width: 80px;
      border-left: 1px solid rgba(204, 204, 204, 0.6);
      color: #000;
      cursor: pointer; }
    header nav {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      padding: 81px 0 0;
      -webkit-box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
              box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
      -webkit-transform: translate(-100%, 0);
              transform: translate(-100%, 0);
      opacity: 0;
      -webkit-transition: opacity 0.1s linear 0s, -webkit-transform 0s linear 0.1s;
      transition: opacity 0.1s linear 0s, -webkit-transform 0s linear 0.1s;
      transition: opacity 0.1s linear 0s, transform 0s linear 0.1s;
      transition: opacity 0.1s linear 0s, transform 0s linear 0.1s, -webkit-transform 0s linear 0.1s; }
      header nav ul {
        display: block;
        background: rgba(204, 204, 204, 0.6);
        color: #666; }
        header nav ul li {
          background: #fff;
          border-bottom: 1px solid rgba(204, 204, 204, 0.6);
          border-left: none;
          -webkit-transform: translate(-100%, 0);
                  transform: translate(-100%, 0);
          opacity: 0; }
          header nav ul li[aria-disabled="true"],
          header nav ul li a {
            display: block;
            padding: 24px 30px 24px 85px;
            font-size: 1.2em;
            text-align: left; }
          header nav ul li:before, header nav ul li.current:before {
            content: "";
            display: block;
            position: absolute;
            z-index: 1;
            top: 0;
            left: 0;
            width: 70px;
            height: 100%;
            background: rgba(204, 204, 204, 0.2); }
          header nav ul li:after {
            z-index: 2;
            top: 50%;
            left: 35px;
            -webkit-transform: translate(-50%, -50%);
                    transform: translate(-50%, -50%); }
          [lang="ja"] header nav ul li .inpreparation {
            display: inline;
            font-size: 1em; }
    .position-fixed header {
      min-height: 50px;
      height: auto;
      border-top: none;
      color: #000; }
      .position-fixed header .site-name {
        border-right: none; }
        .position-fixed header .site-name img {
          -webkit-transform: translate(0, -50%) scale(0.4, 0.4);
                  transform: translate(0, -50%) scale(0.4, 0.4); }
      .position-fixed header .actions {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex; }
      .position-fixed header nav ul li:before, .position-fixed header nav ul li:after {
        display: block; }
      .position-fixed header nav ul li[aria-disabled="true"],
      .position-fixed header nav ul li a {
        display: block;
        padding: 24px 30px 24px 85px;
        font-size: 1.2em;
        text-align: left; }
  .nav-opened header {
    border-bottom: 1px solid #a0abb2; }
    .nav-opened header nav {
      -webkit-transform: translate(0, 0);
              transform: translate(0, 0);
      opacity: 1;
      -webkit-transition: opacity 0.1s linear 0s;
      transition: opacity 0.1s linear 0s; }
      .nav-opened header nav li {
        opacity: 1;
        -webkit-transform: translate(0, 0);
                transform: translate(0, 0);
        -webkit-transition: opacity 0.3s ease-out 0s, -webkit-transform 0.3s ease-out 0s;
        transition: opacity 0.3s ease-out 0s, -webkit-transform 0.3s ease-out 0s;
        transition: transform 0.3s ease-out 0s, opacity 0.3s ease-out 0s;
        transition: transform 0.3s ease-out 0s, opacity 0.3s ease-out 0s, -webkit-transform 0.3s ease-out 0s; }
        .nav-opened header nav li:nth-child(2) {
          -webkit-transition-delay: 0.03s;
                  transition-delay: 0.03s; }
        .nav-opened header nav li:nth-child(3) {
          -webkit-transition-delay: 0.06s;
                  transition-delay: 0.06s; }
        .nav-opened header nav li:nth-child(4) {
          -webkit-transition-delay: 0.09s;
                  transition-delay: 0.09s; }
        .nav-opened header nav li:nth-child(5) {
          -webkit-transition-delay: 0.12s;
                  transition-delay: 0.12s; }
        .nav-opened header nav li:nth-child(6) {
          -webkit-transition-delay: 0.15s;
                  transition-delay: 0.15s; }
        .nav-opened header nav li:nth-child(7) {
          -webkit-transition-delay: 0.18s;
                  transition-delay: 0.18s; }
        .nav-opened header nav li:nth-child(8) {
          -webkit-transition-delay: 0.21s;
                  transition-delay: 0.21s; }
        .nav-opened header nav li:nth-child(9) {
          -webkit-transition-delay: 0.24s;
                  transition-delay: 0.24s; }
        .nav-opened header nav li:nth-child(10) {
          -webkit-transition-delay: 0.27s;
                  transition-delay: 0.27s; }
  .position-fixed .nav-opened {
    -webkit-animation: none;
            animation: none; }
  .nav-opened #nav-cover {
    position: fixed;
    z-index: 1399;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.9); } }

#main-visual {
  position: relative;
  height: 800px;
  min-height: 600px;
  background: #111;
  color: #fff;
  text-shadow: 0 0 0.7em rgba(0, 0, 0, 0.7), 0 0 1.2em rgba(0, 0, 0, 0.7);
  overflow: hidden; }
  [data-font-size="large"] #main-visual {
    min-height: 1000px; }
  [data-font-size="xlarge"] #main-visual {
    min-height: 1400px; }
  #main-visual:after {
    content: "";
    display: block;
    position: absolute;
    z-index: 10;
    top: 0;
    bottom: 0;
    right: 0;
    width: 240px;
    border-left: 1px solid rgba(255, 255, 255, 0.3);
    -webkit-transition: opacity 0.2s linear 0s;
    transition: opacity 0.2s linear 0s;
    pointer-events: none; }
    [data-font-size="large"] #main-visual:after {
      width: 280px; }
    [data-font-size="xlarge"] #main-visual:after {
      width: 330px; }
  #main-visual section {
    position: absolute;
    z-index: 20;
    top: 50%;
    left: 0;
    right: 290px;
    margin: 2em 0 0 0;
    padding: 0 0 0 95px;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    -webkit-transition: -webkit-transform 0.7s ease-out 0s;
    transition: -webkit-transform 0.7s ease-out 0s;
    transition: transform 0.7s ease-out 0s;
    transition: transform 0.7s ease-out 0s, -webkit-transform 0.7s ease-out 0s; }
    [data-font-size="large"] #main-visual section {
      right: 330px; }
    [data-font-size="xlarge"] #main-visual section {
      right: 400px; }
    #main-visual section h2 {
      position: relative;
      margin: 0;
      padding: 1.3em 0 0;
      font-size: 3.2em;
      font-weight: normal;
      line-height: 1.1em; }
      [lang="ja"] #main-visual section h2:before {
        display: block;
        content: "";
        position: absolute;
        top: 0.55em;
        left: -95px;
        width: 80px;
        height: 1px;
        border-top: 1px solid #fff; }
      #main-visual section h2 .sub {
        position: absolute;
        top: 0;
        left: 0;
        font-size: 0.3em;
        font-weight: 700;
        text-transform: uppercase; }
    #main-visual section p {
      margin: 0.5em 0 0;
      font-size: 0.95em;
      font-weight: 700; }
    #main-visual section .btn {
      margin: 3.5em 0 0;
      padding: 24px 70px 23px 40px;
      font-size: 1em;
      background: rgba(0, 0, 0, 0.2);
      border: 2px solid rgba(255, 255, 255, 0.3);
      -webkit-box-shadow: none;
              box-shadow: none;
      color: #fff;
      text-shadow: none; }
      #main-visual section .btn:before {
        background: #fff; }
      #main-visual section .btn:after {
        background: url(../assets/sprites/parts.svg) no-repeat;
        background-position: -140px -120px;
        background-size: 275px 227px;
        width: 26px;
        height: 20px; }
  #main-visual .buttons {
    position: absolute;
    z-index: 100;
    bottom: 50%;
    right: 120px;
    -webkit-transform: translate(50%, 50%);
            transform: translate(50%, 50%);
    text-align: center;
    line-height: 1.1em;
    text-transform: uppercase; }
    [data-font-size="large"] #main-visual .buttons {
      right: 140px;
      width: 260px; }
    [data-font-size="xlarge"] #main-visual .buttons {
      right: 165px;
      width: 310px; }
    #main-visual .buttons ul {
      margin: 30px 0 0;
      padding: 0;
      list-style-type: none;
      font-weight: bold; }
      #main-visual .buttons ul li {
        margin: 1em 0; }
        #main-visual .buttons ul li a {
          position: relative;
          text-decoration: none;
          border-bottom: 1px solid #fff; }
          #main-visual .buttons ul li a:hover {
            border-bottom-width: 2px; }
  #main-visual .play-btn,
  #main-visual .stop-btn {
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    display: none;
    margin: 0 auto;
    background: transparent;
    border: none;
    text-align: center;
    text-transform: uppercase;
    text-decoration: none;
    font-size: 1.2em;
    font-weight: 700;
    line-height: 1.2;
    text-shadow: 0 0 0.7em rgba(0, 0, 0, 0.7), 0 0 1.2em rgba(0, 0, 0, 0.7);
    cursor: pointer;
    -webkit-transition: bottom 0.7s ease-in-out 0s;
    transition: bottom 0.7s ease-in-out 0s; }
    [data-font-size="xlarge"] #main-visual .play-btn, [data-font-size="xlarge"]
    #main-visual .stop-btn {
      font-size: 1em; }
    #main-visual .play-btn.show,
    #main-visual .stop-btn.show {
      display: block; }
    #main-visual .play-btn:hover,
    #main-visual .stop-btn:hover {
      text-decoration: underline; }
    #main-visual .play-btn:before,
    #main-visual .stop-btn:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -70px 0;
      background-size: 275px 227px;
      width: 70px;
      height: 70px;
      content: "";
      display: block;
      margin: 0 auto 15px; }
  #main-visual .summit-info {
    position: absolute;
    z-index: 20;
    bottom: 0;
    right: 0;
    width: 240px;
    padding: 20px 0 5px;
    border-top: 1px solid rgba(255, 255, 255, 0.3);
    font-size: 1.03em;
    text-align: center;
    text-transform: uppercase;
    font-weight: 700;
    text-shadow: 0 0 0.7em rgba(0, 0, 0, 0.7), 0 0 1.2em rgba(0, 0, 0, 0.7);
    -webkit-transition: opacity 0.2s linear 0s;
    transition: opacity 0.2s linear 0s; }
    [data-font-size="large"] #main-visual .summit-info {
      width: 280px; }
    [data-font-size="xlarge"] #main-visual .summit-info {
      width: 330px; }
    #main-visual .summit-info p {
      margin: 5px 0;
      line-height: 1.5; }
      #main-visual .summit-info p:first-child {
        margin-bottom: 18px;
        font-size: 0.8em; }
      #main-visual .summit-info p .days {
        display: block;
        margin: 0;
        font-size: 3em;
        line-height: 1;
        letter-spacing: 0.05em; }
        #main-visual .summit-info p .days .suffix {
          font-size: 0.33em;
          margin-left: 0.1em; }
  #main-visual .player-container {
    position: absolute;
    z-index: 1;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    opacity: 0;
    -webkit-transition: opacity 0.4s linear 0s;
    transition: opacity 0.4s linear 0s; }
  #main-visual .youtube-player {
    display: block; }
  #main-visual .image {
    z-index: 2;
    -webkit-transition: opacity 0.4s linear 0s;
    transition: opacity 0.4s linear 0s;
    background-position: center 50px; }
  #main-visual noscript .bg-image {
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: transparent url(../assets/top_mainvisual.jpg) no-repeat center top; }
  [data-font-size="large"] #main-visual.playing,
  [data-font-size="xlarge"] #main-visual.playing {
    min-height: 800px; }
  #main-visual.playing:after {
    opacity: 0; }
  #main-visual.playing section {
    -webkit-transform: translate(-100%, -50%);
            transform: translate(-100%, -50%);
    -webkit-transition: -webkit-transform 0.3s ease-in 0s;
    transition: -webkit-transform 0.3s ease-in 0s;
    transition: transform 0.3s ease-in 0s;
    transition: transform 0.3s ease-in 0s, -webkit-transform 0.3s ease-in 0s; }
  #main-visual.playing .play-btn:before {
    background: url(../assets/sprites/parts.svg) no-repeat;
    background-position: 0 0;
    background-size: 275px 227px;
    width: 70px;
    height: 70px; }
  #main-visual.playing .summit-info {
    opacity: 0; }
  #main-visual.playing .player-container {
    opacity: 1;
    z-index: 20; }
  #main-visual.playing .image {
    opacity: 0; }

@media (max-width: 800px) {
  #main-visual {
    height: auto;
    min-height: 0px; }
    #main-visual:after {
      display: none; }
    #main-visual .content {
      position: relative; }
    #main-visual section {
      position: relative;
      z-index: 20;
      top: 0;
      margin: 0;
      padding: 110px 15px 60px;
      -webkit-transform: translate(0, 0);
              transform: translate(0, 0);
      -webkit-transition: none;
      transition: none;
      text-align: center; }
      #main-visual section h2 {
        font-size: 1.5em;
        line-height: 1.3; }
        #main-visual section h2 .sub {
          display: block;
          position: relative;
          margin-bottom: 40px; }
      #main-visual section p {
        margin: 10px 0;
        font-size: 0.75em;
        line-height: 1.6; }
      #main-visual section .btn {
        margin: 17px 0 0.8em;
        font-size: 0.9em; }
      #main-visual section:before {
        content: "";
        display: block;
        position: absolute;
        top: 84px;
        left: 50%;
        margin-left: -1px;
        width: 1px;
        height: 40px;
        background: #fff; }
    #main-visual .buttons {
      position: relative;
      top: 0;
      left: 0;
      bottom: auto;
      right: auto;
      -webkit-transform: none;
              transform: none;
      margin: -60px 0 30px; }
      #main-visual .buttons ul {
        margin: 0; }
    #main-visual .play-btn.show {
      display: none; }
    #main-visual .summit-info {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      position: relative;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      top: auto;
      left: auto;
      bottom: auto;
      right: auto;
      padding: 0;
      padding: 5px 15px;
      width: 100%;
      -webkit-box-sizing: border-box;
              box-sizing: border-box; }
      #main-visual .summit-info p {
        margin: 0;
        -webkit-box-flex: 1;
            -ms-flex: 1;
                flex: 1;
        text-align: left;
        font-size: 0.7em;
        white-space: nowrap; }
        #main-visual .summit-info p:first-child {
          margin: 0; }
        #main-visual .summit-info p:last-child {
          text-align: right;
          font-size: 0.9em; } }

main {
  position: relative;
  background: rgba(204, 204, 204, 0.2);
  color: #000;
  overflow: hidden; }
  main:after {
    content: "";
    display: block;
    position: fixed;
    z-index: 1510;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.8);
    -webkit-transform: translate(0, -100%);
            transform: translate(0, -100%);
    opacity: 0;
    -webkit-transition: opacity 0.2s linear 0s, -webkit-transform 0s linear 0.2s;
    transition: opacity 0.2s linear 0s, -webkit-transform 0s linear 0.2s;
    transition: opacity 0.2s linear 0s, transform 0s linear 0.2s;
    transition: opacity 0.2s linear 0s, transform 0s linear 0.2s, -webkit-transform 0s linear 0.2s;
    pointer-events: none; }
    .loading main:after {
      -webkit-transform: translate(0, 0);
              transform: translate(0, 0);
      opacity: 1;
      -webkit-transition: opacity 0.2s linear 0s;
      transition: opacity 0.2s linear 0s; }
  main .page-title {
    margin-top: 250px;
    position: relative;
    min-height: 210px;
    background: #111;
    color: #fff;
    text-shadow: 0 0 0.7em rgba(0, 0, 0, 0.7), 0 0 1.2em rgba(0, 0, 0, 0.7);
    overflow: hidden;
    text-transform: uppercase; }
    main .page-title .image {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
    main .page-title noscript .bg-image {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: transparent none no-repeat center 100%;
      background-size: cover; }
      [data-path="engagementgroups"] main .page-title noscript .bg-image {
        background-image: url(../assets/engagementgroups_top.jpg); }
      [data-path="links"] main .page-title noscript .bg-image {
        background-image: url(../assets/links_top.jpg); }
      [data-path="news"] main .page-title noscript .bg-image {
        background-image: url(../assets/news_top.jpg); }
      [data-path="events"] main .page-title noscript .bg-image {
        background-image: url(../assets/events_top.jpg); }
      [data-path="media"] main .page-title noscript .bg-image {
        background-image: url(../assets/media_top.jpg); }
      [data-path="photos"] main .page-title noscript .bg-image {
        background-image: url(../assets/photos_top.jpg); }
      [data-path="summit"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_top.jpg); }
      [data-path="summit/about"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_about.jpg); }
      [data-path="summit/faq"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_faq.jpg); }
      [data-path="summit/theme"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_theme.jpg); }
      [data-path="summit/message"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_message.jpg); }
      [data-path="summit/ministerialmeetings"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_ministerialmeetings.jpg); }
      [data-path="summit/osaka"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_osaka.jpg); }
      [data-path="summit/previoussummits"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_previoussummits.jpg); }
      [data-path="summit/schedule"] main .page-title noscript .bg-image {
        background-image: url(../assets/summit_schedule.jpg); }
    main .page-title nav {
      position: relative;
      z-index: 1; }
      main .page-title nav ul {
        position: relative;
        margin: 0 40px;
        padding: 12px 0;
        list-style-type: none; }
        main .page-title nav ul li {
          display: inline-block;
          position: relative;
          margin: 0 0 0 45px;
          font-size: 0.75em;
          font-weight: 700; }
          main .page-title nav ul li:before {
            background: url(../assets/sprites/parts.svg) no-repeat;
            background-position: -249.01px -126.19px;
            background-size: 275px 227px;
            width: 20px;
            height: 20px;
            content: "";
            display: inline-block;
            position: absolute;
            top: 50%;
            left: -25px;
            margin-top: 1px;
            -webkit-transform: translate(-50%, -50%);
                    transform: translate(-50%, -50%); }
          main .page-title nav ul li:first-child {
            margin-left: 0; }
            main .page-title nav ul li:first-child:before {
              display: none; }
          main .page-title nav ul li a {
            text-decoration: none;
            border-bottom: 1px solid #fff; }
            main .page-title nav ul li a:hover {
              border-bottom-width: 2px; }
    main .page-title .copyright {
      position: absolute;
      z-index: 2;
      top: 15px;
      right: 18px;
      text-align: right;
      font-size: 0.7em;
      color: #fff;
      text-transform: none;
      pointer-events: none; }
    main .page-title .content {
      position: relative;
      z-index: 2;
      margin: 140px 95px 40px 95px; }
      main .page-title .content h1,
      main .page-title .content p {
        margin: 0;
        font: inherit;
        line-height: 1; }
      main .page-title .content h1 {
        position: relative;
        margin: 0 0 18px;
        font-size: 2.5em;
        line-height: 1.2em; }
        main .page-title .content h1:before, main .page-title .content h1:after {
          content: "";
          display: block;
          position: absolute; }
        main .page-title .content h1:before {
          top: -90px;
          left: 15px;
          -webkit-transform: scale(2, 2);
                  transform: scale(2, 2); }
        main .page-title .content h1:after {
          top: -30.5px;
          left: 0;
          width: 60px;
          border-top: 1px solid rgba(255, 255, 255, 0.5); }
      main .page-title .content .sub-title {
        position: absolute;
        top: -70px;
        left: 0;
        font-size: 0.85em;
        font-weight: 700;
        text-transform: uppercase;
        line-height: 1em; }
      main .page-title .content p {
        margin: 0;
        font-size: 0.85em;
        line-height: 1.4;
        font-weight: 700; }
    main .page-title.no-image {
      background: #fff;
      color: #000;
      text-shadow: none; }
      main .page-title.no-image .content h1:after {
        border-top-color: rgba(0, 0, 0, 0.2); }
      main .page-title.no-image nav ul li:before {
        background: url(../assets/sprites/parts.svg) no-repeat;
        background-position: -249.01px -86.19px;
        background-size: 275px 227px;
        width: 20px;
        height: 20px; }
    main .page-title[data-category="summit"] .content h1:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -180px -137.68px;
      background-size: 275px 227px;
      width: 30px;
      height: 30px; }
    main .page-title[data-category="news"] .content h1:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -60px -169px;
      background-size: 275px 227px;
      width: 26px;
      height: 30px; }
    main .page-title[data-category="documents"] .content h1:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -70px -140px;
      background-size: 275px 227px;
      width: 30px;
      height: 26px; }
    main .page-title[data-category="events"] .content h1:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: 0 -199px;
      background-size: 275px 227px;
      width: 28px;
      height: 28px; }
    main .page-title[data-category="photos"] .content h1:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -100px -140px;
      background-size: 275px 227px;
      width: 30px;
      height: 26px; }
    main .page-title[data-category="media"] .content h1:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -142px -169px;
      background-size: 275px 227px;
      width: 30px;
      height: 30px; }
    main .page-title[data-category="links"] .content h1:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -220px -87.01px;
      background-size: 275px 227px;
      width: 28px;
      height: 28px; }

@media (max-width: 800px) {
  main .page-title {
    min-height: 220px;
    height: auto;
    margin-top: 80px; }
    main .page-title nav {
      display: none; }
    main .page-title .copyright {
      top: 13px;
      right: 13px;
      padding: 0;
      font-size: 0.5em; }
    main .page-title .content {
      margin: 100px 20px 30px; }
      main .page-title .content h1 {
        margin: 0 0 10px;
        font-size: 1.5em; }
        main .page-title .content h1:before {
          top: -54px;
          left: 1px;
          -webkit-transform: scale(1, 1);
                  transform: scale(1, 1);
          -webkit-transform-origin: 0 0;
                  transform-origin: 0 0; }
        main .page-title .content h1:after {
          top: -15px;
          width: 35px; }
      main .page-title .content .sub-title {
        top: -45px; } }

img.icon-pdf {
  display: inline-block; }

.accordion-list {
  margin: 30px 0; }
  .accordion-list > ol,
  .accordion-list > ul {
    margin: 0;
    padding: 0;
    list-style-type: none; }
    .accordion-list > ol > li,
    .accordion-list > ul > li {
      position: relative;
      margin: 38px 0;
      overflow: hidden;
      background: rgba(204, 204, 204, 0.2);
      border: 1px solid rgba(204, 204, 204, 0.6); }
      .accordion-list > ol > li:first-child,
      .accordion-list > ul > li:first-child {
        margin-top: 0; }
      .accordion-list > ol > li:last-child,
      .accordion-list > ul > li:last-child {
        margin-bottom: 0; }
      .accordion-list > ol > li .title,
      .accordion-list > ol > li .content,
      .accordion-list > ul > li .title,
      .accordion-list > ul > li .content {
        position: relative;
        -webkit-box-sizing: border-box;
                box-sizing: border-box; }
      .accordion-list > ol > li .title,
      .accordion-list > ul > li .title {
        display: block;
        z-index: 2;
        padding: 25px 115px 25px 25px;
        font-size: 1.7em;
        overflow: hidden;
        -webkit-user-select: none;
           -moz-user-select: none;
            -ms-user-select: none;
                user-select: none; }
        .accordion-list > ol > li .title h2,
        .accordion-list > ol > li .title h3,
        .accordion-list > ul > li .title h2,
        .accordion-list > ul > li .title h3 {
          margin: 0;
          padding: 0;
          font-size: inherit;
          text-transform: uppercase;
          font-weight: normal; }
      .accordion-list > ol > li a.title,
      .accordion-list > ul > li a.title {
        text-decoration: none; }
        .accordion-list > ol > li a.title h2,
        .accordion-list > ol > li a.title h3,
        .accordion-list > ul > li a.title h2,
        .accordion-list > ul > li a.title h3 {
          display: inline;
          text-decoration: none;
          border-bottom: 1px solid #06c; }
        .accordion-list > ol > li a.title:hover h2,
        .accordion-list > ol > li a.title:hover h3,
        .accordion-list > ul > li a.title:hover h2,
        .accordion-list > ul > li a.title:hover h3 {
          border-bottom-width: 2px; }
      .accordion-list > ol > li .content,
      .accordion-list > ul > li .content {
        padding: 38px;
        font-size: 1.1em;
        border-top: 1px solid rgba(204, 204, 204, 0.6);
        overflow: hidden; }
        .accordion-list > ol > li .content[aria-hidden="true"],
        .accordion-list > ul > li .content[aria-hidden="true"] {
          display: none;
          position: absolute;
          top: 0;
          left: 0;
          opacity: 0;
          -webkit-transform: translate(0, -100%);
                  transform: translate(0, -100%);
          -webkit-transition: opacity 0.2s linear 0s;
          transition: opacity 0.2s linear 0s; }
        .accordion-list > ol > li .content p:first-child,
        .accordion-list > ul > li .content p:first-child {
          margin-top: 0; }
        .accordion-list > ol > li .content p:last-child,
        .accordion-list > ul > li .content p:last-child {
          margin-bottom: 0; }
        .accordion-list > ol > li .content img,
        .accordion-list > ul > li .content img {
          vertical-align: middle; }
        .accordion-list > ol > li .content ul,
        .accordion-list > ul > li .content ul {
          margin: 0;
          padding: 0;
          list-style-type: none; }
          .accordion-list > ol > li .content ul li,
          .accordion-list > ul > li .content ul li {
            margin: 0.2em; }
            .accordion-list > ol > li .content ul li:first-child,
            .accordion-list > ul > li .content ul li:first-child {
              margin-top: 0; }
            .accordion-list > ol > li .content ul li:last-child,
            .accordion-list > ul > li .content ul li:last-child {
              margin-bottom: 0; }
            .accordion-list > ol > li .content ul li ul,
            .accordion-list > ul > li .content ul li ul {
              margin: 0.5em 0 0.5em 1em; }
          .accordion-list > ol > li .content ul.ordered,
          .accordion-list > ul > li .content ul.ordered {
            padding-left: 2.6em; }
            .accordion-list > ol > li .content ul.ordered li,
            .accordion-list > ul > li .content ul.ordered li {
              text-indent: -2.6em; }
            [lang="en"] .accordion-list > ol > li .content ul.ordered, [lang="en"]
            .accordion-list > ul > li .content ul.ordered {
              padding-left: 1.4em; }
              [lang="en"] .accordion-list > ol > li .content ul.ordered li, [lang="en"]
              .accordion-list > ul > li .content ul.ordered li {
                text-indent: -1.4em; }
        .accordion-list > ol > li .content dl dt,
        .accordion-list > ol > li .content dl dd,
        .accordion-list > ul > li .content dl dt,
        .accordion-list > ul > li .content dl dd {
          float: left;
          margin: 0; }
        .accordion-list > ol > li .content dl dt,
        .accordion-list > ul > li .content dl dt {
          clear: left; }
          [lang="en"] .accordion-list > ol > li .content dl dt, [lang="en"]
          .accordion-list > ul > li .content dl dt {
            margin-right: 0.5em; }
        .accordion-list > ol > li .content pre,
        .accordion-list > ul > li .content pre {
          margin: 0 2em; }
  .accordion-list > ol > li .title:after,
  .accordion-list > ol > li .content:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 80px;
    height: 100%;
    border-left: 1px solid rgba(204, 204, 204, 0.6); }
  .accordion-list > ol > li .title {
    padding: 25px 25px 25px 0; }
    .accordion-list > ol > li .title h2 {
      padding-left: 115px; }
    .accordion-list > ol > li .title .num {
      display: block;
      position: absolute;
      top: 50%;
      left: 40px;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%); }
  .accordion-list > ol > li .content {
    padding-left: 115px; }
  .accordion-list.faq > ul > li .title:before, .accordion-list.faq > ul > li .title:after,
  .accordion-list.faq > ul > li .content:before,
  .accordion-list.faq > ul > li .content:after {
    content: "";
    display: block;
    position: absolute; }
  .accordion-list.faq > ul > li .title:before,
  .accordion-list.faq > ul > li .content:before {
    background: url(../assets/sprites/parts.svg) no-repeat;
    background-position: -180px -107.3px;
    background-size: 275px 227px;
    width: 24.66px;
    height: 30.38px;
    top: 50%;
    left: 40px;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%); }
  .accordion-list.faq > ul > li .title:after,
  .accordion-list.faq > ul > li .content:after {
    top: 0;
    left: 80px;
    height: 100%;
    border-left: 1px solid rgba(204, 204, 204, 0.6); }
  .accordion-list.faq > ul > li .title {
    padding-left: 115px; }
  .accordion-list.faq > ul > li .content {
    padding-left: 115px; }
    .accordion-list.faq > ul > li .content:before {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -220px -171.01px;
      background-size: 275px 227px;
      width: 26.13px;
      height: 27.06px;
      top: 50px; }

@media (max-width: 800px) {
  .accordion-list {
    margin: 15px -27px 0; }
    .accordion-list > ol > li,
    .accordion-list > ul > li {
      margin: 28px 0;
      border-left: none;
      border-right: none; }
      .accordion-list > ol > li .title,
      .accordion-list > ul > li .title {
        padding: 20px;
        font-size: 1em; }
      .accordion-list > ol > li .content,
      .accordion-list > ul > li .content {
        padding: 20px;
        font-size: 1em; }
        .accordion-list > ol > li .content:before,
        .accordion-list > ul > li .content:before {
          top: 30px; }
    .accordion-list ol li .title:before,
    .accordion-list ol li .content:before {
      left: 30px; }
    .accordion-list ol li .title:after,
    .accordion-list ol li .content:after {
      left: 60px; }
    .accordion-list ol li .title {
      padding: 0; }
      .accordion-list ol li .title h2 {
        padding: 20px;
        padding-left: 80px; }
      .accordion-list ol li .title .num {
        left: 30px; }
    .accordion-list ol li .content {
      padding-left: 80px; }
    .accordion-list.faq ul li .title:before,
    .accordion-list.faq ul li .content:before {
      left: 30px; }
    .accordion-list.faq ul li .title:after,
    .accordion-list.faq ul li .content:after {
      left: 60px; }
    .accordion-list.faq ul li .title {
      padding-left: 100px; }
    .accordion-list.faq ul li .content {
      padding-left: 100px; } }

main .splitview + .article-container {
  border-top: 1px solid rgba(204, 204, 204, 0.6); }

main article,
main .article {
  position: relative;
  padding: 50px 95px;
  background: #fff;
  border-bottom: 1px solid rgba(204, 204, 204, 0.6); }
  main article:last-child,
  main .article:last-child {
    border-bottom: none; }
  main article.colored:before,
  main .article.colored:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(204, 204, 204, 0.2); }
  main article.border-less,
  main .article.border-less {
    padding-bottom: 1px;
    border-bottom: none; }
  main article h2,
  main .article h2 {
    position: relative;
    margin: 100px 0 55px;
    padding-top: 1.7em;
    font-size: 1em;
    font-weight: normal;
    text-transform: uppercase; }
    main article h2:first-child,
    main .article h2:first-child {
      margin-top: 30px; }
    main article h2 .sub,
    main .article h2 .sub {
      display: inline-block;
      position: absolute;
      top: 0;
      left: 0;
      font-size: 0.9em;
      font-weight: 700;
      text-transform: uppercase;
      color: #666;
      line-height: 1em; }
      main article h2 .sub .num,
      main .article h2 .sub .num {
        position: relative;
        display: inline-block;
        margin-left: 70px; }
        main article h2 .sub .num:before,
        main .article h2 .sub .num:before {
          content: "";
          display: block;
          position: absolute;
          top: 50%;
          left: -55px;
          -webkit-transform: translate(0, -50%);
                  transform: translate(0, -50%);
          width: 40px;
          height: 1px;
          border-top: 1px solid #666; }
    main article h2 .title,
    main .article h2 .title {
      display: inline-block;
      font-size: 2em;
      color: #000;
      line-height: 1.3333333em; }
  main article h2 + .main-image,
  main .article h2 + .main-image {
    margin: 0 0 50px; }
    main article h2 + .main-image img,
    main .article h2 + .main-image img {
      display: block;
      width: 100%;
      height: auto; }
  main article a,
  main .article a {
    color: #06c; }
  main article .top-level-link,
  main .article .top-level-link {
    margin: 15px;
    text-align: center; }
    main article .top-level-link .btn,
    main .article .top-level-link .btn {
      margin: 0 auto;
      min-width: 300px; }
  main article .logo-box,
  main .article .logo-box {
    padding: 45px 0;
    border: 1px solid rgba(204, 204, 204, 0.6);
    text-align: center; }
  main article .placeinfo,
  main .article .placeinfo {
    position: relative;
    margin: 0 -95px;
    padding: 0 60% 0 0;
    background: rgba(204, 204, 204, 0.2); }
    main article .placeinfo h2,
    main .article .placeinfo h2 {
      margin: 0;
      padding: 28px 58px;
      background: #666;
      color: #fff;
      text-transform: uppercase;
      font-weight: 700;
      line-height: 1; }
    main article .placeinfo .content,
    main .article .placeinfo .content {
      padding: 58px; }
      main article .placeinfo .content h3,
      main .article .placeinfo .content h3 {
        margin: 2.5em 0 0;
        font-size: 1em;
        color: #000; }
        main article .placeinfo .content h3:first-child,
        main .article .placeinfo .content h3:first-child {
          margin-top: 0; }
      main article .placeinfo .content dl,
      main .article .placeinfo .content dl {
        margin: 0.5em 0; }
        main article .placeinfo .content dl dt,
        main .article .placeinfo .content dl dt {
          clear: left;
          float: left;
          margin-right: 0.5em; }
          main article .placeinfo .content dl dt:after,
          main .article .placeinfo .content dl dt:after {
            content: ":"; }
      main article .placeinfo .content .note,
      main .article .placeinfo .content .note {
        font-size: 0.75em;
        color: #000; }
    main article .placeinfo .map,
    main .article .placeinfo .map {
      position: absolute;
      top: 0;
      right: 0;
      width: 50%;
      height: 100%;
      margin: 0;
      background: #a0abb2 url(../assets/summit_osaka_map.png) no-repeat center center;
      background-size: cover; }
  main article .infobox h2,
  main .article .infobox h2 {
    margin: 0;
    padding: 23px 58px;
    background: #06c;
    color: #fff;
    text-transform: uppercase;
    font-weight: 700;
    line-height: 1; }
  main article .infobox .content,
  main .article .infobox .content {
    padding: 58px;
    background: rgba(204, 204, 204, 0.2); }
    main article .infobox .content h3,
    main .article .infobox .content h3 {
      margin: 2.5em 0 0;
      font-size: 1em;
      color: #000; }
      main article .infobox .content h3:first-child,
      main .article .infobox .content h3:first-child {
        margin-top: 0; }
    main article .infobox .content h3 + p,
    main .article .infobox .content h3 + p {
      margin-top: 0; }

main .engagementgroup-link {
  padding: 20px 95px;
  background: rgba(204, 204, 204, 0.6);
  text-align: center; }
  main .engagementgroup-link .btn {
    min-width: 300px; }

@media (max-width: 800px) {
  main article,
  main .article {
    padding: 45px 27px; }
    main article h2,
    main .article h2 {
      margin: 100px 0 55px;
      padding-top: 0.8em; }
      main article h2:first-child,
      main .article h2:first-child {
        margin-top: 15px; }
      main article h2 .sub,
      main .article h2 .sub {
        font-size: 0.6em; }
      main article h2 .title,
      main .article h2 .title {
        margin-top: 5px;
        font-size: 1.5em; }
    main article h2 + .main-image,
    main .article h2 + .main-image {
      margin: 0 -27px 40px; }
      main article h2 + .main-image img,
      main .article h2 + .main-image img {
        display: block;
        width: 100%; }
    main article > .main-image:last-child,
    main .article > .main-image:last-child {
      margin: 30px -27px 0; }
    main article .top-level-link,
    main .article .top-level-link {
      margin: 15px auto; }
      main article .top-level-link .btn,
      main .article .top-level-link .btn {
        display: block;
        min-width: 0; }
    main article .logo-box img,
    main .article .logo-box img {
      width: 60%;
      height: auto; }
    main article .placeinfo,
    main .article .placeinfo {
      margin: 0;
      padding: 0; }
      main article .placeinfo h2,
      main .article .placeinfo h2 {
        margin: 0;
        padding: 15px 30px;
        background: #666;
        color: #fff;
        text-transform: uppercase;
        font-weight: 700;
        line-height: 1; }
      main article .placeinfo .content,
      main .article .placeinfo .content {
        padding: 30px 28px; }
      main article .placeinfo .map,
      main .article .placeinfo .map {
        position: relative;
        top: 0;
        right: 0;
        width: 100%;
        height: 300px; }
    main article .infobox h2,
    main .article .infobox h2 {
      padding: 15px 28px; }
    main article .infobox .content,
    main .article .infobox .content {
      padding: 30px 28px 15px; }
      main article .infobox .content h3,
      main .article .infobox .content h3 {
        margin: 1.5em 0 0; }
  main .engagementgroup-link {
    padding: 27px; }
    main .engagementgroup-link .btn {
      display: block;
      min-width: 0; } }

@-webkit-keyframes titlelineload {
  0% {
    width: 0%; }
  30% {
    width: 100%; }
  80% {
    left: 0;
    width: 100%; }
  100% {
    left: 100%;
    width: 0; } }

@keyframes titlelineload {
  0% {
    width: 0%; }
  30% {
    width: 100%; }
  80% {
    left: 0;
    width: 100%; }
  100% {
    left: 100%;
    width: 0; } }

.breadcrumb-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid rgba(204, 204, 204, 0.6);
  background: #FFF;
  color: #000;
  font-size: .75em;
  font-weight: 700;
  text-transform: uppercase; }
  .breadcrumb-list ul {
    position: relative;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin: 0;
    padding: 28px 40px;
    list-style-type: none; }
    .breadcrumb-list ul li {
      display: inline-block;
      position: relative;
      margin: 0 0 0 50px; }
      .breadcrumb-list ul li:before {
        background: url(../assets/sprites/parts.svg) no-repeat;
        background-position: -249.01px -86.19px;
        background-size: 275px 227px;
        width: 20px;
        height: 20px;
        content: "";
        display: inline-block;
        position: absolute;
        top: 50%;
        left: -25px;
        margin-top: 1px;
        -webkit-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%); }
      .breadcrumb-list ul li:first-child {
        margin-left: 0; }
        .breadcrumb-list ul li:first-child:before {
          display: none; }
      .breadcrumb-list ul li a {
        text-decoration: none;
        border-bottom: 1px solid #666; }
        .breadcrumb-list ul li a:hover, .breadcrumb-list ul li a:focus {
          border-bottom-width: 2px; }
  .breadcrumb-list .page-top-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
    padding: 28px 58px 28px 28px;
    border-left: 1px solid rgba(204, 204, 204, 0.6);
    text-decoration: none;
    overflow: hidden;
    cursor: pointer; }
    .breadcrumb-list .page-top-link:after {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -180px -40px;
      background-size: 275px 227px;
      width: 20px;
      height: 34px;
      content: "";
      display: inline-block;
      position: absolute;
      top: 50%;
      right: 28px;
      -webkit-transform: translate(0, -50%);
              transform: translate(0, -50%);
      -webkit-transition: -webkit-transform .2s ease-out 0s;
      transition: -webkit-transform .2s ease-out 0s;
      transition: transform .2s ease-out 0s;
      transition: transform .2s ease-out 0s, -webkit-transform .2s ease-out 0s;
      vertical-align: middle; }
    .breadcrumb-list .page-top-link:hover:after, .breadcrumb-list .page-top-link:focus:after {
      -webkit-transform: translate(0, -58%);
              transform: translate(0, -58%); }

@media (max-width: 800px) {
  .breadcrumb-list {
    display: none; } }

.btn {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: inline-block;
  position: relative;
  padding: 24px 60px 23px 30px;
  background: #fff;
  -webkit-box-shadow: 0 0 2em rgba(0, 0, 0, 0.07);
          box-shadow: 0 0 2em rgba(0, 0, 0, 0.07);
  border: none;
  border-radius: 10em;
  text-decoration: none;
  text-transform: uppercase;
  font: inherit;
  font-size: 0.85em;
  line-height: 1;
  font-weight: 700;
  text-align: center;
  white-space: nowrap;
  color: #06c;
  -webkit-tap-highlight-color: transparent;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  cursor: pointer;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
  -webkit-transition: opacity 0.1s linear 0s;
  transition: opacity 0.1s linear 0s;
  overflow: hidden; }
  .btn:before, .btn:after,
  .btn img {
    display: block;
    position: absolute;
    -webkit-transform: translate(50%, -50%);
            transform: translate(50%, -50%); }
  .btn:before, .btn:after {
    content: ""; }
  .btn:before {
    top: 50%;
    right: 32px;
    width: 30px;
    height: 30px;
    background: #06c;
    border-radius: 100%; }
  .btn:after {
    background: url(../assets/sprites/parts.svg) no-repeat;
    background-position: -28px -199px;
    background-size: 275px 227px;
    width: 26px;
    height: 20px;
    z-index: 10;
    top: 50%;
    right: 32px; }

  .btn img {
    z-index: 10;
    top: 50%;
    right: 20px; }
  .btn:active {
    top: 0.1em; }

.pc .btn {
  -webkit-transition-timing-function: ease-out;
          transition-timing-function: ease-out; }
  .pc .btn:hover, .pc .btn:focus {
    text-decoration: underline; }

@media (max-width: 360px) {
  .btn[href="/en/summit/"] {
    padding: 24px 50px 23px 20px; } }

@media (max-width: 330px) {
  .btn[href="/en/summit/"] {
    padding: 24px 55px 23px 15px;
    font-size: 0.8em; } }

.cookie-alert {
  display: none;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: fixed;
  z-index: 1400;
  bottom: 0;
  left: 0;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: rgba(0, 102, 204, 0.95);
  font-weight: bold;
  color: #FFF;
  overflow: hidden; }
  .cookie-alert.show {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center; }
  .cookie-alert p {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin: 0 0;
    padding: 10px 0 10px 20px;
    font-size: .8em;
    letter-spacing: -.01em; }
  .cookie-alert .ok.btn {
    display: block;
    margin: 14px 0 14px 20px;
    padding: 10px 35px 10px 20px;
    background: #FFF;
    border: none;
    color: #06c;
    -webkit-box-shadow: none;
            box-shadow: none; }
    .cookie-alert .ok.btn:before {
      display: none; }
    .cookie-alert .ok.btn:after {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -249.01px -68.19px;
      background-size: 275px 227px;
      width: 20px;
      height: 18px;
      right: 18px; }
  .cookie-alert .close-btn {
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    display: block;
    position: relative;
    background: transparent;
    border: none;
    margin: 14px 10px 14px 15px;
    padding: 0 5px;
    font-size: .8em;
    font-weight: bold;
    white-space: nowrap;
    text-transform: uppercase;
    cursor: pointer; }
    .cookie-alert .close-btn:before {
      content: "";
      display: block;
      position: absolute;
      bottom: 0;
      left: 3px;
      right: 25px;
      border-bottom: 1px solid #FFF; }
    .cookie-alert .close-btn:after {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -249.01px -106.19px;
      background-size: 275px 227px;
      width: 20px;
      height: 20px;
      content: "";
      display: inline-block;
      vertical-align: middle;
      margin: 0 0 0 .3em;
      -webkit-transform: translate(0, -1px);
              transform: translate(0, -1px); }
    .cookie-alert .close-btn:hover:before, .cookie-alert .close-btn:focus:before {
      border-bottom-width: 2px; }

@media (max-width: 800px) {
  .cookie-alert.show {
    display: none; } }

.country-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  list-style-type: none;
  margin: 30px -45px -10px 0;
  padding: 0; }
  .country-list ul li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 49.9999999%;
    margin: 0 0 40px 0;
    padding: 0 40px 0 0; }
    .country-list ul li .country {
      position: relative;
      display: block;
      width: 100%;
      background: rgba(204, 204, 204, 0.2);
      border-top: 4px solid #06c; }
      .country-list ul li .country:before {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        right: 0;
        width: 80px;
        height: 100%;
        border-left: 1px solid rgba(204, 204, 204, 0.6); }
      .country-list ul li .country:after {
        content: "";
        display: block;
        position: absolute;
        top: 50%;
        right: 40px;
        width: 36px;
        height: 36px;
        -webkit-transform: translate(50%, -50%);
                transform: translate(50%, -50%);
        background: transparent none no-repeat center center;
        background-size: contain; }
      .country-list ul li .country .name {
        position: relative;
        padding: 30px 106px 30px 26px;
        font-size: 1.4em;
        line-height: 1.2;
        text-align: left; }
      .country-list ul li .country[data-country="argentina"]:after {
        background-image: url(../assets/summit_participants_flag_argentina.png); }
      .country-list ul li .country[data-country="australia"]:after {
        background-image: url(../assets/summit_participants_flag_australia.png); }
      .country-list ul li .country[data-country="brazil"]:after {
        background-image: url(../assets/summit_participants_flag_brazil.png); }
      .country-list ul li .country[data-country="canada"]:after {
        background-image: url(../assets/summit_participants_flag_canada.png); }
      .country-list ul li .country[data-country="china"]:after {
        background-image: url(../assets/summit_participants_flag_china.png); }
      .country-list ul li .country[data-country="france"]:after {
        background-image: url(../assets/summit_participants_flag_france.png); }
      .country-list ul li .country[data-country="germany"]:after {
        background-image: url(../assets/summit_participants_flag_germany.png); }
      .country-list ul li .country[data-country="india"]:after {
        background-image: url(../assets/summit_participants_flag_india.png); }
      .country-list ul li .country[data-country="indonesia"]:after {
        background-image: url(../assets/summit_participants_flag_indonesia.png); }
      .country-list ul li .country[data-country="italy"]:after {
        background-image: url(../assets/summit_participants_flag_italy.png); }
      .country-list ul li .country[data-country="japan"]:after {
        background-image: url(../assets/summit_participants_flag_japan.png); }
      .country-list ul li .country[data-country="mexico"]:after {
        background-image: url(../assets/summit_participants_flag_mexico.png); }
      .country-list ul li .country[data-country="korea"]:after {
        background-image: url(../assets/summit_participants_flag_korea.png); }
      .country-list ul li .country[data-country="southafrica"]:after {
        background-image: url(../assets/summit_participants_flag_southafrica.png); }
      .country-list ul li .country[data-country="russia"]:after {
        background-image: url(../assets/summit_participants_flag_russia.png); }
      .country-list ul li .country[data-country="saudiarabia"]:after {
        background-image: url(../assets/summit_participants_flag_saudiarabia.png); }
      .country-list ul li .country[data-country="turkey"]:after {
        background-image: url(../assets/summit_participants_flag_turkey.png); }
      .country-list ul li .country[data-country="england"]:after {
        background-image: url(../assets/summit_participants_flag_england.png); }
      .country-list ul li .country[data-country="usa"]:after {
        background-image: url(../assets/summit_participants_flag_usa.png); }
      .country-list ul li .country[data-country="eu"]:after {
        background-image: url(../assets/summit_participants_flag_eu.png); }
      .country-list ul li .country[data-country="vietnam"]:after {
        background-image: url(../assets/summit_participants_flag_vietnam.png); }
      .country-list ul li .country[data-country="spain"]:after {
        background-image: url(../assets/summit_participants_flag_spain.png); }
      .country-list ul li .country[data-country="singapore"]:after {
        background-image: url(../assets/summit_participants_flag_singapore.png); }
      .country-list ul li .country[data-country="senegal"]:after {
        background-image: url(../assets/summit_participants_flag_senegal.png); }
      .country-list ul li .country[data-country="netherlands"]:after {
        background-image: url(../assets/summit_participants_flag_netherlands.png); }
      .country-list ul li .country[data-country="chile"]:after {
        background-image: url(../assets/summit_participants_flag_chile.png); }
      .country-list ul li .country[data-country="au"]:after {
        background-image: url(../assets/summit_participants_flag_au.png); }
      .country-list ul li .country[data-country="asean"]:after {
        background-image: url(../assets/summit_participants_flag_asean.png); }

@media (max-width: 800px) {
  .country-list ul {
    display: block; }
    .country-list ul li {
      display: block;
      width: auto; }
      .country-list ul li .country .name {
        padding: 20px 95px 20px 15px; } }

.event-list ul,
.article-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  position: relative;
  list-style-type: none;
  margin: 30px 0 0;
  padding: 0; }
  .event-list ul li,
  .article-list ul li {
    width: 33.3333333%;
    margin: 0 0 30px;
    border-left: 1px solid rgba(204, 204, 204, 0.6); }
    .event-list ul li a,
    .article-list ul li a {
      position: relative;
      display: block;
      margin-right: 2px;
      text-decoration: none; }
      .event-list ul li a:before,
      .article-list ul li a:before {
        content: "";
        display: block;
        position: absolute;
        z-index: 1;
        top: 0;
        left: -1px;
        right: 1px;
        border-top: 4px solid #06c; }
      .event-list ul li a:hover img.thumbnail,
      .article-list ul li a:hover img.thumbnail {
        opacity: 0.8; }
      .event-list ul li a:hover .footer,
      .article-list ul li a:hover .footer {
        text-decoration: underline; }
      .event-list ul li a img.thumbnail,
      .article-list ul li a img.thumbnail {
        position: relative;
        left: -1px;
        width: 100%;
        height: auto;
        vertical-align: top; }
      .event-list ul li a .title,
      .article-list ul li a .title {
        margin: 0 29px;
        padding: 37px 10px;
        min-height: 123px;
        border-bottom: 1px solid rgba(204, 204, 204, 0.6);
        font-weight: bold;
        line-height: 1.2em;
        color: #000; }
      .event-list ul li a .footer,
      .article-list ul li a .footer {
        position: relative;
        display: block;
        margin: 0 29px;
        padding: 27px 9px;
        color: #06c; }
        .event-list ul li a .footer:after,
        .article-list ul li a .footer:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -140px -40px;
          background-size: 275px 227px;
          width: 40px;
          height: 40px;
          content: "";
          display: block;
          position: absolute;
          top: 50%;
          right: 0;
          -webkit-transform: translate(0, -50%);
                  transform: translate(0, -50%); }

.article-list ul li {
  width: 49.999%; }

@media (max-width: 800px) {
  .event-list {
    margin: 0 0 -20px; }
    .event-list ul {
      display: block; }
      .event-list ul li {
        width: 100%;
        border-left: none; }
        .event-list ul li a .title {
          margin: 0;
          padding: 18px 0;
          min-height: 0; }
        .event-list ul li a .footer {
          margin: 0;
          padding: 13px 0;
          font-size: 0.85em; } }

@media (max-width: 1024px) {
  .article-list {
    margin: 0 0 -20px; }
    .article-list ul {
      display: block; }
      .article-list ul li {
        width: 100%;
        border-left: none; }
        .article-list ul li a .title {
          margin: 0;
          padding: 18px 0;
          min-height: 0; }
        .article-list ul li a .footer {
          margin: 0;
          padding: 13px 0;
          font-size: 0.85em; } }

.image-link-list {
  position: relative;
  margin: 30px -95px; }
  .image-link-list ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 0;
    padding: 0;
    list-style-type: none;
    background: rgba(204, 204, 204, 0.2); }
    .image-link-list ul li {
      position: relative;
      width: 33.33333333333%;
      overflow: hidden;
      background: #000;
      text-shadow: 0 0 0.7em rgba(0, 0, 0, 0.7), 0 0 1.2em rgba(0, 0, 0, 0.7), 0 0 1.2em rgba(0, 0, 0, 0.7); }
      [data-font-size="xlarge"] .image-link-list ul li {
        width: 49.99999%; }
      .image-link-list ul li:before, .image-link-list ul li:after {
        content: "";
        display: block;
        position: absolute; }
      .image-link-list ul li:before {
        z-index: 1;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        -webkit-transform-origin: center bottom;
                transform-origin: center bottom;
        background: #000 none no-repeat center center;
        background-size: cover;
        -webkit-transition: -webkit-transform 0.3s ease-out 0s;
        transition: -webkit-transform 0.3s ease-out 0s;
        transition: transform 0.3s ease-out 0s;
        transition: transform 0.3s ease-out 0s, -webkit-transform 0.3s ease-out 0s; }
      .image-link-list ul li:after {
        background: url(../assets/sprites/parts.svg) no-repeat;
        background-position: -70px -70px;
        background-size: 275px 227px;
        width: 60px;
        height: 60px;
        z-index: 10;
        bottom: 45px;
        right: 35px;
        -webkit-transform: translate(0, 50%);
                transform: translate(0, 50%);
        pointer-events: none; }
        [data-font-size="xlarge"] .image-link-list ul li:after {
          bottom: 68px; }
      .image-link-list ul li .copyright {
        position: absolute;
        z-index: 10;
        top: 9px;
        left: 9px;
        font-size: 0.7em;
        color: #fff;
        text-transform: none;
        pointer-events: none; }
      .image-link-list ul li:hover:before {
        -webkit-transform: scale(1.04, 1.04);
                transform: scale(1.04, 1.04);
        -webkit-transition: -webkit-transform 0.2s ease-out 0s;
        transition: -webkit-transform 0.2s ease-out 0s;
        transition: transform 0.2s ease-out 0s;
        transition: transform 0.2s ease-out 0s, -webkit-transform 0.2s ease-out 0s; }
      .image-link-list ul li a,
      .image-link-list ul li .box {
        position: relative;
        z-index: 2;
        display: block;
        height: 360px;
        color: #fff;
        text-decoration: none;
        overflow: hidden; }
        [data-font-size="large"] .image-link-list ul li a, [data-font-size="large"]
        .image-link-list ul li .box {
          height: 420px; }
        [data-font-size="xlarge"] .image-link-list ul li a, [data-font-size="xlarge"]
        .image-link-list ul li .box {
          height: 500px; }
        .image-link-list ul li a:before,
        .image-link-list ul li .box:before {
          content: "";
          display: block;
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          -webkit-box-sizing: border-box;
                  box-sizing: border-box; }
        .image-link-list ul li a:focus,
        .image-link-list ul li .box:focus {
          z-index: 2; }
          .image-link-list ul li a:focus:before,
          .image-link-list ul li .box:focus:before {
            -webkit-box-shadow: 0 0 5px 2px #06c inset, 0 0 5px 2px #06c inset;
                    box-shadow: 0 0 5px 2px #06c inset, 0 0 5px 2px #06c inset; }
        .image-link-list ul li a:after,
        .image-link-list ul li .box:after {
          content: "";
          display: block;
          position: absolute;
          z-index: 2;
          bottom: 90px;
          left: 30px;
          right: 40px;
          border-bottom: 1px solid rgba(255, 255, 255, 0.3); }
          [data-font-size="xlarge"] .image-link-list ul li a:after, [data-font-size="xlarge"]
          .image-link-list ul li .box:after {
            bottom: 136px; }
        .image-link-list ul li a .title,
        .image-link-list ul li a .description,
        .image-link-list ul li .box .title,
        .image-link-list ul li .box .description {
          display: block;
          position: absolute;
          z-index: 3;
          -webkit-box-sizing: border-box;
                  box-sizing: border-box;
          left: 0;
          right: 0;
          padding: 0 35px; }
        .image-link-list ul li a .title,
        .image-link-list ul li .box .title {
          top: 50%;
          -webkit-transform: translate(0, -50%);
                  transform: translate(0, -50%);
          font-size: 2em;
          line-height: 1.2;
          text-transform: uppercase;
          word-wrap: break-word;
          word-break: keep-all; }
          .image-link-list ul li a .title .inpreparation,
          .image-link-list ul li .box .title .inpreparation {
            display: block;
            font-size: 0.8em; }
        .image-link-list ul li a .description,
        .image-link-list ul li .box .description {
          bottom: 45px;
          -webkit-transform: translate(0, 50%);
                  transform: translate(0, 50%);
          padding: 0 100px 0 35px;
          font-size: 0.9em;
          font-weight: 700; }
          [data-font-size="large"] .image-link-list ul li a .description, [data-font-size="large"]
          .image-link-list ul li .box .description {
            line-height: 1.2; }
          [data-font-size="xlarge"] .image-link-list ul li a .description, [data-font-size="xlarge"]
          .image-link-list ul li .box .description {
            bottom: 68px;
            line-height: 1.2; }
      .image-link-list ul li[aria-disabled="true"]:before {
        opacity: 0.3; }
      .image-link-list ul li[aria-disabled="true"]:hover:before {
        -webkit-transform: none;
                transform: none; }
      .image-link-list ul li[aria-disabled="true"]:after {
        display: none; }
      .image-link-list ul li.message:before {
        background-image: url(../assets/image_link_list_message.jpg);
        background-position: 80% 10%; }
      .image-link-list ul li.schedule:before {
        background-image: url(../assets/image_link_list_schedule.jpg); }
      .image-link-list ul li.osaka:before {
        background-image: url(../assets/image_link_list_osaka.jpg); }
      .image-link-list ul li.theme:before {
        background-image: url(../assets/image_link_list_theme.jpg); }
      .image-link-list ul li.participants:before {
        background-image: url(../assets/image_link_list_participants.jpg); }
      .image-link-list ul li.ministerialmeetings:before {
        background-image: url(../assets/image_link_list_ministerialmeetings.jpg); }
      .image-link-list ul li.about:before {
        background-image: url(../assets/image_link_list_about.jpg); }
      .image-link-list ul li.faq:before {
        background-image: url(../assets/image_link_list_faq.jpg); }
      .image-link-list ul li.previoussummits:before {
        background-image: url(../assets/image_link_list_previoussummits.jpg); }
        /* Topics */
      .image-link-list ul li.culture:before {
        background-image: url(../assets/image_link_list_culture.jpg); }
      .image-link-list ul li.partner:before {
        background-image: url(../assets/image_link_list_partner.jpg); }
      .image-link-list ul li.foods:before {
        background-image: url(../assets/image_link_list_foods.jpg); }
      .image-link-list ul li.pr:before {
        background-image: url(../assets/image_link_list_pr.jpg); }
      .image-link-list ul li.items:before {
        background-image: url(../assets/image_link_list_items.jpg); }
      .image-link-list ul li.plasticsmart:before {
        background-image: url(../assets/image_link_list_plasticsmart.jpg); }
      .image-link-list ul li.others:before {
        background-image: url(../assets/image_link_list_others.jpg); }
      .image-link-list ul li.result:before {
        background-image: url(../assets/image_link_list_result.jpg); }
      .image-link-list ul li.summit:before {
        background-image: url(../assets/image_link_list_summit.jpg); }
      .image-link-list ul li.sideevent:before {
        background-image: url(../assets/image_link_list_sideevent.jpg); }
        /* Topics */
      .image-link-list ul li.message .title {
        right: 30%; }
      html[lang="ja"] .image-link-list ul li.message .title {
        word-break: normal; }

@media (max-width: 800px) {
  .image-link-list {
    margin: 20px -27px;
    background: transparent; }
    .image-link-list ul {
      display: block;
      border-top: 1px solid #fff; }
      .image-link-list ul:before {
        content: "";
        display: block;
        width: 50%;
        position: absolute;
        top: 1px;
        left: 0;
        bottom: 0;
        background: #000; }
      .image-link-list ul li {
        width: 100%;
        border-bottom: 1px solid #fff; }
        .image-link-list ul li:before {
          top: 0;
          left: 0;
          -webkit-transform: none;
                  transform: none;
          width: 50%;
          -webkit-transition: none;
          transition: none; }
        .image-link-list ul li:after {
          bottom: 35px;
          right: 5px;
          zoom: 0.7; }
        .image-link-list ul li:hover:before {
          -webkit-transform: none;
                  transform: none;
          -webkit-transition: none;
          transition: none; }
        .image-link-list ul li .copyright {
          top: auto;
          left: 5px;
          bottom: 5px;
          font-size: 0.5em; }
        .image-link-list ul li a,
        .image-link-list ul li .box {
          height: auto;
          min-height: 140px;
          padding: 0 0 28px 50%;
          color: #000;
          text-shadow: none; }
          .image-link-list ul li a:before,
          .image-link-list ul li .box:before {
            z-index: 1;
            background: #fff;
            left: 50%;
            right: 0;
            width: auto;
            border: none; }
          .image-link-list ul li a:after,
          .image-link-list ul li .box:after {
            z-index: 2;
            background: rgba(204, 204, 204, 0.2);
            top: 0;
            left: 50%;
            right: 0;
            width: auto;
            height: 100%;
            border: none; }
          .image-link-list ul li a .title,
          .image-link-list ul li a .description,
          .image-link-list ul li .box .title,
          .image-link-list ul li .box .description {
            position: relative;
            top: auto;
            left: auto;
            bottom: auto;
            right: auto;
            -webkit-transform: none;
                    transform: none; }
          .image-link-list ul li a .title,
          .image-link-list ul li .box .title {
            padding: 30px 15px 13px;
            font-size: 1.2em; }
          .image-link-list ul li a .description,
          .image-link-list ul li .box .description {
            padding: 0 15px 15px;
            font-weight: normal; }
            .image-link-list ul li a .description:after,
            .image-link-list ul li .box .description:after {
              display: none; }
        .image-link-list ul li.message .title {
          right: auto; }
        html[lang="ja"] .image-link-list ul li.message .title {
          word-break: normal; } }

.image.parallax {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent none no-repeat center 100%;
  background-size: cover;
  opacity: 0; }
  .image.parallax.show {
    opacity: 1;
    -webkit-transition: opacity 0.3s linear 0s;
    transition: opacity 0.3s linear 0s; }

.main-image,
.photobox {
  margin: 1em 0; }
  .main-image.lazy,
  .photobox.lazy {
    position: relative;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
    overflow: hidden; }
    .main-image.lazy:before,
    .photobox.lazy:before {
      content: "";
      display: block;
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: #000; }
    .main-image.lazy img,
    .photobox.lazy img {
      position: relative;
      z-index: 1;
      opacity: 0;
      -webkit-transform: scale(1.1, 1.1);
              transform: scale(1.1, 1.1);
      display: block;
      width: 100%;
      height: auto; }
    .main-image.lazy.show.loaded img,
    .photobox.lazy.show.loaded img {
      opacity: 1;
      -webkit-transform: scale(1, 1);
              transform: scale(1, 1);
      -webkit-transition: opacity 0.3s linear 0.2s, -webkit-transform 1s ease-out 0.2s;
      transition: opacity 0.3s linear 0.2s, -webkit-transform 1s ease-out 0.2s;
      transition: transform 1s ease-out 0.2s, opacity 0.3s linear 0.2s;
      transition: transform 1s ease-out 0.2s, opacity 0.3s linear 0.2s, -webkit-transform 1s ease-out 0.2s; }

.imagebox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden; }
  .imagebox .image {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1; }
    .imagebox .image img {
      width: 100%;
      height: auto;
      vertical-align: top; }
  .imagebox .image + .image {
    margin-left: 2px; }

@media (max-width: 768px) {
  .imagebox {
    display: block; }
    .imagebox .image + .image {
      margin-left: 0;
      margin-top: 2px; } }

.link-list {
  margin: 30px 0 -10px; }
  .link-list ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 0;
    padding: 0;
    list-style-type: none; }
    .link-list ul li {
      width: 33%;
      word-wrap: break-word;
      -webkit-box-sizing: border-box;
              box-sizing: border-box;
      margin: 0 0.3333333% 40px 0;
      padding: 27px 27px 7px;
      border-top: 4px solid #06c;
      border-left: 1px solid rgba(204, 204, 204, 0.6); }
      .link-list ul li a {
        position: relative;
        display: block;
        text-decoration: none;
        color: inherit; }
        .link-list ul li a .title {
          margin-bottom: 27px;
          padding: 0 10px;
          font-size: 1.3em; }
        .link-list ul li a .url {
          position: relative;
          padding: 20px 40px 20px 10px;
          border-top: 1px solid rgba(204, 204, 204, 0.6);
          color: #06c;
          font-size: .8em; }
        .link-list ul li a .memo {
          display: block;
          color: #666; }
        .link-list ul li a:hover .url {
          text-decoration: underline; }
          .link-list ul li a:hover .url .memo {
            text-decoration: none; }
        .link-list ul li a .url img {
          display: block;
          position: absolute;
          top: 50%;
          right: 0;
          -webkit-transform: translate(0, -50%);
                  transform: translate(0, -50%); }

@media (max-width: 800px) {
  .link-list {
    margin: 40px 0 -30px; }
    .link-list ul {
      display: block; }
      .link-list ul li {
        width: 100%;
        margin-right: 0;
        padding: 0;
        border-left: none; }
        .link-list ul li a .title {
          margin: 0;
          padding: 17px 0; }
        .link-list ul li a .url {
          padding: 17px 40px 17px 0; } }

.map {
  position: relative;
  margin: 30px 0; }
  .map img {
    vertical-align: top;
    width: 100%;
    height: auto; }
  .map ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
    overflow: hidden; }
  .map li {
    display: block;
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    width: 22.8%;
    height: 6.8%;
    overflow: hidden;
    text-indent: -999em;
    cursor: pointer; }
    .map li.niigata {
      top: 23.5%;
      left: 36%; }
    .map li.fukuoka {
      top: 50.2%;
      left: 10%; }
    .map li.ibaraki {
      top: 48.7%;
      left: 72.7%;
      width: 23.6%; }
    .map li.nagano {
      top: 33.5%;
      left: 68.7%;
      width: 24.3%; }
    .map li.ehime {
      top: 69.3%;
      left: 40%;
      width: 22.5%; }
    .map li.okayama {
      top: 36.7%;
      left: 20.5%;
      width: 22.8%; }
    .map li.hokkaido {
      top: 10.3%;
      left: 38%;
      width: 24.3%; }
    .map li.aichi {
      top: 63.5%;
      left: 65%;
      width: 24%; }

.media-link-list {
  margin: 30px 0; }
  .media-link-list > ul {
    margin: 0;
    padding: 0;
    list-style-type: none; }
    .media-link-list > ul > li {
      position: relative;
      margin: 20px 0;
      background: rgba(204, 204, 204, 0.2);
      border-top: 3px solid #06c; }
      .media-link-list > ul > li .content {
        display: block;
        position: relative;
        padding: 33px 205px 30px 27px;
        text-decoration: none; }
        .media-link-list > ul > li .content[aria-disabled="true"] {
          color: #666;
          padding-right: 27px; }
        .media-link-list > ul > li .content .title {
          display: block;
          font-size: 1.5em;
          text-transform: uppercase; }
        .media-link-list > ul > li .content .btn {
          position: absolute;
          top: 50%;
          right: 30px;
          -webkit-transform: translate(0, -50%);
                  transform: translate(0, -50%);
          width: 150px;
          padding: 1em 20px 1em 0; }
          [data-font-size="xlarge"] .media-link-list > ul > li .content .btn {
            width: 170px; }
          .media-link-list > ul > li .content .btn:before {
            right: 20px;
            width: 20px;
            height: 20px; }
          .media-link-list > ul > li .content .btn:after {
            right: 20px; }
          .media-link-list > ul > li .content .btn[target="_blank"]:after {
            display: none; }
      .media-link-list > ul > li a.content:hover {
        text-decoration: underline; }
        .media-link-list > ul > li a.content:hover .btn {
          text-decoration: underline; }

@media (max-width: 800px) {
  .media-link-list {
    margin: -5px 0 -5px; }
    .media-link-list > ul > li .date {
      padding: 5px 19px; }
    .media-link-list > ul > li .content {
      padding: 15px 48px 15px 19px; }
      .media-link-list > ul > li .content .title {
        font-size: 1.2em; }
      .media-link-list > ul > li .content > .btn {
        display: block;
        right: 5px;
        width: 40px;
        height: 40px;
        overflow: hidden;
        text-indent: -999em;
        padding: 0;
        background: transparent;
        -webkit-box-shadow: none;
                box-shadow: none; }
        .media-link-list > ul > li .content > .btn:active {
          top: 50%; }
        .media-link-list > ul > li .content > .btn:hover {
          -webkit-box-shadow: none;
                  box-shadow: none; }
        .media-link-list > ul > li .content > .btn:before, .media-link-list > ul > li .content > .btn:after {
          right: 50%;
          -webkit-transform: translate(50%, -50%);
                  transform: translate(50%, -50%); }
        .media-link-list > ul > li .content > .btn:before {
          width: 20px;
          height: 20px;
          background: #06c;
          -webkit-box-shadow: 0 0 2em rgba(0, 0, 0, 0.07);
                  box-shadow: 0 0 2em rgba(0, 0, 0, 0.07); }
      .media-link-list > ul > li .content .links {
        margin: 15px -19px -15px;
        padding: 15px 19px 15px; } }

.movie-list {
  margin: 30px 0 0; }
  .movie-list ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    position: relative;
    list-style-type: none;
    margin: 0;
    padding: 0; }
    .movie-list ul li {
      width: 33.333333%;
      margin: 0 0 30px; }
      .movie-list ul li .content {
        margin-right: 1px; }
        .movie-list ul li .content .movie {
          display: block;
          position: relative;
          cursor: pointer; }
          .movie-list ul li .content .movie:hover {
            opacity: 0.8; }
          .movie-list ul li .content .movie .thumbnail {
            position: relative; }
            .movie-list ul li .content .movie .thumbnail img {
              width: 100%;
              height: auto;
              vertical-align: top; }
          [data-enabled-videp="true"] .movie-list ul li .content .movie[data-video-src] {
            cursor: pointer; }
            [data-enabled-videp="true"] .movie-list ul li .content .movie[data-video-src] .thumbnail:after {
              background: url(../assets/sprites/parts.svg) no-repeat;
              background-position: 0 -70px;
              background-size: 275px 227px;
              width: 70px;
              height: 70px;
              content: "";
              display: block;
              position: absolute;
              z-index: 10;
              top: 50%;
              left: 50%;
              -webkit-transform: translate(-50%, -50%);
                      transform: translate(-50%, -50%); }
          [data-enabled-video="false"] .movie-list ul li .content .movie {
            cursor: default; }
            [data-enabled-video="false"] .movie-list ul li .content .movie:after {
              display: none; }
        .movie-list ul li .content .caption {
          padding: 36px 40px;
          font-size: 0.9em;
          border-left: 1px solid rgba(204, 204, 204, 0.6); }

.movie-container {
  margin: 30px 40px 0 0; }
  .movie-container a.youtube {
    text-decoration: none;
    border-bottom: 1px solid #06c; }
    .movie-container a.youtube .thumbnail {
      position: relative;
      width: 100%;
      overflow: hidden; }
      .movie-container a.youtube .thumbnail:after {
        background: url(../assets/sprites/parts.svg) no-repeat;
        background-position: 0 -70px;
        background-size: 275px 227px;
        width: 70px;
        height: 70px;
        content: "";
        display: block;
        position: absolute;
        z-index: 10;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%); }
      .movie-container a.youtube .thumbnail img {
        width: 100%;
        height: auto;
        -webkit-transition: -webkit-transform 0.4s ease 0s;
        transition: -webkit-transform 0.4s ease 0s;
        transition: transform 0.4s ease 0s;
        transition: transform 0.4s ease 0s, -webkit-transform 0.4s ease 0s; }
    .movie-container a.youtube:hover {
      border-bottom: 2px solid #06c; }
      .movie-container a.youtube:hover .thumbnail img {
        -webkit-transform: scale(1.02, 1.02);
                transform: scale(1.02, 1.02); }
  .movie-container [data-video-src] {
    color: #06c;
    border-bottom: 1px solid #06c;
    cursor: pointer; }
  .movie-container .unsupported-message {
    margin: 0.5em 0 1em;
    font-size: 0.85em;
    color: #c33; }
  [data-enabled-video="true"] .movie-container [data-video-src]:hover {
    border-bottom-width: 2px; }
  [data-enabled-video="true"] .movie-container .unsupported-message {
    display: none; }
  [data-enabled-video="false"] .movie-container [data-video-src] {
    cursor: default; }
    [data-enabled-video="false"] .movie-container [data-video-src]:after {
      display: none; }
  [data-enabled-video="false"] .movie-container .unsupported-message {
    display: block; }

.movie-modal {
  display: none;
  position: fixed;
  z-index: 1800;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  opacity: 0;
  -webkit-transform: translate(-100%, -100%);
          transform: translate(-100%, -100%);
  -webkit-transition: opacity 0.3s linear 0s, -webkit-transform 0s linear 0.3s;
  transition: opacity 0.3s linear 0s, -webkit-transform 0s linear 0.3s;
  transition: opacity 0.3s linear 0s, transform 0s linear 0.3s;
  transition: opacity 0.3s linear 0s, transform 0s linear 0.3s, -webkit-transform 0s linear 0.3s;
  color: #fff; }
  .movie-modal.show {
    display: block;
    opacity: 1;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
    -webkit-transition: opacity 0.2s linear 0s;
    transition: opacity 0.2s linear 0s; }
  .movie-modal .movie-modal-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000; }
  .movie-modal .video-player {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%); }
  .movie-modal .close-btn {
    display: block;
    position: absolute;
    z-index: 100;
    top: 15px;
    right: 15px;
    padding: 5px 8px;
    white-space: nowrap;
    cursor: pointer;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 0.85em; }
    .movie-modal .close-btn:after {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -249.01px -22.19px;
      background-size: 275px 227px;
      width: 24.03px;
      height: 24px;
      content: "";
      display: inline-block;
      margin-left: 0.5em;
      vertical-align: middle;
      margin-top: -0.2em; }

@media (max-width: 800px) {
  .movie-list {
    margin: 0 0 -30px; }
    .movie-list ul li {
      width: 49.9999%; }
      .movie-list ul li .content .caption {
        padding: 20px 0;
        border-left: none;
        font-size: 0.8em; }
  .movie-container {
    margin: 30px 0; }
    .movie-container .unsupported-message {
      margin: 1em 0; }
      .movie-container .unsupported-message.memo {
        font-size: 0.85em; } }

ul.news {
  margin: 30px 0;
  padding: 0;
  list-style-type: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1); }
  ul.news li {
    position: relative;
    border-top: 1px solid rgba(0, 0, 0, 0.1); }
    ul.news li .date {
      display: block;
      position: absolute;
      top: -1px;
      left: 0;
      width: 11em;
      padding: 40px 10px;
      white-space: nowrap;
      text-align: center;
      font-size: 0.85em;
      color: #000;
      border-top: 1px solid #06c; }
    ul.news li a {
      display: block;
      position: relative;
      z-index: 1;
      padding: 40px 100px 40px 10em;
      text-decoration: none; }
      ul.news li a:hover {
        background: rgba(0, 0, 0, 0.02); }
      ul.news li a img:not(.icon-pdf) {
        display: block;
        position: absolute;
        top: 50%;
        right: 25px;
        -webkit-transform: translate(0, -50%);
                transform: translate(0, -50%); }
      ul.news li a img.icon-pdf {
        width: 22px;
        height: 24px;
        margin-left: 8px; }

@media (max-width: 800px) {
  ul.news li .date {
    padding: 13px 0;
    width: auto;
    font-size: 0.62em; }
  ul.news li a {
    padding: 40px 40px 35px 0;
    font-size: 0.85em; }
    ul.news li a img:not(.icon-pdf) {
      right: 0; }
    ul.news li a img.icon-pdf {
      width: 18px;
      height: 19px; } }

.topics li a img.icon-pdf {
  width: 22px;
  height: 24px;
  margin-left: 8px; }

@media (max-width: 800px) {
  .topics li a img.icon-pdf {
    width: 18px;
    height: 19px; } }

.group-list .group-box .group-detail a img.icon-pdf {
  width: 19px;
  height: 21px;
  margin-left: 3px; }

@media (max-width: 800px) {
  .group-list .group-box .group-detail a img.icon-pdf {
    width: 18px;
    height: 19px;
    margin-left: 1px; } }

table.tbl-topics a img.icon-pdf {
  width: 19px;
  height: 21px;
  margin-left: 3px; }

@media (max-width: 800px) {
  table.tbl-topics a img.icon-pdf {
    width: 18px;
    height: 19px;
    margin-left: 1px; } }

.doc-link a img.icon-pdf {
  width: 19px;
  height: 21px;
  margin-left: 3px; }

@media (max-width: 800px) {
  .doc-link a img.icon-pdf {
    width: 18px;
    height: 19px;
    margin-left: 1px; } }

.accordion-list a img.icon-pdf {
  width: 19px;
  height: 21px;
  margin-left: 3px; }

@media (max-width: 800px) {
  .accordion-list a img.icon-pdf {
    width: 18px;
    height: 19px;
    margin-left: 1px; } }

.photo-list .caption {
  margin: 30px 0 0.25em;
  padding: 0;
  font: inherit;
  font-size: 1.5em;
  text-transform: uppercase; }

.photo-list .caption + ul {
  margin-top: 0; }

.photo-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  position: relative;
  list-style-type: none;
  margin: 30px 0 0;
  padding: 0; }
  .photo-list ul li {
    width: 33.3333%;
    margin: 0 0 30px;
    font-size: 0.9em;
    height: 100%;}
    .photo-list ul li a {
      display: block;
      margin: 0 3px 0 0;
      padding: 0;
      border-top: 4px solid #06c;
      border-left: 1px solid rgba(204, 204, 204, 0.6);
      text-decoration: none; }
      .photo-list ul li a:hover .footer {
        text-decoration: underline; }
    .photo-list ul li img {
      display: block;
      width: 100%;
      height: auto; }
      .photo-list ul li img.enabled {
        cursor: pointer; }
        .photo-list ul li img.enabled:hover {
          opacity: 0.8; }
    .photo-list ul li .title {
      padding: 15px 15px 0;
      background-color: rgba(0, 0, 0, 0);
      color: #000;
      font-weight: bold;
      text-align: center; }
    .photo-list ul li .footer {
      position: relative;
      padding: 3px 15px 5px;
      text-align: center; }
      .photo-list ul li .footer:after {
        background: url(../assets/sprites/parts.svg) no-repeat;
        background-position: -140px -40px;
        background-size: 275px 227px;
        width: 40px;
        height: 40px;
        content: "";
        display: inline-block;
        vertical-align: middle;
        margin-right: -20px; }

@media (max-width: 800px) {
  .photo-list {
    margin: 0 0 -20px; }
    .photo-list .caption {
      margin: 30px 0 0.25em; }
    .photo-list ul li {
      width: 100%; }
      .photo-list ul li a {
        margin: 0; }
      .photo-list ul li .title {
        padding: 15px 25px 0;
        border-left: none; }
      .photo-list ul li .footer {
        padding: 15px 25px 15px;
        border-left: none; } }

.pswp__ui--idle .pswp__top-bar {
  opacity: 1; }

button.pswp__button.pswp__button--close {
  width: auto;
  height: auto;
  background: none;
  color: #fff;
  margin: 10px;
  padding: 5px 10px;
  opacity: 1;
  text-transform: uppercase;
  font-weight: 700; }
  button.pswp__button.pswp__button--close:hover {
    text-decoration: underline; }
  button.pswp__button.pswp__button--close:after {
    background: url(../assets/sprites/parts.svg) no-repeat;
    background-position: -249.01px -22.19px;
    background-size: 275px 227px;
    width: 24.03px;
    height: 24px;
    content: "";
    display: inline-block;
    margin-left: 0.5em;
    vertical-align: middle;
    margin-top: -0.2em; }

.schedule-list {
  margin: 30px 0; }
  .schedule-list > ul {
    margin: 0;
    padding: 0;
    list-style-type: none; }
    .schedule-list > ul > li {
      position: relative;
      margin: 20px 0;
      background: rgba(204, 204, 204, 0.2); }
      .schedule-list > ul > li .date {
        padding: 8px 27px;
        background: #06c;
        color: #fff;
        line-height: 1em; }
      .schedule-list > ul > li .content {
        position: relative;
        padding: 33px 27px 30px; }
        .schedule-list > ul > li .content .title {
          display: block;
          font-size: 1.5em; }
        .schedule-list > ul > li .content > a.btn {
          position: absolute;
          top: 50%;
          right: 30px;
          -webkit-transform: translate(0, -50%);
                  transform: translate(0, -50%);
          width: 150px;
          padding: 1em 20px 1em 0; }
          .schedule-list > ul > li .content > a.btn:before {
            right: 20px;
            width: 20px;
            height: 20px; }
          .schedule-list > ul > li .content > a.btn:after {
            right: 20px; }
          .schedule-list > ul > li .content > a.btn[target="_blank"]:after {
            display: none; }
        .schedule-list > ul > li .content .links {
          margin: 30px -27px -30px;
          padding: 19px 27px 30px;
          border-top: 1px solid rgba(204, 204, 204, 0.6);
          list-style-type: none; }
          .schedule-list > ul > li .content .links li {
            margin: 3px 0; }
          .schedule-list > ul > li .content .links a {
            text-decoration: none; }
            .schedule-list > ul > li .content .links a:hover {
              text-decoration: underline; }
            .schedule-list > ul > li .content .links a[target="_blank"]:after {
              display: none; }
            .schedule-list > ul > li .content .links a img {
              vertical-align: middle;
              margin-left: 0.5em; }
      .schedule-list > ul > li.has-link .content {
        padding-right: 205px; }

@media (max-width: 800px) {
  .schedule-list {
    margin: -5px 0 -5px; }
    .schedule-list > ul > li .date {
      padding: 5px 19px; }
    .schedule-list > ul > li .content {
      padding: 15px 19px; }
      .schedule-list > ul > li .content .title {
        font-size: 1.2em; }
      .schedule-list > ul > li .content > a.btn {
        display: block;
        right: 15px;
        width: 40px;
        height: 40px;
        overflow: hidden;
        text-indent: -999em;
        padding: 0;
        background: transparent;
        -webkit-box-shadow: none;
                box-shadow: none; }
        .schedule-list > ul > li .content > a.btn:active {
          top: 50%; }
        .schedule-list > ul > li .content > a.btn:hover {
          -webkit-box-shadow: none;
                  box-shadow: none; }
        .schedule-list > ul > li .content > a.btn:before, .schedule-list > ul > li .content > a.btn:after {
          right: 50%;
          -webkit-transform: translate(50%, -50%);
                  transform: translate(50%, -50%); }
        .schedule-list > ul > li .content > a.btn:before {
          width: 20px;
          height: 20px;
          background: #06c;
          -webkit-box-shadow: 0 0 2em rgba(0, 0, 0, 0.07);
                  box-shadow: 0 0 2em rgba(0, 0, 0, 0.07); }
        .schedule-list > ul > li .content > a.btn[target="_blank"]:after {
          display: none; }
      .schedule-list > ul > li .content .links {
        margin: 15px -19px -15px;
        padding: 15px 19px 15px; }
    .schedule-list > ul > li.has-link .content {
      padding-right: 58px; } }

.share-container {
  display: none;
  padding: 15px 95px;
  background: #fff;
  color: #000;
  border-bottom: 1px solid rgba(204, 204, 204, 0.6);
  line-height: 1em; }
  .share-container.show {
    display: block; }
  .share-container .share {
    position: relative;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    display: inline-block;
    margin-left: 5px;
    padding: 0 12px 0 36px;
    height: 24px;
    line-height: 24px;
    overflow: hidden;
    background: rgba(204, 204, 204, 0.2);
    border: none;
    font-size: 0.8em;
    text-transform: uppercase;
    cursor: pointer;
    -webkit-transition: background-color 0.1s linear 0s;
    transition: background-color 0.1s linear 0s; }
    .share-container .share:first-child {
      margin-left: 0; }
    .share-container .share:before, .share-container .share:after {
      content: "";
      display: block;
      position: absolute; }
    .share-container .share:before {
      top: 0;
      left: 0;
      width: 24px;
      height: 24px; }
    .share-container .share:after {
      z-index: 2;
      top: 12px;
      left: 12px;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%); }
    .share-container .share:hover {
      background: rgba(204, 204, 204, 0.6); }
    .share-container .share[data-service="facebook"]:before {
      background: #4267b2; }
    .share-container .share[data-service="facebook"]:after {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -249.01px -46.19px;
      background-size: 275px 227px;
      width: 22px;
      height: 22px; }
    .share-container .share[data-service="twitter"]:before {
      background: #1da1f2; }
    .share-container .share[data-service="twitter"]:after {
      background: url(../assets/sprites/parts.svg) no-repeat;
      background-position: -249.01px 0;
      background-size: 275px 227px;
      width: 25px;
      height: 22.19px; }

@media (max-width: 800px) {
  .share-container,
  .share-container.show {
    display: none; } }

.splitview {
  position: relative;
  margin-right: 320px; }
  .splitview aside {
    display: block;
    position: absolute;
    top: -25px;
    right: -320px;
    z-index: 1000;
    width: 320px;
    height: 100%;
    border-top: 5px solid #fff;
    text-transform: uppercase; }
    .splitview aside ul {
      position: relative;
      list-style-type: none;
      margin: 0;
      padding: 0; }
    .splitview aside nav > ul:after {
      content: "";
      display: block;
      position: absolute;
      bottom: 0;
      left: 29px;
      right: 29px;
      border-bottom: 1px solid rgba(204, 204, 204, 0.6); }
    .splitview aside nav > ul > li {
      position: relative;
      margin: 0 0 18px;
      padding: 0; }
      .splitview aside nav > ul > li > a {
        position: relative;
        display: block;
        padding: 32px;
        background: #06c;
        font-size: 0.8em;
        font-weight: 700;
        line-height: 1.3em;
        color: #fff;
        text-decoration: none;
        -webkit-transition: padding-left 0.1s ease-out 0s;
        transition: padding-left 0.1s ease-out 0s; }
        .splitview aside nav > ul > li > a:before {
          display: none; }
        .splitview aside nav > ul > li > a:hover {
          padding-left: 35px; }
      .splitview aside nav > ul > li .group .title {
        margin: 20px 0 30px;
        padding: 10px 37px;
        background: #e9e9e9; }
      .splitview aside nav > ul > li ul {
        margin: 18px 0 0; }
        .splitview aside nav > ul > li ul li {
          position: relative;
          padding: 0 29px; }
          .splitview aside nav > ul > li ul li:after {
            content: "";
            display: block;
            position: absolute;
            top: 0;
            left: 29px;
            right: 29px;
            border-top: 1px solid rgba(204, 204, 204, 0.6); }
          .splitview aside nav > ul > li ul li.current, .splitview aside nav > ul > li ul li[aria-disabled="true"] {
            padding: 23px 40px;
            background: #fff;
            color: #000; }
            .splitview aside nav > ul > li ul li.current:after, .splitview aside nav > ul > li ul li[aria-disabled="true"]:after {
              display: none; }
          .splitview aside nav > ul > li ul li.current + li:after {
            display: none; }
          .splitview aside nav > ul > li ul li[aria-disabled="true"] {
            background: transparent;
            color: #000; }
            .splitview aside nav > ul > li ul li[aria-disabled="true"]:after {
              display: block; }
          .splitview aside nav > ul > li ul li a {
            position: relative;
            display: block;
            padding: 23px 37px 23px 11px;
            color: #06c;
            text-decoration: none; }
            .splitview aside nav > ul > li ul li a:before {
              background: url(../assets/sprites/parts.svg) no-repeat;
              background-position: -30px -169px;
              background-size: 275px 227px;
              width: 30px;
              height: 30px;
              content: "";
              display: block;
              position: absolute;
              top: 50%;
              right: 0;
              -webkit-transform: translate(0, -50%);
                      transform: translate(0, -50%);
              -webkit-transition: -webkit-transform 0.2s ease-out 0s;
              transition: -webkit-transform 0.2s ease-out 0s;
              transition: transform 0.2s ease-out 0s;
              transition: transform 0.2s ease-out 0s, -webkit-transform 0.2s ease-out 0s; }
            .splitview aside nav > ul > li ul li a:hover:before {
              -webkit-transform: translate(5px, -50%);
                      transform: translate(5px, -50%); }
          .splitview aside nav > ul > li ul li .inpreparation {
            font-size: 0.9em; }
            [lang="en"] .splitview aside nav > ul > li ul li .inpreparation {
              display: block; }

@media (max-width: 940px) {
  .splitview {
    position: relative;
    margin-right: 0; }
    .splitview aside {
      position: relative;
      top: 0;
      right: auto;
      width: 100%;
      height: auto;
      margin: 0;
      padding: 0;
      background: #fff;
      border-top: none; }
      .splitview aside nav > ul:after {
        border: none; }
      .splitview aside nav > ul > li > a {
        padding: 15px 29px;
        font-size: inherit; }
      .splitview aside nav > ul > li .group .title {
        margin-bottom: 0;
        padding: 5px 29px; }
      .splitview aside nav > ul > li ul {
        margin: 0;
        background: rgba(204, 204, 204, 0.2); }
        .splitview aside nav > ul > li ul li.current, .splitview aside nav > ul > li ul li[aria-disabled="true"] {
          padding: 15px 29px; }
        .splitview aside nav > ul > li ul li a {
          padding: 15px 35px 15px 0; }
        .splitview aside nav > ul > li ul li::first-child:after {
          border-top: none; } }

.summit-logo-guidline {
  position: relative;
  z-index: 10; }
  .summit-logo-guidline a {
    display: block;
    margin: 30px 0;
    padding: 10px;
    background: #06c;
    color: #fff;
    text-align: center;
    font-size: 1.3em;
    line-height: 1em;
    text-decoration: none; }
    .summit-logo-guidline a:hover {
      text-decoration: underline; }
    .summit-logo-guidline a .logo {
      display: inline-block;
      margin: 0 20px 0 0;
      padding: 10px;
      background: #fff; }
      .summit-logo-guidline a .logo img {
        width: 48px;
        height: auto; }

.sns-links {
  position: relative;
  z-index: 10;
  margin: 30px 0;
  background: #06c;
  color: #fff; }
  .sns-links ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0;
    padding: 0;
    list-style-type: none; }
    .sns-links ul li {
      -webkit-box-flex: 1;
          -ms-flex: 1;
              flex: 1;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      position: relative;
      width: 120px;
      border-left: 1px solid rgba(255, 255, 255, 0.3);
      font-size: 0.9em;
      font-weight: 700; }
      .sns-links ul li a {
        -webkit-box-flex: 1;
            -ms-flex: 1;
                flex: 1;
        position: relative;
        padding: 67px 0 32px;
        font-size: 0.95em;
        text-decoration: none;
        text-align: center;
        -webkit-transition: background-color 0.3s linear 0s;
        transition: background-color 0.3s linear 0s;
        overflow: hidden;
        color: #fff; }
        .sns-links ul li a:before {
          content: "";
          display: block;
          position: absolute;
          z-index: 2;
          top: 48px;
          left: 50%;
          -webkit-transform: translate(-50%, -50%) scale(1.3, 1.3);
                  transform: translate(-50%, -50%) scale(1.3, 1.3); }
        .sns-links ul li a.twitter:before {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -172px -169px;
          background-size: 275px 227px;
          width: 29.01px;
          height: 25.98px; }
        .sns-links ul li a.facebook:before {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -220px -58.01px;
          background-size: 275px 227px;
          width: 29px;
          height: 29px; }
        .sns-links ul li a.instagram:before {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -220px 0;
          background-size: 275px 227px;
          width: 29.01px;
          height: 29.01px; }
        .sns-links ul li a.flickr:before {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -220px -29.01px;
          background-size: 275px 227px;
          width: 29px;
          height: 29px; }

@media (min-width: 801px) {
  .sns-links ul li a:after {
    content: "";
    display: block;
    position: absolute;
    top: 45px;
    left: 50%;
    width: 0;
    height: 0;
    border-radius: 100%;
    background: rgba(255, 255, 255, 0.1);
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    -webkit-transition: all 0.3s ease-out 0s;
    transition: all 0.3s ease-out 0s; }
  .sns-links ul li a:hover:after {
    width: 500px;
    height: 500px;
    -webkit-transition: all 0.3s ease-in-out 0s;
    transition: all 0.3s ease-in-out 0s; } }

@media (max-width: 800px) {
  .summit-logo-guidline a {
    font-size: 0.9em; }
    .summit-logo-guidline a .logo {
      display: block;
      width: 68px;
      margin: 0 auto 10px; }
  .sns-links ul li {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1; }
    .sns-links ul li a {
      padding: 40px 0 10px;
      font-size: 0.75em; }
      .sns-links ul li a:before {
        top: 26px; }
      .sns-links ul li a:hover {
        background: transparent;
        -webkit-transition: none;
        transition: none; } }

.text-container {
  line-height: 2em;
  margin: 30px -80px;
  padding: 0 80px; }
  .text-container p:first-child {
    margin-top: 0; }
  .text-container p:last-child {
    margin-bottom: 0; }
  .text-container img.wide {
    margin: 1.5em 0;
    width: 100%;
    height: auto; }
  .text-container a {
    text-decoration: none;
    border-bottom: 1px solid #06c; }
    .text-container a:hover {
      border-bottom-width: 2px; }
  .text-container .note {
    margin: 30px 0 0;
    padding: 30px 0 0;
    border-top: 1px solid rgba(204, 204, 204, 0.6);
    color: rgba(204, 204, 204, 0.6);
    font-size: 0.75em; }
  .text-container .textbox-with-note {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow: hidden; }
    .text-container .textbox-with-note > .text {
      width: 65%; }
    .text-container .textbox-with-note > .note {
      -webkit-box-flex: 1;
          -ms-flex: 1;
              flex: 1;
      margin: 0 0 0 50px;
      padding: 40px 0; }
  .text-container .textbox-with-photo {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin: 60px 0; }
    .text-container .textbox-with-photo .photobox {
      -webkit-box-flex: 1;
          -ms-flex: 1;
              flex: 1;
      margin: 0;
      margin-right: 20px;
      overflow: hidden; }
      .text-container .textbox-with-photo .photobox img {
        width: 100%;
        height: auto;
        margin: 0;
        vertical-align: top; }
      .text-container .textbox-with-photo .photobox p.caption {
        position: relative;
        z-index: 100;
        margin: -10px;
        padding: 10px 20px;
        background: #fff;
        line-height: 1.26;
        font-size: 0.9em;
        text-align: center; }
    .text-container .textbox-with-photo .textbox {
      -webkit-box-flex: 1;
          -ms-flex: 1;
              flex: 1;
      margin-left: 20px; }
      .text-container .textbox-with-photo .textbox p:first-child {
        margin-top: 0; }
      .text-container .textbox-with-photo .textbox p:last-child {
        margin-bottom: 0; }
  .text-container .profilebox h2 {
    margin: 0;
    padding: 24px 60px;
    background: #06c;
    color: #fff;
    font-size: 1.4em;
    line-height: 1; }
  .text-container .profilebox .content {
    position: relative;
    margin: 0;
    min-height: 300px;
    padding: 60px 60px 60px 280px;
    background: rgba(204, 204, 204, 0.2);
    overflow: hidden; }
    .text-container .profilebox .content img.profile-image {
      position: absolute;
      top: 60px;
      left: 60px; }
    .text-container .profilebox .content p:first-child {
      margin-top: 0; }
    .text-container .profilebox .content p:last-child {
      margin-bottom: 0; }
    .text-container .profilebox .content a {
      display: inline;
      position: relative;
      border-bottom: 1px solid #06c; }
      .text-container .profilebox .content a:hover {
        border-bottom-width: 2px; }
      .text-container .profilebox .content a img {
        vertical-align: middle;
        margin: 0 0 0 0.3em; }

@media (max-width: 1200px) {
  .text-container .textbox-with-photo .photobox,
  .text-container .textbox-with-photo.small .photobox {
    width: 285px; }
    .text-container .textbox-with-photo .photobox img,
    .text-container .textbox-with-photo.small .photobox img {
      width: 330px; } }

@media (max-width: 800px) {
  .text-container {
    margin: 0 -15px;
    padding: 0 15px; }
    .text-container .textbox-with-note {
      display: block;
      overflow: hidden; }
      .text-container .textbox-with-note > .text {
        width: 100%;
        -webkit-box-sizing: border-box;
                box-sizing: border-box; }
      .text-container .textbox-with-note > .note {
        margin: 30px 0 0;
        padding: 30px 0 10px; }
    .text-container .textbox-with-photo {
      display: block; }
      .text-container .textbox-with-photo .photobox {
        margin: 1em 0;
        width: 100%;
        -webkit-transform: translate(0, 0);
                transform: translate(0, 0); }
        .text-container .textbox-with-photo .photobox img {
          width: 100%;
          height: auto; }
        .text-container .textbox-with-photo .photobox p.caption {
          padding: 10px; }
      .text-container .textbox-with-photo .textbox {
        -webkit-box-flex: 1;
            -ms-flex: 1;
                flex: 1;
        margin-left: 0; }
        .text-container .textbox-with-photo .textbox p {
          margin: 1em 0; }
    .text-container .profilebox h2 {
      margin: 0;
      padding: 12px 30px; }
    .text-container .profilebox .content {
      min-height: 0;
      margin: 0;
      padding: 30px; }
      .text-container .profilebox .content img.profile-image {
        float: none;
        display: block;
        position: relative;
        top: 0;
        left: 0;
        margin: 0 auto 30px;
        width: 80%;
        max-width: 240px;
        height: auto; }
      .text-container .profilebox .content p {
        margin: 0; } }

footer {
  padding: 60px 0 40px 40px;
  background: #666 url(../assets/footer_bg.jpg) no-repeat center center;
  background-size: cover;
  font-size: 0.95em;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  text-shadow: 0 0 0.7em rgba(0, 0, 0, 0.7), 0 0 1.2em rgba(0, 0, 0, 0.7); }
  footer .sitemap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin: 20px 0; }
    footer .sitemap .group {
      position: relative;
      width: 24.9999999%;
      padding: 20px 40px 45px 0; }
      footer .sitemap .group:before {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        right: 40px;
        height: 1px;
        border-top: 1px solid #fff; }
      footer .sitemap .group:first-child {
        margin-left: 0; }
      footer .sitemap .group .inpreparation {
        display: block;
        font-size: 0.9em; }
      footer .sitemap .group ul {
        margin: 0;
        padding: 0;
        list-style-type: none; }
        footer .sitemap .group ul li {
          position: relative;
          margin: 1.1em 0;
          padding-right: 20px;
          color: #fff;
          font-size: 1.03em;
          line-height: 1.3;
          text-transform: uppercase; }
          footer .sitemap .group ul li ul {
            margin-top: 2em;
            margin-left: 1.2em; }
            footer .sitemap .group ul li ul li {
              padding-right: 0; }
      footer .sitemap .group > ul > li:first-child > a {
        position: relative;
        display: block;
        padding-right: 30px; }
        footer .sitemap .group > ul > li:first-child > a:after {
          background: url(../assets/sprites/parts.svg) no-repeat;
          background-position: -140px -80px;
          background-size: 275px 227px;
          width: 40px;
          height: 40px;
          content: "";
          display: block;
          position: absolute;
          top: 50%;
          right: -10px;
          -webkit-transform: translate(0, -50%) scale(0.9, 0.9);
                  transform: translate(0, -50%) scale(0.9, 0.9);
          -webkit-transform-origin: 100% 50%;
                  transform-origin: 100% 50%; }
      footer .sitemap .group a {
        text-decoration: none;
        color: #fff; }
        footer .sitemap .group a span.title {
          border-bottom: 1px solid #fff; }
        .pc footer .sitemap .group a:hover span.title {
          border-bottom-width: 2px; }
  footer .framed {
    margin: 30px 40px 0 0;
    padding: 20px 36px;
    background: #fff;
    font-size: 0.85em;
    line-height: 1.8;
    color: #666;
    text-shadow: none; }
    footer .framed ul {
      margin: 0;
      padding: 0;
      list-style-type: none; }
      footer .framed ul li {
        display: inline-block; }
    footer .framed .copyright {
      margin-bottom: 5px;
      text-align: center; }
    footer .framed ul li {
      display: block; }
      footer .framed ul li a {
        display: inline;
        position: relative;
        display: inline;
        text-decoration: none;
        line-height: 1em;
        border-bottom: 1px solid #666; }
        footer .framed ul li a[target="_blank"] {
          padding-right: 5px; }
        footer .framed ul li a:hover {
          border-bottom-width: 2px; }
        footer .framed ul li a img {
          margin-left: 0.5em; }
/* #17 add */
footer dl.entity{
 padding: 1em 0 0.5em 0;
 text-align: center;
}
footer dl.entity dt,
footer dl.entity dd{
 display: inline;
}
footer dl.entity dd{
 margin-left: 1em;
 white-space: nowrap;
}
/* #17 add */

@media (max-width: 800px) {
  footer {
    padding: 20px 0 15px 13px; }
    footer .sitemap .group {
      width: 49.9999%;
      padding: 10px 20px 25px 0; }
      footer .sitemap .group:before {
        right: 13px; }
      footer .sitemap .group .logo {
        zoom: 0.7; }
      footer .sitemap .group ul {
        font-size: 0.7em; }
        footer .sitemap .group ul li {
          margin: 1em 0;
          font-size: 1em; }
          footer .sitemap .group ul li ul {
            font-size: inherit; }
    footer .framed {
      display: block;
      margin: 0 13px 0 0;
      padding: 25px 13px 13px;
      text-align: center;
      font-size: 0.68em; }
      footer .framed .copyright {
        margin-bottom: 1.3em; }
      footer .framed ul li {
        margin: 0.8em 0;
        font-size: inherit; }
  .nav-opened footer {
    display: none; }
/* #17 add */
 footer dl.entity dt+dd::after{
  content: "\A" ;
  white-space: pre ;
 }
/* #17 add */
}

/* #17 add */
@media (max-width: 360px) {
 footer dl.entity dt,
 footer dl.entity dd{
  display: block;
 }
 footer dl.entity dt+dd::after{
  content: "";
 }
}
/* #17 add */

/* display in session (top page) */
#main-visual .summit-info .insession{
 height: 59px;
}
html[lang="ja"] #main-visual .summit-info p.insession .days{
 font-size: 1.8em;
}
html[lang="en"] #main-visual .summit-info p.insession .days{
 font-size: 1.5em;
}
@media (max-width: 800px) {
 html[lang="ja"] #main-visual .summit-info p.insession .days{
  padding-top: 15px;
 }
 html[lang="en"] #main-visual .summit-info p.insession .days{
  padding-top: 20px;
 }
}
/* display in session (top page) */
