@charset "UTF-8";
/* color
================================================== */
/* effect
================================================== */
/* frame
================================================== */
/* break point
================================================== */
/* mixin
================================================== */
/* media query
================================================== */
/* meyer
================================================== */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline; }

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

body {
  line-height: 1; }

ol, ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

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

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

/* addition
================================================== */
a {
  color: #000;
  text-decoration: none; }

/* clearfix
================================================== */
.clearfix::after {
  content: '';
  display: block;
  clear: both;
  height: 0; }

.clearfix {
  zoom: 1; }

/* font
================================================== */
@font-face {
  font-family: 'Hannari';
  src: url(../font/hannari.eot) format("embedded-opentype");
  src: url(../font/hannari.otf) format("opentype");
  /*src: local('hannari Regular'), local('hannari');*/ }
/*このフォントはIPAフォントライセンスv1.0の下で提供されています。(http://ipafont.ipa.go.jp/ipa_font_license_v1.html)*/
.font_hannari {
  font-family: 'Hannari', serif; }

.font_montserrat {
  font-family: 'Montserrat', sans-serif; }

/* a
================================================== */
a:hover,
a:hover > li {
  opacity: 0.5; }

/* break
================================================== */
.break {
  display: none; }
  @media screen and (min-width: 750px) {
    .break {
      display: inline; } }
  @media screen and (min-width: 1060px) {
    .break {
      display: none; } }

/* effect
================================================== */
.effect_1 {
  transition: 1s; }

.effect_2 {
  transition: 1s;
  transition-delay: 0.5s; }

.effect_3 {
  transition: 1s;
  transition-delay: 1s; }

.effect_4 {
  transition: 1s;
  transition-delay: 1.5s; }

/* frame
================================================== */
@media screen and (min-width: 750px) {
  html::before {
    background: #fff;
    content: "";
    display: block;
    position: fixed;
    z-index: 1;
    height: 30px;
    top: 0;
    right: 0;
    left: 0; }

  html::after {
    background: #fff;
    content: "";
    display: block;
    position: fixed;
    z-index: 1;
    width: 30px;
    top: 0;
    right: 0;
    bottom: 0; }

  body::before {
    background: #fff;
    content: "";
    display: block;
    position: fixed;
    z-index: 1;
    height: 30px;
    right: 0;
    bottom: 0;
    left: 0; }

  body::after {
    background: #fff;
    content: "";
    display: block;
    position: fixed;
    z-index: 1;
    width: 30px;
    top: 0;
    bottom: 0;
    left: 0; } }
/* container
================================================== */
.container {
  overflow-x: hidden; }
  @media screen and (min-width: 750px) {
    .container {
      border: solid 30px #fff;
      margin: 0 auto; } }

/* main
================================================== */
@media screen and (min-width: 750px) {
  .main {
    background: url(../images/background@2x.jpg) left top repeat;
    background-size: 640px;
    margin: 0 auto;
    width: 100%; } }
/* inner
================================================== */
@media screen and (min-width: 750px) {
  .inner {
    margin: 0 auto;
    max-width: 1000px;
    width: 100%; } }
/* headline
================================================== */
.headline {
  display: none; }

/* header
================================================== */
@media screen and (min-width: 750px) {
  .Header {
    height: 51.15vw;
    margin: 0 auto 30px;
    width: 100%; } }
  @media screen and (min-width: 750px) and (min-width: 1400px) {
    .Header {
      height: 716px; } }

  @media screen and (min-width: 750px) and (min-width: 1400px) and (min-width: 2560px) {
    .Header {
      width: 2500px; } }

.Header__main {
  height: 60vw;
  position: relative;
  width: 100%; }
  @media screen and (min-width: 750px) {
    .Header__main {
      float: right;
      height: 100%;
      text-align: center;
      width: 26.7%; } }
