@charset "UTF-8";
/*!
 * YUI 3.5.0 - reset.css (http://developer.yahoo.com/yui/3/cssreset/)
 * http://cssreset.com
 * Copyright 2012 Yahoo! Inc. All rights reserved.
 * http://yuilibrary.com/license/
 */
/*
    TODO will need to remove settings on HTML since we can't namespace it.
    TODO with the prefix, should I group by selector or property for weight savings?
*/
html {
  color: #000;
  background: #FFF; }

/*
    TODO remove settings on BODY since we can't namespace it.
*/
/*
    TODO test putting a class on HEAD.
        - Fails on FF.
*/
blockquote,
body,
code,
dd,
div,
dl,
dt,
fieldset,
form,
h1,
h2,
h3,
h4,
h5,
h6,
input,
legend,
li,
ol,
p,
pre,
td,
textarea,
th,
ul,
figure {
  margin: 0;
  padding: 0; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

fieldset,
img {
  border: 0; }

/*
    TODO think about hanlding inheritence differently, maybe letting IE6 fail a bit...
*/
address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  font-weight: normal; }

ol,
ul {
  list-style: none; }

caption,
th {
  text-align: left; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal; }

q:after,
q:before {
  content: ''; }

abbr,
acronym {
  border: 0;
  font-variant: normal; }

/* to preserve line-height and selector appearance */
sup {
  vertical-align: text-top; }

sub {
  vertical-align: text-bottom; }

input,
select,
textarea {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit; }

/*to enable resizing for IE*/
input,
select,
textarea {
  *font-size: 100%; }

/*because legend doesn't inherit in IE */
legend {
  color: #000; }

/* YUI CSS Detection Stamp */
#yui3-css-stamp.cssreset {
  display: none; }

@font-face {
  font-family: 'icomoon';
  src: url("../fonts/icomoon.eot?7lnntq");
  src: url("../fonts/icomoon.eot?7lnntq#iefix") format("embedded-opentype"), url("../fonts/icomoon.ttf?7lnntq") format("truetype"), url("../fonts/icomoon.woff?7lnntq") format("woff"), url("../fonts/icomoon.svg?7lnntq#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block; }

html {
  font-family: shippori-antique, "ＭＳ Ｐゴシック", "MS PGothic", "Droid Sans", "Osaka", sans-serif;
  font-size: 62.5%;
  font-weight: 400;
  font-style: normal;
  font-feature-settings: "normal";
  letter-spacing: 0;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #e60012;
  border-right: 0.8rem solid #e60012;
  box-sizing: border-box;
  overflow-x: hidden; }

* {
  box-sizing: border-box; }

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
  font-family: shippori-antique, "ＭＳ Ｐゴシック", "MS PGothic", "Droid Sans", "Osaka", sans-serif; }

body {
  font-size: 0; }

h1, h2, h3, h4, h5, h6 {
  font-weight: inherit;
  font-style: inherit; }

ul {
  list-style: none; }

img {
  display: block; }

a {
  color: inherit;
  text-decoration: none;
  position: relative;
  /*
  &:hover, &:active {
    color: $gray;
    background: $gray;
  }
  */ }

::selection {
  background: #84ccc9; }

::-moz-selection {
  background: #84ccc9; }

#wrapper {
  position: relative;
  padding-top: 30.0rem; }

#cover {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 0;
  background-image: url("../images/cover_x.jpg");
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: top right;
  border-right: 0.8rem solid #e60012;
  box-sizing: border-box;
  height: 30.0rem; }

#header {
  position: sticky;
  top: 0;
  width: 100%;
  height: 7.0rem;
  background-color: #e60012;
  box-sizing: border-box;
  z-index: 998; }
  #header h1 {
    text-align: center; }
    #header h1 a {
      display: inline-block;
      padding: 1.0rem 0;
      margin: 0 auto; }
      #header h1 a img {
        height: 5.0rem; }
  #header #sns {
    position: absolute;
    display: block;
    right: 2.6rem;
    top: 3.5rem;
    transform: translate(0, -50%); }
    #header #sns li {
      float: left;
      margin-left: 1.0rem; }
      #header #sns li a {
        font-size: 1.4rem;
        line-height: 1.4rem;
        background: #ddd;
        color: #e60012;
        border-radius: 0.4rem;
        padding: 0.4rem 0.8rem 0.4rem 0.8rem; }
        #header #sns li a.twitter::before, #header #sns li a.facebook::before {
          font-family: 'icomoon' !important;
          speak: never;
          font-style: normal;
          font-weight: normal;
          font-variant: normal;
          text-transform: none;
          line-height: 1;
          -webkit-font-smoothing: antialiased;
          -moz-osx-font-smoothing: grayscale; }
        #header #sns li a.twitter::before {
          content: "\ea96"; }
        #header #sns li a.facebook::before {
          content: "\ea91"; }
  #header.fixed {
    position: fixed;
    top: 0; }
  #header #hamburger {
    display: none; }

