@charset "UTF-8";
@font-face {
  font-family: 'LogoTypeGothic';
  src: url("https://plus1-haken.jp/lib/font/07LogoTypeGothic7.otf") format("opentype"), url("https://plus1-haken.jp/lib/font/07LogoTypeGothic7.ttf") format("truetype");
  font-weight: bold; }
html {
  font-size: 62.5%; }

body {
  min-width: 920px;
  font-size: 16px;
  font-size: 1.6rem;
  font-family: "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  line-height: 1.4;
  color: #535353;
  -webkit-text-size-adjust: 100%;
  counter-reset: count-number;
  -webkit-font-smoothing: antialiased; }

a {
  color: #4d4c4e;
  text-decoration: none; }

.hover:hover,
a:hover {
  text-decoration: underline;
  opacity: 0.8;
  filter: alpha(opacity=80);
  -ms-filter: "alpha( opacity=80 )"; }

img {
  vertical-align: top;
  max-width: 100%;
  height: auto; }

.campaign img {
  width: 100%; }

strong {
  font-weight: bold; }

.inner {
  max-width: 900px;
  margin: 0 auto; }

.inner.top {
  max-width: 980px !important;
  margin: 0 auto; }

@media (min-width: 641px) {
  #footer .inner.top,
  #page_top .sec_area .inner {
    width: 980px; } }
.hide_pc {
  display: none; }

.pc_only {
  display: block; }

.sp_only {
  display: none; }

@media (max-width: 640px) {
  * {
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }

  body {
    min-width: 0;
    padding: 55px 0 15.8%;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.5em; }

  a:hover {
    text-decoration: underline; }

  .ovr:hover {
    opacity: 1;
    filter: alpha(opacity=100);
    -ms-filter: "alpha( opacity=100 )"; }

  .inner, .inner.top {
    margin: 0 auto;
    width: 100%; }

  .inner.padding {
    padding: 0 3.125%; }

  .hide_sp {
    display: none; }

  .hide_pc {
    display: block; }

  .hide_pc.ib {
    display: inine-block; }

  .pc_only {
    display: none !important; }

  .sp_only {
    display: block; } }
/*-----------------------------------------
HEADER
*/
#header {
  position: fixed;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  background-color: #fff;
  z-index: 500;
  height: 80px;
  width: 100%; }
  #header .flex {
    overflow: hidden; }
  #header .logo {
    width: 40%;
    float: left;
    padding: 16px 0 14px;
    line-height: 1.2em; }
    #header .logo img {
      height: 50px;
      width: auto;
      float: left;
      margin-right: 15px; }
    #header .logo span {
      position: relative;
      color: #666666;
      position: relative;
      top: -5px;
      font-size: 13px;
      font-size: 1.3rem; }
    #header .logo a {
      display: block; }
      #header .logo a:hover {
        text-decoration: none;
        opacity: 0.7; }
  #header .btns {
    float: right;
    width: 41.5%; }
    #header .btns ul.sp {
      display: none; }
    #header .btns ul {
      text-align: right; }
      #header .btns ul li {
        display: inline-block; }
        #header .btns ul li a {
          display: block; }
        #header .btns ul li img {
          max-width: 100%; }

#header_inner {
  position: relative;
  height: 80px; }

#menu_btn {
  cursor: pointer; }
  #menu_btn.opened {
    position: relative; }
    #menu_btn.opened:after {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      right: 0;
      top: -10px;
      bottom: 0;
      background: url(../img/head_menu_close.png) center center no-repeat #f485b3;
      -webkit-background-size: 100%;
      background-size: 100%; }

#gnavi {
  display: none;
  position: absolute;
  top: 100%;
  right: 0; }
  #gnavi ul {
    float: right;
    background: url(../img/bg_stripe-pink.png);
    -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    font-size: 16px;
    font-weight: bold;
    opacity: 0.95; }
  #gnavi li a {
    display: block;
    padding: 16px 20px 18px;
    color: #fff;
    position: relative;
    width: 280px;
    font-size: 16px;
    font-weight: 500; }
    #gnavi li a:before {
      content: "";
      display: block;
      width: 15px;
      height: 15px;
      border: 1px solid #FFF;
      position: absolute;
      right: 20px;
      top: 20px; }
    #gnavi li a:after {
      content: "";
      position: absolute;
      top: 24px;
      right: 26px;
      width: 7px;
      height: 7px;
      border-top: 1.5px solid #FFF;
      border-right: 1.5px solid #FFF;
      -webkit-transform: rotate(45deg);
      transform: rotate(45deg); }
  #gnavi li + li {
    border-top: 1px solid #fbccdf; }