.Header__sub {
  background: url(../images/photo_main_sp@2x.jpg) center center no-repeat;
  background-size: 100%;
  height: 100vw;
  width: 100%; }
  @media screen and (min-width: 750px) {
    .Header__sub {
      background: url(../images/photo_main_pc@2x.jpg) center center no-repeat;
      background-size: cover;
      float: left;
      height: 100%;
      text-align: center;
      width: 73.3%; } }
.Header__body {
  background: #fff;
  display: none;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 2; }
  @media screen and (min-width: 750px) {
    .Header__body {
      background: auto;
      display: block;
      height: auto;
      position: static;
      top: auto;
      left: auto;
      width: auto;
      z-index: auto; } }

.Logo__img {
  display: inline;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 12.5%; }
  @media screen and (min-width: 750px) {
    .Logo__img {
      margin: 10.7vw 0 7.7vw;
      position: static;
      top: auto;
      left: auto;
      transform: none;
      width: 4.4vw; } }
  @media screen and (min-width: 750px) and (min-width: 1400px) {
    .Logo__img {
      margin: 150px 0 108px;
      width: 62px; } }

.Burger {
  position: fixed;
  top: 20px;
  right: 20px;
  width: 12%;
  z-index: 3; }
  @media screen and (min-width: 750px) {
    .Burger {
      display: none; } }
  .Burger__img {
    width: 100%; }

.Nav {
  letter-spacing: 0.24em;
  /* autoprefixer: off */
  -webkit-writing-mode: vertical-rl;
  /* autoprefixer: on */
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl; }
  @media screen and (min-width: 750px) {
    .Nav {
      background: url(../images/border_nav.svg) center top no-repeat, url(../images/border_nav.svg) center bottom no-repeat;
      background-size: 100%, 100%;
      font-size: 1vw;
      height: 14.3vw;
      margin: 0 auto;
      min-height: 13.5em;
      min-width: 15em;
      position: absolute;
      bottom: 8%;
      left: 50%;
      text-align: left;
      transform: translateX(-50%);
      width: 17vw; } }
  @media screen and (min-width: 750px) and (min-width: 1400px) {
    .Nav {
      font-size: 87.5%;
      height: 200px;
      width: 238px; } }

  .Nav__menu {
    font-size: 112.5%;
    height: 9em;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); }
    @media screen and (min-width: 750px) {
      .Nav__menu {
        font-size: 100%;
        height: auto;
        margin: 3.4vw 2.2vw 1.7vw 0;
        position: static;
        top: auto;
        left: auto;
        transform: none; } }
  @media screen and (min-width: 750px) and (min-width: 1400px) {
    .Nav__menu {
      margin: 48px 30px 24px; } }

    .Nav__menu__item {
      margin-left: 1.5em; }
      @media screen and (min-width: 750px) {
        .Nav__menu__item {
          margin-left: 1.9vw; } }
  @media screen and (min-width: 750px) and (min-width: 1400px) {
    .Nav__menu__item {
      margin-left: 27px; } }

      .Nav__menu__item:last-of-type {
        margin-left: 0; }

.Social {
  height: 30px;
  min-width: 80px;
  position: absolute;
  top: 80%;
  left: 50%;
  transform: translate(-50%, -50%); }
  @media screen and (min-width: 750px) {
    .Social {
      height: 1.7vw;
      margin: 0 auto;
      min-width: inherit;
      top: auto;
      bottom: 0;
      transform: translateX(-50%);
      width: 17vw; } }
  @media screen and (min-width: 750px) and (min-width: 1400px) {
    .Social {
      height: 24px;
      width: 238px; } }

  .Social__menu__item {
    float: right;
    margin-left: 20px;
    width: 30px; }
    @media screen and (min-width: 750px) {
      .Social__menu__item {
        margin-left: 1.2vw;
        width: 1.7vw; } }
  @media screen and (min-width: 750px) and (min-width: 1400px) {
    .Social__menu__item {
      margin-left: 16px;
      width: 24px; } }

    @media screen and (min-width: 750px) {
      .Social__menu__item:first-of-type {
        margin-right: 0.9vw; } }
  @media screen and (min-width: 750px) and (min-width: 1400px) {
    .Social__menu__item:first-of-type {
      margin-right: 9px; } }

    .Social__menu__item:last-of-type {
      margin-left: 0; }
    .Social__menu__item__img {
      width: 100%; }