#nav {
  position: fixed;
  left: 2.6rem;
  bottom: 2.6rem;
  z-index: 999; }
  #nav ul {
    display: block; }
    #nav ul:after {
      display: block;
      content: "";
      clear: both; }
  #nav ul {
    text-align: left;
    font-size: 1.3rem;
    line-height: 3.9rem; }
    #nav ul li:last-child {
      border: 0; }
    #nav ul li a {
      display: block;
      position: relative;
      width: 100%;
      height: 100%;
      z-index: 1; }
      #nav ul li a::after {
        position: absolute;
        top: 0;
        left: 0;
        display: block;
        left: -2.6rem;
        content: "";
        width: 0;
        background: #e60012;
        height: 3.9rem;
        z-index: -1;
        transition: 0.2s; }
      #nav ul li a:hover {
        color: #ddd; }
      #nav ul li a:hover:after {
        width: calc(100% + 5.2rem); }

#main {
  display: block;
  width: 100%;
  overflow-x: hidden;
  background-image: url("../images/bg.png");
  background-repeat: repeat;
  z-index: 1; }
  #main section {
    max-width: 120.0rem;
    position: relative;
    margin: 0 auto;
    z-index: 5;
    padding: 2rem calc(2rem - 0.8rem) 8rem 16rem; }
    #main section div {
      margin: 0;
      padding: 0; }
    #main section h1, #main section h2, #main section p {
      color: #e60012; }
    #main section h2 {
      font-size: 2.0rem;
      line-height: 4.8rem;
      border-bottom: 0.2rem solid #e60012;
      margin-bottom: 4.0rem; }
    #main section p {
      font-size: 1.6rem;
      line-height: 3.0rem; }
      #main section p .small, #main section p.small {
        font-size: 1.2rem;
        margin-right: 0.3rem; }
    #main section ul li {
      font-size: 1.6rem;
      line-height: 3.0rem; }
      #main section ul li .small, #main section ul li.small {
        font-size: 1.2rem; }
      #main section ul li:before {
        content: "- "; }
    #main section ul li:last-child:after {
      content: ""; }
    #main section hr {
      position: relative;
      display: block;
      text-align: left;
      margin-left: 0;
      padding-top: 1.6rem;
      margin-bottom: 1.6rem;
      width: 3.2rem;
      border: 0;
      border-bottom: 0.1rem solid #e60012; }
    #main section address {
      font-size: 2.0rem;
      line-height: 3.6rem; }
    #main section .members {
      display: flex;
      flex-wrap: wrap;
      align-content: space-between;
      justify-content: space-between; }
    #main section .member {
      display: block;
      margin-bottom: 4.0rem;
      padding: 0 1.0rem 1.0rem 0;
      box-sizing: border-box;
      border-bottom: 0.2rem solid #e60012;
      border-right: 0.2rem solid #e60012;
      width: calc(50% - 2.0rem); }
      #main section .member:after {
        display: block;
        content: "";
        clear: both; }
      #main section .member__icon {
        float: left;
        width: 15.0rem;
        position: relative; }
      #main section .member__profile {
        float: right;
        width: calc(100% - 15.0rem);
        padding-left: 2.6rem;
        position: relative; }
        #main section .member__profile a {
          display: block;
          position: absolute;
          right: 0.5rem;
          top: 0.5rem;
          color: #e60012;
          text-decoration: none; }
          #main section .member__profile a::before {
            font-family: 'icomoon' !important;
            speak: never;
            font-style: normal;
            font-weight: normal;
            font-variant: normal;
            text-transform: none;
            line-height: 1;
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            display: block;
            font-size: 2.4rem;
            line-height: 2.4rem;
            color: #e60012; }
          #main section .member__profile a.twitter::before {
            content: "\ea96"; }
          #main section .member__profile a.soundcloud::before {
            content: "\eac3"; }
          #main section .member__profile a.instagram::before {
            content: "\ea92"; }
          #main section .member__profile a.web::before {
            content: "\e9c9"; }
        #main section .member__profile h3 {
          display: inline-block;
          font-size: 1.6rem;
          line-height: 2.0rem; }
        #main section .member__profile h4 {
          padding-left: 0.5rem;
          display: inline-block;
          font-size: 1.3rem;
          line-height: 2.4rem; }
        #main section .member__profile p {
          font-size: 1.3rem;
          line-height: 2.4rem; }
        #main section .member__profile hr {
          position: relative;
          display: block;
          text-align: left;
          margin-left: 0;
          padding-top: 1.2rem;
          margin-bottom: 1.2rem;
          width: 3.2rem;
          border: 0;
          border-bottom: 0.1rem solid #e60012; }
    #main section .text img {
      width: 100%;
      display: block; }
    #main section .text h3 {
      font-size: 2.8rem;
      line-height: 4.8rem; }
      #main section .text h3.midashi {
        font-family: fot-udmincho-pr6n, sans-serif;
        font-feature-settings: "palt";
        font-weight: 700;
        font-style: normal; }
    #main section .image {
      display: flex;
      position: relative;
      flex-wrap: wrap;
      align-content: space-between;
      justify-content: space-between; }
      #main section .image img {
        position: relative;
        display: block;
        width: calc(50% - 1.0rem);
        margin-bottom: 2.0rem; }
    #main section a.stripe {
      width: 50%;
      color: #ddd;
      background: #e60012;
      display: block;
      font-size: 1.6rem;
      line-height: 3.0rem;
      margin: 0 auto;
      text-decoration: line-through;
      text-align: center;
      transition: 0.5s all;
      /*
      &:hover {
        background: $mint;
        color: $red;

        &:after {
          color: $red;
        }
      }
      */ }
      #main section a.stripe .small {
        font-size: 1.2rem;
        line-height: 2.0rem; }
    #main section p.notice {
      margin-top: 1.0rem;
      font-size: 1.1rem;
      line-height: 1.8rem;
      text-align: center; }
    #main section:after {
      display: block;
      content: "";
      clear: both; }
  #main a {
    text-decoration: underline; }
  #main .map {
    height: 30.0rem;
    filter: grayscale(100%); }