@media screen and (min-width: 600px) and (max-height: 1000px) {
  #gnavi ul {
    background: url(../img/bg_stripe-pink.png); }
    #gnavi ul li a {
      font-size: 13px;
      padding: 14px 20px 16px; }
      #gnavi ul li a:before {
        content: "";
        display: block;
        width: 12px;
        height: 12px;
        border: 1px solid #FFF;
        position: absolute;
        right: 20px;
        top: 16px; }
      #gnavi ul li a:after {
        content: "";
        position: absolute;
        top: 19.5px;
        right: 25.5px;
        width: 5px;
        height: 5px;
        border-top: 1.5px solid #FFF;
        border-right: 1.5px solid #FFF;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
  #gnavi li + li {
    border-color: rgba(255, 255, 255, 0.5); } }
@media (max-width: 640px) {
  #header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 55px;
    box-shadow: 0px 0px 4px 0px rgba(163, 163, 163, 0.4);
    -webkit-box-shadow: 0px 0px 4px 0px rgba(163, 163, 163, 0.4); }
    #header .flex {
      height: 55px; }
    #header .logo {
      width: 42%;
      padding: 10px 0 9px 10px; }
      #header .logo img {
        height: 34px;
        margin-right: 5px; }
      #header .logo span {
        font-size: 10px;
        display: inline-block;
        letter-spacing: -0.03em;
        line-height: 1.3rem;
        top: -2px;
        transform: scale(0.9, 1);
        margin-left: -5px; }
      #header .logo a {
        display: block; }
        #header .logo a:hover {
          text-decoration: none;
          opacity: 0.7; }
    #header .btns {
      width: 58%; }
      #header .btns ul li {
        width: 50px; }

  #header_inner {
    padding: 0;
    height: 50px; }

  #menu_btn.opened {
    margin-bottom: 0; }

  #menu_btn.opened:after {
    top: 0; }

  #gnavi {
    width: 100%;
    overflow: scroll;
    top: 55px; }
    #gnavi ul {
      width: 100%;
      background: url(../img/bg_stripe-pink.png);
      -webkit-background-size: 4px;
      background-size: 4px;
      overflow: scroll; }
      #gnavi ul li a {
        font-size: 13px;
        text-align: center;
        width: auto;
        padding: 14px 20px 16px; }
        #gnavi ul li a:before {
          content: "";
          display: block;
          width: 12px;
          height: 12px;
          border: 1px solid #FFF;
          position: absolute;
          right: 20px;
          top: 16px; }
        #gnavi ul li a:after {
          content: "";
          position: absolute;
          top: 19.5px;
          right: 25.5px;
          width: 5px;
          height: 5px;
          border-top: 1.5px solid #FFF;
          border-right: 1.5px solid #FFF;
          -webkit-transform: rotate(45deg);
          transform: rotate(45deg); }
    #gnavi li + li {
      border-color: rgba(255, 255, 255, 0.5); } }
@media (max-width: 359px) {
  #header .logo {
    width: 130px;
    padding: 11px 0 9px 8px; }
    #header .logo img {
      height: 32px;
      margin-right: -9px; }
    #header .logo span {
      transform: scale(0.8, 1);
      transform-origin: top right; }
    #header .logo a {
      display: block; }
      #header .logo a:hover {
        text-decoration: none;
        opacity: 0.7; }
  #header .btns {
    width: 188px; }
    #header .btns ul li {
      width: 47px; }
      #header .btns ul li img {
        height: 55px;
        width: 100%; } }
/*-----------------------------------------
FOOTER
*/
#pagetop {
  position: fixed;
  right: 0;
  bottom: 18px;
  width: 90px;
  height: 90px;
  z-index: 400; }
  #pagetop a {
    display: block;
    width: 100%;
    height: 100%;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    background: url(../img/btn_pagetop.png) bottom right no-repeat;
    -webkit-background-size: contain;
    background-size: contain; }