/* footer
================================================== */
.Footer {
  position: relative; }
  @media screen and (min-width: 750px) {
    .Footer {
      padding: 0;
      position: fixed;
      text-align: left;
      top: 30px;
      left: 10px;
      z-index: 6; } }
  .Footer__body {
    display: block;
    font-size: 2.7vw;
    letter-spacing: 0.08em;
    padding: 4vw 0;
    position: absolute;
    bottom: 0;
    text-align: center;
    width: 100%;
    z-index: 6; }
    @media screen and (min-width: 750px) {
      .Footer__body {
        display: inline;
        font-size: 62.5%;
        padding: 0;
        position: static;
        text-align: left;
        width: auto;
        z-index: auto;
        /* autoprefixer: off */
        -webkit-text-orientation: sideways;
        /* autoprefixer: on */
        -ms-text-orientation: sideways;
        text-orientation: sideways;
        /* autoprefixer: off */
        -webkit-writing-mode: vertical-rl;
        /* autoprefixer: on */
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl; } }

/* topics
================================================== */
.Topics {
  background: url(../images/headline_h_topics.svg) center top 8.5vw no-repeat, url(../images/background@2x.jpg) center top repeat;
  background-size: 42.6vw, 640px;
  padding: 27vw 4vw 9vw;
  text-align: center; }
  @media screen and (min-width: 750px) {
    .Topics {
      background: url(../images/headline_v_topics.svg) right 20px top 100px no-repeat;
      background-size: 33px;
      padding: 125px 0 50px;
      position: relative; } }