.x1x3 {
  width: calc(100% / 3);
  float: left; }

.x2x3 {
  width: calc(100% / 3 * 2);
  float: right; }

.x1x2 {
  width: calc(100% / 2);
  float: left; }

.right {
  text-align: right; }

#footer {
  width: 100%;
  font-size: 1.4rem;
  line-height: 5.6rem;
  text-align: center;
  color: #e60012;
  background-color: #84ccc9;
  padding-bottom: 8.0rem; }

@media (max-width: 1000px) {
  /*
  [class^="icon-"]:after, [class*=" icon-"]:after {
    content: "";
  }
  */
  #cover {
    background-color: #e60012;
    background-image: url("../images/cover_y.jpg");
    background-size: auto 100vh;
    background-position: center top;
    height: calc(100vh - 7.0rem); }
  #wrapper {
    padding-top: calc(100vh - 7.0rem); }
  #header {
    transition: all 0.5s; }
    #header #sns {
      position: absolute;
      top: 7.0rem;
      left: 0;
      width: 100%;
      height: 3.0rem;
      background: #e60012;
      color: #ddd;
      transform: none;
      right: auto; }
      #header #sns li {
        float: left;
        display: block;
        width: 50%;
        text-align: center;
        margin: auto;
        border-radius: 0;
        border-bottom: 0.1rem solid #e60012;
        box-sizing: border-box; }
        #header #sns li:first-child {
          border-right: 0.1rem solid #e60012; }
        #header #sns li a {
          display: block;
          padding: 0;
          height: 3.0rem;
          line-height: 3.0rem;
          border-radius: 0; }
          #header #sns li a:hover {
            background-color: #e60012;
            color: #ddd; }
    #header #hamburger {
      display: block;
      position: absolute;
      right: 2rem;
      top: 3.5rem;
      transform: translate(0, -50%);
      width: 30px;
      height: 20px;
      cursor: pointer;
      display: inline-block;
      transition: all 0.5s;
      box-sizing: border-box; }
      #header #hamburger span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 3px;
        background-color: #ddd;
        border-radius: 3px;
        display: inline-block;
        transition: all 0.5s;
        box-sizing: border-box; }
        #header #hamburger span:nth-of-type(1) {
          top: 0; }
        #header #hamburger span:nth-of-type(2) {
          top: 8.5px; }
        #header #hamburger span:nth-of-type(3) {
          bottom: 0; }
    #header.active #hamburger span:nth-of-type(1) {
      -webkit-transform: translateY(9px) rotate(-315deg);
      transform: translateY(9px) rotate(-315deg); }
    #header.active #hamburger span:nth-of-type(2) {
      opacity: 0; }
    #header.active #hamburger span:nth-of-type(3) {
      -webkit-transform: translateY(-9px) rotate(315deg);
      transform: translateY(-9px) rotate(315deg); }
  #nav {
    height: 0;
    left: 0;
    right: 0;
    top: 100vh;
    bottom: 0;
    transition: 0.5s all;
    perspective: 1000;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    overflow: hidden;
    white-space: nowrap;
    background: #e60012;
    border-right: 0.8rem solid #e60012; }
    #nav ul li a {
      display: block;
      width: 100%;
      height: 6.0rem;
      font-size: 1.4rem;
      line-height: 6.0rem;
      border-bottom: 0.1rem solid #ddd;
      color: #ddd;
      text-align: center; }
      #nav ul li a:after {
        display: none; }
      #nav ul li a:hover {
        background-color: #ddd;
        color: #e60012; }
    #nav.active {
      top: 10.1rem;
      height: calc(100vh - 10.1rem); }
  #main {
    padding-top: 3.0rem; }
    #main section {
      margin: 0;
      padding-left: 2rem; }
      #main section p {
        font-size: 1.4rem;
        line-height: 2.8rem;
        width: 100%; }
      #main section ul li {
        font-size: 1.4rem;
        line-height: 2.8rem; }
      #main section .member {
        width: calc(50% - 1.0rem);
        margin: 0 0 2.0rem 0; }
        #main section .member__icon, #main section .member__profile {
          float: none;
          width: 100%;
          padding-left: 0; }
        #main section .member__icon img {
          width: 100%;
          margin-bottom: 2.0rem; }
        #main section .member__profile h3, #main section .member__profile h4 {
          display: block;
          padding: 0; }
      #main section a.stripe {
        width: 40.0rem;
        max-width: 100%;
        font-size: 1.4rem;
        line-height: 2.5rem;
        height: 5.0rem;
        /*
        &:hover {
          background: $mint;
          color: $red;

          &:after {
            color: $red;
          }
        }
        */ }
        #main section a.stripe:after {
          font-size: 1.2rem;
          line-height: 2.5rem; }
      #main section .text h3.midashi {
        width: 100%; }
      #main section .image {
        display: block; }
        #main section .image img {
          width: 100%;
          margin: 0 0 1.0rem 0; }
      #main section#introduction .text h3.midashi {
        margin-bottom: 2.0rem; }
  .x1x3, .x2x3, .x1x2 {
    width: 100%;
    float: none; }
  .map {
    margin-top: 2.0rem; } }

body {
  opacity: 1; }
  body.hidden {
    opacity: 0; }