#footer_area_01 {
  padding: 40px 0 45px;
  background-color: #f7f5f5;
  font-size: 14px;
  font-size: 1.4rem; }
  #footer_area_01 .sp_only {
    display: none; }
  #footer_area_01 nav {
    overflow: hidden; }
  #footer_area_01 ul {
    float: left;
    width: 50%;
    margin-bottom: 10px; }
    #footer_area_01 ul.clear {
      clear: left; }
    #footer_area_01 ul li {
      display: table;
      float: left;
      width: 50%;
      font-weight: bold; }
      #footer_area_01 ul li.special a span {
        line-height: 1.4; }
    #footer_area_01 ul li a {
      display: inline-block;
      vertical-align: middle;
      color: #FFF;
      padding-left: 22px;
      position: relative;
      font-weight: bold; }
      #footer_area_01 ul li a:before {
        content: "";
        display: block;
        width: 15px;
        height: 15px;
        border: 1px solid #FFF;
        position: absolute;
        left: 0; }
      #footer_area_01 ul li a:after {
        content: "";
        position: absolute;
        top: 4px;
        left: 2px;
        width: 7px;
        height: 7px;
        border-top: 1.5px solid #FFF;
        border-right: 1.5px solid #FFF;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }

#footer_area_02 {
  background-color: #535353;
  color: #fff;
  padding: 20px 0 22px;
  font-size: 16px;
  font-size: 1.6rem; }
  #footer_area_02 ul {
    text-align: center; }
    #footer_area_02 ul li {
      display: inline-block;
      margin: 5px 10px; }
  #footer_area_02 a {
    color: #fff;
    font-weight: 500; }
  #footer_area_02 .copyright {
    font-family: Arial, Helvetica, sans-serif;
    margin-top: 10px;
    text-align: center;
    color: #b6b6b6;
    font-size: 12px; }

#bottom_button {
  display: none; }

@media (max-width: 640px) {
  #pagetop {
    width: 60px;
    height: 60px;
    bottom: 10px;
    margin-bottom: 17.8%; }

  #footer_area_01 {
    font-size: 14px;
    padding: 0; }
    #footer_area_01 .sp_only {
      display: block; }
    #footer_area_01 ul {
      margin: 0;
      display: table;
      width: 100%;
      border-bottom: 1px solid rgba(225, 225, 225, 0.5); }
      #footer_area_01 ul:last-child {
        border-bottom: none; }
      #footer_area_01 ul.clear {
        clear: none; }
      #footer_area_01 ul li {
        display: table-cell;
        border-right: 1px solid transparent;
        height: 4em;
        line-height: 1.2em;
        font-weight: normal;
        vertical-align: middle; }
        #footer_area_01 ul li:first-child {
          border-right: 1px solid rgba(225, 225, 225, 0.5); }
        #footer_area_01 ul li.special {
          white-space: nowrap; }
          #footer_area_01 ul li.special a span {
            font-size: 10px;
            height: 18px; }
        #footer_area_01 ul li a {
          font-size: 15px;
          display: block;
          vertical-align: middle;
          width: 100%;
          height: 100%;
          padding: 6px 25px 0 0.5em; }
          #footer_area_01 ul li a span {
            display: table-cell;
            vertical-align: middle;
            height: 3em; }
          #footer_area_01 ul li a:before {
            content: "";
            width: 12px;
            height: 12px;
            left: auto;
            right: 5%;
            top: 34%; }
          #footer_area_01 ul li a:after {
            content: "";
            top: 40%;
            left: auto;
            right: 8%;
            width: 5px;
            height: 5px; }
        #footer_area_01 ul li .footer--btn {
          padding-top: 10px; }

  #footer_area_02 {
    padding: 3% 0 4%;
    font-size: 11px; }
    #footer_area_02 ul li {
      margin: 5px; }
    #footer_area_02 .copyright {
      margin-top: 8px;
      font-size: 10px; }

  #bottom_button {
    padding: 1%;
    display: block;
    position: fixed;
    bottom: 0;
    background-color: #fff;
    background-color: rgba(255, 255, 255, 0.85);
    box-shadow: 0px 0px 4px 0px rgba(163, 163, 163, 0.4);
    z-index: 100;
    transition: transform 0.3s linear;
    transform: translateY(100%); }
    #bottom_button.show {
      transform: translateY(0); }
    #bottom_button ul {
      overflow: hidden; }
    #bottom_button li {
      float: left;
      width: 32.66%; }
      #bottom_button li + li {
        margin-left: 1%; } }