.News {
  padding-left: 8vw;
  text-align: left; }
  @media screen and (min-width: 750px) {
    .News {
      margin: 0 auto 40px;
      padding-left: 0;
      width: 74%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .News {
      width: 740px; } }

  .News__main {
    display: block;
    float: left;
    letter-spacing: 0.08em;
    width: 50vw; }
    @media screen and (min-width: 750px) {
      .News__main {
        display: inline;
        float: none;
        width: auto; } }
  .News__sub {
    display: block;
    float: left; }
    @media screen and (min-width: 750px) {
      .News__sub {
        display: inline;
        float: none; } }
  .News__item {
    display: block;
    margin-bottom: 8vw; }
    @media screen and (min-width: 750px) {
      .News__item {
        float: left;
        margin: 0 9.5% 0 0;
        width: 27%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .News__item {
      margin: 0 70px 0 0;
      width: 200px; } }
    @media screen and (min-width: 750px) {
        .News__item:last-of-type {
          margin: 0; } }
  .News__thumb {
    margin-right: 5.3vw; }
    @media screen and (min-width: 750px) {
      .News__thumb {
        margin: 0 0 33px; } }
    .News__thumb__img {
      border-radius: 100px;
      width: 26.7vw; }
      @media screen and (min-width: 750px) {
        .News__thumb__img {
          width: 100%; } }
  .News__date {
    font-size: 3.73vw;
    margin: 2vw 0 3vw;
    width: 45vw; }
    @media screen and (min-width: 750px) {
      .News__date {
        font-size: 81.25%;
        letter-spacing: 0.1em;
        margin: 0 auto 5px;
        width: 90%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .News__date {
      width: 180px; } }

  .News__category {
    color: #646a58;
    font-size: 3.47vw;
    margin-bottom: 3vw; }
    @media screen and (min-width: 750px) {
      .News__category {
        font-size: 68.75%;
        letter-spacing: 0.1em;
        margin: 0 auto 10px;
        width: 90%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .News__category {
      width: 180px; } }

    .News__category::before {
      content: "---"; }
  .News__title {
    font-size: 3.73vw;
    line-height: 1.5; }
    @media screen and (min-width: 750px) {
      .News__title {
        font-size: 75%;
        letter-spacing: 0.1em;
        margin: 0 auto;
        width: 90%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .News__title {
      width: 180px; } }

/* concept
================================================== */
.Concept {
  background: url(../images/headline_h_concept.svg) center top 8.5vw no-repeat;
  background-size: 64.2vw, 640px;
  padding: 28.5vw 0 14.7vw; }
  @media screen and (min-width: 750px) {
    .Concept {
      background: url(../images/headline_v_concept.svg) right 20px top 100px no-repeat;
      background-size: 33px;
      padding: 90px 0 80px;
      position: relative; } }

.Copy {
  height: 98vw;
  position: relative;
  width: 100%; }
  @media screen and (min-width: 750px) {
    .Copy {
      font-size: 193.75%;
      height: 12.5em;
      letter-spacing: 0.32em;
      margin-bottom: 90px; } }
  .Copy__body {
    display: inline;
    font-size: 6.7vw;
    letter-spacing: 0.34em;
    position: absolute;
    top: 0%;
    left: 50%;
    transform: translateX(-50%);
    /* autoprefixer: off */
    -webkit-writing-mode: vertical-rl;
    /* autoprefixer: on */
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl; }
    @media screen and (min-width: 750px) {
      .Copy__body {
        font-size: 100%;
        letter-spacing: inherit; } }
    .Copy__body span {
      margin-bottom: 0.5em; }

@media screen and (min-width: 1060px) {
  .Message {
    display: block;
    height: 24.5em;
    margin: 0 auto 105px;
    position: relative;
    width: 80%; } }
@media screen and (min-width: 1060px) {
  .Message__body {
    display: inline;
    letter-spacing: 0.28em;
    line-height: 2.8;
    position: absolute;
    top: 0%;
    left: 50%;
    transform: translateX(-50%);
    /* autoprefixer: off */
    -webkit-writing-mode: vertical-rl;
    /* autoprefixer: on */
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl; } }
@media screen and (min-width: 750px) {
  .Message__body__1st {
    height: 22em;
    letter-spacing: 0.28em;
    line-height: 2.8;
    margin: 0 auto 75px;
    position: relative;
    width: 80%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Message__body__1st {
      height: 100%;
      margin: 0 0 0 40px;
      position: static;
      width: auto; } }

@media screen and (min-width: 750px) {
  .Message__body__1st__unit {
    display: inline;
    position: absolute;
    top: 0%;
    left: 50%;
    transform: translateX(-50%);
    /* autoprefixer: off */
    -webkit-writing-mode: vertical-rl;
    /* autoprefixer: on */
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Message__body__1st__unit {
      position: static;
      top: auto;
      left: auto;
      transform: none; } }

@media screen and (max-width: 749px) {
  .Message__body__1st__unit__A {
    display: block;
    height: 94vw;
    margin: 0 auto;
    position: relative;
    width: 80%; } }
@media screen and (max-width: 749px) {
  .Message__body__1st__unit__A__text {
    display: inline;
    font-size: 3.7vw;
    letter-spacing: 0.28em;
    line-height: 2.6;
    position: absolute;
    top: 0%;
    left: 50%;
    transform: translateX(-50%);
    /* autoprefixer: off */
    -webkit-writing-mode: vertical-rl;
    /* autoprefixer: on */
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl; } }
@media screen and (max-width: 749px) {
  .Message__body__1st__unit__B {
    display: block;
    float: right;
    height: 107vw;
    margin-right: 10.5vw;
    position: relative;
    width: 40%; } }
@media screen and (max-width: 749px) {
  .Message__body__1st__unit__B__text {
    display: inline;
    font-size: 3.7vw;
    letter-spacing: 0.28em;
    line-height: 2.6;
    position: absolute;
    top: 0%;
    left: 50%;
    transform: translateX(-50%);
    /* autoprefixer: off */
    -webkit-writing-mode: vertical-rl;
    /* autoprefixer: on */
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl; } }
.Message__body__2nd {
  display: block;
  float: right;
  height: 107vw;
  margin-right: 4vw;
  position: relative;
  width: 40%; }
  @media screen and (min-width: 750px) {
    .Message__body__2nd {
      display: inherit;
      float: none;
      height: 24.5em;
      letter-spacing: 0.28em;
      line-height: 2.8;
      margin: 0 auto 105px;
      width: 80%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Message__body__2nd {
      height: 100%;
      margin: 0;
      position: static;
      width: auto; } }

  .Message__body__2nd__unit {
    display: inline;
    font-size: 3.7vw;
    letter-spacing: 0.28em;
    line-height: 2.6;
    position: absolute;
    top: 0%;
    left: 50%;
    transform: translateX(-50%);
    /* autoprefixer: off */
    -webkit-writing-mode: vertical-rl;
    /* autoprefixer: on */
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl; }
    @media screen and (min-width: 750px) {
      .Message__body__2nd__unit {
        font-size: 100%;
        letter-spacing: inherit;
        line-height: inherit; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Message__body__2nd__unit {
      position: static; } }

.Profile {
  background: url(../images/photo_portrait@2x.png) center top no-repeat;
  background-size: 40vw;
  clear: right;
  height: 140vw;
  position: relative;
  width: 100%; }
  @media screen and (min-width: 750px) {
    .Profile {
      background: url(../images/photo_portrait@2x.png) right 40px top 5px no-repeat;
      background-size: 150px;
      clear: none;
      height: 310px;
      margin: 0 auto;
      width: 530px; } }
  .Profile__item {
    display: inline;
    position: absolute;
    top: 48vw;
    left: 50%;
    transform: translateX(-50%);
    /* autoprefixer: off */
    -webkit-writing-mode: vertical-rl;
    /* autoprefixer: on */
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl; }
    @media screen and (min-width: 750px) {
      .Profile__item {
        top: 0%;
        left: 15px;
        transform: none; } }
    .Profile__item__job {
      font-size: 3.6vw;
      letter-spacing: 0.34em;
      line-height: 1.5;
      margin-left: 3.6vw; }
      @media screen and (min-width: 750px) {
        .Profile__item__job {
          font-size: 75%;
          letter-spacing: 0.32em;
          line-height: 1.54;
          margin-left: 15px; } }
    .Profile__item__name {
      font-size: 6vw;
      letter-spacing: 0.32em;
      margin-left: 5vw; }
      @media screen and (min-width: 750px) {
        .Profile__item__name {
          font-size: 137.5%;
          margin-left: 25px; } }
      .Profile__item__name span {
        margin-bottom: 0.4em; }
    .Profile__item__bio {
      font-size: 3.3vw;
      height: 27em;
      letter-spacing: 0.24em;
      line-height: 1.8; }
      @media screen and (min-width: 750px) {
        .Profile__item__bio {
          font-size: 68.75%;
          height: auto;
          line-height: 2;
          max-height: 27em; } }

/* works
================================================== */
.Works {
  background: url(../images/headline_h_works.svg) center top 8.5vw no-repeat, url(../images/background@2x.jpg) center top repeat;
  background-size: 49.8vw;
  padding: 34vw 0 30vw;
  position: relative;
  text-align: center; }
  @media screen and (min-width: 750px) {
    .Works {
      background: url(../images/headline_v_works.svg) right 20px top 100px no-repeat;
      background-size: 33px;
      padding: 85px 0 95px; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Works {
      min-height: 630px; } }

.Seed__1st {
  margin-bottom: 6vw; }
  @media screen and (min-width: 750px) {
    .Seed__1st {
      margin-bottom: 6%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Seed__1st {
      margin-bottom: 60px; } }

  .Seed__1st__img {
    width: 32.1vw; }
    @media screen and (min-width: 750px) {
      .Seed__1st__img {
        width: 26.7%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Seed__1st__img {
      width: 267px; } }

.Seed__2nd {
  display: inline-block;
  margin-right: 19vw; }
  @media screen and (min-width: 750px) {
    .Seed__2nd {
      margin-right: 18%;
      width: 28.4%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Seed__2nd {
      margin-right: 180px;
      width: auto; } }

  .Seed__2nd__img {
    width: 34.1vw; }
    @media screen and (min-width: 750px) {
      .Seed__2nd__img {
        width: 100%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Seed__2nd__img {
      width: 284px; } }

.Seed__3rd {
  display: inline-block; }
  @media screen and (min-width: 750px) {
    .Seed__3rd {
      width: 26.7%; } }
  .Seed__3rd__img {
    width: 32.1vw; }
    @media screen and (min-width: 750px) {
      .Seed__3rd__img {
        width: 100%; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Seed__3rd__img {
      width: 267px; } }

.Toggle__item {
  display: none;
  margin-top: 7vw;
  padding: 7vw 0; }
  @media screen and (min-width: 750px) {
    .Toggle__item {
      margin-top: 40px;
      padding: 40px 0; } }
  .Toggle__item__head {
    background: url(../images/border_works.svg) center bottom no-repeat;
    background-size: 100% 1px;
    font-size: 3.7vw;
    letter-spacing: 0.32em;
    line-height: 2;
    margin: 0 auto 11.7vw;
    width: 66.7vw; }
    @media screen and (min-width: 750px) {
      .Toggle__item__head {
        background-size: 100%;
        font-size: 118.75%;
        margin-bottom: 60px;
        width: 435px; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Toggle__item__head {
      margin: 0 auto 60px; } }

  .Toggle__item__foot {
    margin: 0 auto;
    width: 11.5vw; }
    @media screen and (min-width: 750px) {
      .Toggle__item__foot {
        width: 50px; } }
    .Toggle__item__foot__img {
      width: 100%; }

.Lineup {
  margin-bottom: 9.3vw; }
  @media screen and (min-width: 750px) {
    .Lineup {
      margin: 0 auto 55px;
      width: 480px; } }
  @media screen and (min-width: 750px) and (min-width: 750px) {
    .Lineup {
      width: 840px; } }

  .Lineup__thumb {
    margin: 0 auto 4vw;
    width: 80vw; }
    @media screen and (min-width: 750px) {
      .Lineup__thumb {
        margin-bottom: 0;
        width: 300px; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Lineup__thumb {
      float: left;
      margin-right: 60px; } }

  .Lineup__text {
    margin: 0 auto;
    width: 88.8vw; }
    @media screen and (min-width: 750px) {
      .Lineup__text {
        width: 480px; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Lineup__text {
      float: left; } }

    .Lineup__text__head {
      font-size: 4.5vw;
      letter-spacing: 0.26em;
      line-height: 2.9;
      position: relative; }
      @media screen and (min-width: 750px) {
        .Lineup__text__head {
          font-size: 137.5%;
          letter-spacing: 0.3em;
          line-height: 3; } }
      .Lineup__text__head span {
        margin-left: 12vw; }
        @media screen and (min-width: 750px) {
          .Lineup__text__head span {
            margin-left: 60px; } }
      .Lineup__text__head__img {
        position: absolute;
        top: -1vw;
        left: 8vw;
        width: 12.3vw; }
        @media screen and (min-width: 750px) {
          .Lineup__text__head__img {
            top: 3px;
            left: 65px;
            width: 51px; } }
    .Lineup__text__body {
      font-size: 3.5vw;
      letter-spacing: 0.08em;
      line-height: 2;
      text-align: left; }
      @media screen and (min-width: 750px) {
        .Lineup__text__body {
          font-size: 87.5%;
          letter-spacing: 0.2em; } }
      .Lineup__text__body span {
        margin-left: -1.9vw; }
        @media screen and (min-width: 750px) {
          .Lineup__text__body span {
            margin-left: -9px; } }

/* diary
================================================== */
.Diary {
  background: url(../images/headline_h_diary.svg) center top 8.5vw no-repeat;
  background-size: 48.4vw, 640px;
  min-height: 54vw;
  padding: 23.3vw 0 22.7vw;
  text-align: center; }
  @media screen and (min-width: 750px) {
    .Diary {
      background: url(../images/headline_v_diary.svg) right 20px top 100px no-repeat;
      background-size: 33px;
      min-height: 270px;
      padding: 95px 0 60px; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Diary {
      padding: 95px 0 75px; } }

.Instagram {
  display: inline-block; }
  .Instagram__timeline {
    display: inline-block; }
    .Instagram__timeline li {
      float: left;
      height: 45vw;
      margin: 0 0 7px 7px;
      /*overflow: hidden;
      position: relative;*/
      width: 45vw; }
      .Instagram__timeline li:nth-of-type(2n+1) {
        clear: left;
        margin-left: 0; }
      @media screen and (min-width: 750px) {
        .Instagram__timeline li {
          height: 22.6vw;
          margin: 0 0 13px 13px;
          width: 22.6vw; } }
  @media screen and (min-width: 750px) and (min-width: 1060px) {
    .Instagram__timeline li {
      height: 270px;
      width: 270px; } }
      @media screen and (min-width: 750px) {
          .Instagram__timeline li:nth-of-type(2n+1) {
            clear: none;
            margin-left: 13px; }
          .Instagram__timeline li:nth-of-type(3n+1) {
            clear: left;
            float: left;
            margin-left: 0; } }
      .Instagram__timeline li img {
        /*display: block;
        min-height: 100%;
        min-width: 100%;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%);*/
        height: 100%;
        width: 100%;
        object-fit: cover; }

/* contact
================================================== */
.Contact {
  background: url(../images/headline_h_contact.svg) center top 8.5vw no-repeat, url(../images/background@2x.jpg) center top repeat;
  background-size: 58.4vw;
  padding: 30vw 0;
  text-align: center; }
  @media screen and (min-width: 750px) {
    .Contact {
      background: url(../images/headline_v_contact.svg) right 20px top 100px no-repeat;
      background-size: 33px;
      padding: 125px 0 230px;
      position: relative; } }
  .Contact__body {
    font-size: 4vw;
    letter-spacing: 0.1em;
    line-height: 2;
    margin: 0 auto 8.5vw;
    padding-bottom: 0.2em;
    width: 90vw; }
    @media screen and (min-width: 750px) {
      .Contact__body {
        font-size: 93.75%;
        letter-spacing: 0.16em;
        line-height: 2.4;
        margin: 0 0 45px 0.5em;
        padding-bottom: 0;
        width: auto; } }

/* buttons
================================================== */
.button--small {
  border: 1px solid #000;
  display: inline-block;
  font-size: 3.2vw;
  height: 5.33vw;
  letter-spacing: 0.18em;
  padding-top: 1.87vw;
  text-align: center;
  width: 50vw; }
  .button--small:hover {
    border-color: #999;
    color: #999; }
  @media screen and (min-width: 750px) {
    .button--small {
      font-size: 87.5%;
      height: 21px;
      padding-top: 7px;
      width: 180px; } }

.button--large {
  background: #000;
  color: #fff;
  display: inline-block;
  font-size: 4.7vw;
  height: 9.4vw;
  letter-spacing: 0.26em;
  padding-top: 4.7vw;
  width: 81.5vw; }
  .button--large:hover {
    background-color: #999; }
  @media screen and (min-width: 750px) {
    .button--large {
      font-size: 137.5%;
      height: 40px;
      letter-spacing: 0.32em;
      padding-top: 20px;
      width: 500px; } }