@media screen and (max-width: 360px) {
  #footer_area_01 ul li.special a span {
    line-height: 1.2; } }
/*-----------------------------------------
CONTENTS
*/
.bg_fix {
  background: url(../img/plusone_top_pc_bg.jpg) no-repeat;
  background-position: center top;
  background-size: cover;
  position: fixed;
  top: 0;
  z-index: -1;
  width: 100%;
  height: 100%; }

#contents {
  position: relative;
  z-index: 99;
  padding-top: 80px; }

#bottom_link_area {
  padding: 0;
  background-color: #fff;
  text-align: center;
  display: table;
  width: 100%; }
  #bottom_link_area.deco_01 {
    background: url(../img/bg_deco_01_b.png) center 5px no-repeat #fef3f7; }
  #bottom_link_area.home {
    background: #fef3f7; }
    #bottom_link_area.home ul {
      display: block !important;
      height: auto;
      width: 980px;
      margin: 0 auto;
      padding: 40px 0;
      text-align: left; }
      #bottom_link_area.home ul li {
        font-size: 16px;
        font-weight: normal; }
  #bottom_link_area > ul {
    display: table-cell;
    width: 100%;
    height: 280px;
    vertical-align: middle; }
    #bottom_link_area > ul li + li {
      margin-top: 20px; }
  #bottom_link_area nav#l-breadcrumbs ul {
    max-width: 900px;
    margin: 0 auto;
    text-align: left; }
  #bottom_link_area nav#l-breadcrumbs li.category-list__item {
    display: inline-block; }
    #bottom_link_area nav#l-breadcrumbs li.category-list__item:not(:last-child) {
      margin-right: 22px;
      position: relative; }
      #bottom_link_area nav#l-breadcrumbs li.category-list__item:not(:last-child):after {
        content: "";
        position: absolute;
        top: 6.5px;
        right: -15px;
        border-top: 1px solid #535353;
        border-right: 1px solid #535353;
        width: 8px;
        height: 8px;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        transition: all 0.3s; }
    #bottom_link_area nav#l-breadcrumbs li.category-list__item a {
      color: #f485b2;
      padding: 0;
      border-bottom: 1px solid #f485b2;
      display: inline-block; }
      #bottom_link_area nav#l-breadcrumbs li.category-list__item a:hover {
        text-decoration: none; }

/* .page_title_01 */
.page_title_01 {
  position: relative;
  background-color: #8b8b8b;
  color: #fff;
  font-family: "LogoTypeGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  font-size: 24px;
  font-size: 2.4rem; }
  .page_title_01:before {
    content: "";
    z-index: 0;
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    background-image: url(../img/bg_pattern_01_black.png);
    opacity: 0.1; }
    .ie8 .page_title_01:before {
      display: none; }
  .page_title_01 > * {
    position: relative; }
  .page_title_01 .title_inner {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto; }
  .page_title_01 h1,
  .page_title_01 h2 {
    position: relative;
    padding: 20px 10% 20px 0; }
    .page_title_01 h1:before,
    .page_title_01 h2:before {
      content: "";
      display: block;
      position: absolute;
      right: 20px;
      top: 0;
      width: 44px;
      height: 47px; }

/* .sub_title_01 */
.sub_title_01 {
  text-align: center;
  font-family: "LogoTypeGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  font-size: 22px;
  font-size: 2.2rem;
  font-weight: bold;
  color: #f485b2; }

.head_image_01 + .sub_title_01 {
  margin-top: 20px; }

/* .lead_text_01 */
.lead_text_01 {
  margin: 20px 0; }

/* .lead_text_02 */
.lead_text_02 {
  font-family: "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  font-size: 18px;
  font-size: 1.8rem;
  text-align: center; }
  .lead_text_02 strong {
    color: #f485b2;
    font-weight: normal; }

.head_image_01 + .lead_text_02 {
  margin-top: 10px; }

/* .head_image_01 */
.head_image_01 {
  text-align: center; }

/* .button_01 */
.button_01 {
  position: relative;
  margin: auto;
  width: 400px;
  background-color: #f485b2;
  text-align: center;
  font-size: 20px;
  font-size: 2rem;
  font-family: "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif; }
  .button_01 .sp_only {
    display: none; }
  .button_01.gold {
    background-color: #d1b772;
    text-align: center; }
    .button_01.gold a {
      padding: 8px 0 6px;
      letter-spacing: 0.05em;
      font-size: 20px;
      font-weight: bold; }
      .button_01.gold a small {
        font-size: 12px;
        display: block;
        position: relative;
        letter-spacing: 0; }
      .button_01.gold a img {
        height: 38px;
        position: absolute;
        left: 65px;
        top: 10px; }
  .button_01:hover {
    text-decoration: none; }
  .button_01:before {
    content: "";
    z-index: 0;
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    background-image: url(../img/bg_pattern_01_white.png);
    opacity: 0.1;
    filter: alpha(opacity=10);
    -ms-filter: "alpha( opacity=10 )"; }
    .ie8 .button_01:before {
      display: none; }
  .button_01 + .button_01 {
    margin-top: 10px; }
  .button_01 > * {
    position: relative; }
  .button_01 > a:hover {
    opacity: 1;
    filter: alpha(opacity=100);
    -ms-filter: "alpha( opacity=100 )"; }
  .button_01 > a,
  .button_01 > span {
    display: block;
    padding: 15px;
    color: #fff;
    text-decoration: none;
    background-position: 96% center;
    background-repeat: no-repeat;
    -webkit-background-size: 35px;
    background-size: 35px; }
  .button_01.pointer > a,
  .button_01.pointer > span {
    background-image: url(../img/ico_pointer_01.png); }
  .button_01.pointer.list-btn > a,
  .button_01.pointer.list-btn > span {
    background-image: none; }
  .button_01.call > a,
  .button_01.call > span {
    background-image: url(../img/ico_call_01.png); }
  .button_01.mail > a,
  .button_01.mail > span {
    background-image: url(../img/ico_mail_01.png); }

/* .table_01 */
.table_01,
.table_01 tbody,
.table_01 tr,
.table_01 th,
.table_01 td {
  display: block; }

.table_01 {
  margin: auto; }
  .table_01 th {
    vertical-align: top;
    text-align: left;
    background-color: #e892ba;
    color: #fff;
    font-weight: bold;
    padding: 5px 1em; }
  .table_01 td {
    vertical-align: top;
    padding: 1em;
    margin-bottom: 10px; }

.bottom_banner_01 {
  margin: 50px 0 0;
  text-align: center; }
  .bottom_banner_01 .banner {
    max-width: 640px;
    margin: 0 auto; }
    .bottom_banner_01 .banner img {
      border: 1px solid #6f6f6f; }

.square_01 > li {
  text-indent: -1.5em;
  padding-left: 1.5em; }
  .square_01 > li:before {
    content: "■";
    margin-right: 0.5em; }

.triangle_01 > li {
  text-indent: -1.5em;
  padding-left: 1.5em; }
  .triangle_01 > li:before {
    content: "▼";
    margin-right: 0.5em; }

@media (max-width: 640px) {
  .bg_fix {
    background: url(../img/plusone_top_sp_bg.jpg) no-repeat;
    background-size: 100% auto; }

  #contents {
    padding-top: 0; }

  #bottom_link_area {
    padding: 9.375% 10px; }
    #bottom_link_area.deco_01 {
      -webkit-background-size: 80%;
      background-size: 80%; }
    #bottom_link_area.home {
      padding: 0; }
      #bottom_link_area.home ul {
        padding: 25px 0 30px;
        margin: 0 6%;
        width: 88%; }
        #bottom_link_area.home ul li {
          font-size: 15px; }
    #bottom_link_area > ul {
      height: auto; }
      #bottom_link_area > ul li + li {
        margin-top: 5px; }
    #bottom_link_area .button_01 + li {
      margin-top: 4%; }
    #bottom_link_area nav#l-breadcrumbs ul {
      max-width: none;
      margin-top: 10px; }
    #bottom_link_area nav#l-breadcrumbs li.category-list__item:not(:last-child) {
      margin-right: 15px;
      position: relative; }
      #bottom_link_area nav#l-breadcrumbs li.category-list__item:not(:last-child):after {
        right: -10px;
        width: 6px;
        height: 6px; }

  /* .page_title_01 */
  .page_title_01 {
    font-size: 18px;
    font-size: 1.8rem; }
    .page_title_01:before {
      -webkit-background-size: 50% auto;
      background-size: 50% auto; }
    .page_title_01 h1,
    .page_title_01 h2 {
      padding: 12px 40px 12px 10px; }
      .page_title_01 h1:before,
      .page_title_01 h2:before {
        right: 10px;
        -webkit-background-size: 90%;
        background-size: 90%; }

  /* .sub_title_01 */
  .sub_title_01 {
    font-size: 17px;
    font-size: 1.7rem; }

  /* .lead_text_01 */
  .lead_text_01 {
    margin: 20px 0;
    padding: 0 10px;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.7em;
    text-align: justify; }

  /* .lead_text_02 */
  .lead_text_02 {
    font-size: 16px;
    font-size: 1.6rem; }

  /* .button_01 */
  .button_01 {
    width: 100%;
    font-size: 16px;
    font-size: 1.6rem; }
    .button_01 .sp_only {
      display: block; }
    .button_01:before {
      -webkit-background-size: 50% auto;
      background-size: 50% auto; }
    .button_01.gold a {
      padding: 3px 0 5px;
      font-size: 18px;
      font-weight: bold; }
      .button_01.gold a small {
        font-size: 11px;
        font-weight: normal; }
      .button_01.gold a img {
        height: 34px;
        left: 7%;
        top: 10px; }
    .button_01 > a,
    .button_01 > span {
      padding: 10px;
      padding-left: 0;
      background-position: 97% center;
      -webkit-background-size: 25px;
      background-size: 25px; }

  .bottom_banner_01 {
    margin-top: 7.8125%; } }
/*-----------------------------------------
PATTERN

.bg_patternをベースに、パターンと透明度を指定するクラスを合わせて使う。
このクラスを付けると、自身とその直下の要素にposition:relative;などが付く。
これによって問題が生じる要素にはこのクラスを使わず別の方法をとること。
*/
.bg_pattern {
  position: relative; }
  .bg_pattern:before {
    content: "";
    background-position: center center;
    z-index: 0;
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0; }
    .ie8 .bg_pattern:before {
      display: none; }
  .bg_pattern > * {
    position: relative;
    z-index: 1; }

.bg_black_01:before {
  background-image: url(../img/bg_pattern_01_black.png); }

.bg_white_01:before {
  background-image: url(../img/bg_pattern_01_white.png); }

.bg_stripe-pink:before {
  background-image: url(../img/bg_stripe-pink.png); }

.bg_alpha_5:before {
  opacity: 0.05;
  filter: alpha(opacity=5);
  -ms-filter: "alpha( opacity=5 )"; }

.bg_alpha_10:before {
  opacity: 0.1;
  filter: alpha(opacity=10);
  -ms-filter: "alpha( opacity=10 )"; }

.bg_alpha_15:before {
  opacity: 0.15;
  filter: alpha(opacity=15);
  -ms-filter: "alpha( opacity=15 )"; }

.bg_alpha_20:before {
  opacity: 0.2;
  filter: alpha(opacity=20);
  -ms-filter: "alpha( opacity=20 )"; }

.bg_alpha_25:before {
  opacity: 0.25;
  filter: alpha(opacity=25);
  -ms-filter: "alpha( opacity=25 )"; }

.bg_alpha_30:before {
  opacity: 0.3;
  filter: alpha(opacity=30);
  -ms-filter: "alpha( opacity=30 )"; }

.bg_alpha_35:before {
  opacity: 0.35;
  filter: alpha(opacity=35);
  -ms-filter: "alpha( opacity=35 )"; }

.bg_alpha_50:before {
  opacity: 0.5;
  filter: alpha(opacity=50); }

@media (max-width: 640px) {
  .bg_pattern:before {
    -webkit-background-size: 50% auto;
    background-size: 50% auto; }

  .bg_stripe-pink:before {
    -webkit-background-size: 1.5% auto;
    background-size: 1.5% auto; } }
.img_woman {
  float: left;
  margin: 0 15px 0 0;
  width: 400px; }

@media (max-width: 640px) {
  .img_woman {
    margin: 0 0 20px 0;
    width: 100%;
    float: none; } }
