@charset "UTF-8";
/* ============================================================
   cocole_open_event/style.css
   CocoLe by le-noble 梅田 4/25 オープン告知LP
   ベース: history_event_style.css → ニュース告知型に簡素化・拡張
   ============================================================ */

/* FS共通レイアウト 非表示制御（このLPのみ）
   出典: https://faq.future-shop.jp/hc/ja/articles/4419654066585
   グループURLコード: cocole_open_event（body class はアンダースコアで確定 / 2026-04-27 実機検証）
   - .fs-c-noResultMessage  : 「現在登録されている商品はありません」
   - .category-header__link : 「対象商品の一覧へ」（PC自動生成のアンカー）
------------------------------ */
.fs-body-category-cocole_open_event .fs-c-noResultMessage,
.fs-body-category-cocole_open_event .category-header__link {
  display: none !important;
}

/* base
------------------------------ */
* { box-sizing: border-box; }
a {
  opacity: 1 !important;
  -webkit-tap-highlight-color: rgba(86,86,86,0.5);
}
h2, h3, h4, h5 { font-weight: normal; }
ul, ol, li { list-style: none; }
dd {
  display: block;
  margin-inline-start: 0;
  unicode-bidi: normal;
}
figure {
  display: block;
  margin-block-start: 0;
  margin-block-end: 0;
  margin-inline-start: 0;
  margin-inline-end: 0;
}

/* font
------------------------------ */
@font-face {
  font-display: swap;
  font-family: "ShipporiMincho";
  src: url("https://lenoble.itembox.cloud/item/images/font/ShipporiMincho.eot?") format('eot'),
       url("https://lenoble.itembox.cloud/item/images/font/ShipporiMincho.woff") format('woff'),
       url("https://lenoble.itembox.cloud/item/images/font/ShipporiMincho.otf") format('opentype');
}

/* wrapper
------------------------------ */
.wrapper_top,
.wrapper_first,
.wrapper_second,
.wrapper_third,
.wrapper_fourth,
.wrapper_fifth,
.wrapper_sixth {
  overflow: hidden;
  width: 100%;
  margin: 0 auto;
  padding: 0 15%;
}
.wrapper_footer {
  overflow: hidden;
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

/* wrap
------------------------------ */
.wrap_top {
  width: 100%;
  margin: 0 auto;
  padding: 0 0 5%;
}
.wrap_first,
.wrap_second,
.wrap_third,
.wrap_fourth,
.wrap_fifth,
.wrap_sixth {
  width: 100%;
  margin: 0 auto;
  padding: 4% 0 8%;
}
.wrap_footer {
  width: 100%;
  margin: 0 auto;
  padding: 4% 0 6%;
}

/* section
------------------------------ */
.section_top,
.section_first,
.section_second,
.section_third,
.section_fourth,
.section_fifth,
.section_sixth,
.section_footer {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

/* figure
------------------------------ */
.figure_top,
.figure_logo,
.figure_04,
.figure_footer {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}
.figure_top img,
.figure_logo img,
.figure_04 img,
.figure_footer img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  display: block;
  margin: 0 auto;
}
img.eachPik,
img.top_img01,
img.logo_img {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

/* 2カラムレイアウト
------------------------------ */
.flexBox_01 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  flex-direction: row;
  column-gap: 4%;
  margin: 0;
  padding: 0;
  list-style: none;
}
.textBox_01,
.imgBox_02 {
  width: 48%;
  margin: 0;
  padding: 0;
}
.textBlock_01,
.imgBlock_01 {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

/* contents
   EC課ルール: スペース責任は手前要素 padding-bottom / 同タイトル群は最小gap / lead は自分の padding-top
------------------------------ */
.contents_top {
  width: 100%;
  margin: 0 auto;
  padding: 0 0 5%;
}
.contents_logo {
  width: 30%;
  margin: 0 auto;
  padding: 0 0 2%;
}
.contents_title {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}
.contents_lead {
  width: 100%;
  margin: 0 auto;
  padding: 4% 10% 2%;
}
.contents_heading {
  width: 100%;
  margin: 0 auto;
  padding: 5% 0 1%;
}
.contents_explain {
  width: 100%;
  margin: 0 auto;
  padding: 5% 0;
}
.contents_button {
  width: 100%;
  margin: 0;
  padding: 0 15%;
  box-sizing: border-box;
}

/* background-color
------------------------------ */
.beige_bk { background: rgba(240,238,228,.8); }

/* h2 heading
------------------------------ */
.heading {
  margin: 0;
  font-family: "ShipporiMincho";
  color: #111;
  font-size: calc(1.8rem * 1.5);
  text-align: center;
  line-height: normal;
}
.heading::before,
.heading::after {
  content: "〜";
  margin: 0 1rem;
  display: inline-block;
}

/* h3 heading_sub
------------------------------ */
.heading_sub {
  margin: 0 0 4% 0;
  font-family: "ShipporiMincho";
  color: #111;
  font-size: calc(1.4rem * 1.5);
  text-align: left;
  line-height: calc(2rem * 1.5);
  font-weight: normal;
  border-left: 4px solid #9f8a5a;
  padding-left: 3%;
}
* + .heading_sub { margin-top: 5%; }

/* p.catchcopy（ヒーロー大見出し）
------------------------------ */
p.catchcopy {
  margin: 0;
  font-family: "ShipporiMincho";
  color: #111;
  font-size: calc(1.8rem * 1.5);
  text-align: center;
  line-height: calc(3rem * 1.5);
  letter-spacing: .15rem;
  font-weight: normal;
}

/* p text
------------------------------ */
p.lead {
  margin: 0;
  font-family: Lato, "Noto Sans JP", sans-serif;
  color: #000;
  font-size: calc(1.2rem * 1.5);
  text-align: center;
  line-height: calc(2rem * 1.5);
  letter-spacing: .2rem;
}
p.text_01 {
  margin: 0;
  font-family: Lato, "Noto Sans JP", sans-serif;
  color: #000;
  font-size: calc(1.1rem * 1.5);
  text-align: left;
  line-height: 3rem;
  letter-spacing: .1rem;
}

/* shop_info（dl形式の店舗情報・問い合わせ）
------------------------------ */
.shop_info {
  width: 100%;
  margin: 3% auto;
  padding: 4% 5%;
  border-top: 1px solid #9f8a5a;
  border-bottom: 1px solid #9f8a5a;
  display: grid;
  grid-template-columns: 22% 1fr;
  row-gap: 2%;
  column-gap: 4%;
  align-items: start;
}
.shop_info dt {
  font-family: "ShipporiMincho";
  font-size: calc(1.1rem * 1.5);
  color: #9f8a5a;
  font-weight: normal;
  letter-spacing: .1rem;
  padding-top: .2em;
}
.shop_info dd {
  font-family: Lato, "Noto Sans JP", sans-serif;
  font-size: calc(1.1rem * 1.5);
  color: #000;
  line-height: calc(1.8rem * 1.5);
  letter-spacing: .05rem;
}

/* contents_press（プレスリリース案内ブロック・フッター上部）
------------------------------ */
.contents_press {
  width: 100%;
  margin: 0 auto 5%;
  padding: 0 15%;
}
.contents_press .text_01 {
  text-align: center;
}

/* 代表コメント
------------------------------ */
.ceo_quote {
  font-family: "ShipporiMincho";
  font-size: calc(1.2rem * 1.5);
  line-height: calc(2.2rem * 1.5);
  letter-spacing: .12rem;
}
.ceo_name {
  margin: 4% 0 0 0;
  font-family: Lato, "Noto Sans JP", sans-serif;
  font-size: calc(1.1rem * 1.5);
  color: #111;
  text-align: right;
  letter-spacing: .1rem;
}

/* footer button
------------------------------ */
.flexColumn_footer {
  margin: 0;
  display: flex;
  flex-direction: column;
}
.ColumnBox_footer__01,
.ColumnBox_footer__02 {
  width: 100%;
  margin: 0 auto;
  padding: 0 15%;
}
.contents_button > a {
  display: block;
  width: 100%;
  text-decoration: none;
  box-sizing: border-box;
}
.contents_button .seriesBtn {
  display: block;
  width: 100%;
  margin: 0;
  box-sizing: border-box;
}
.contents_button + .contents_button { margin-top: 2%; }
.ColumnBox_footer__01 + .ColumnBox_footer__02 { margin-top: 2%; }

p.seriesBtn {
  margin: 0 auto;
  display: block;
  padding: 2.5% 0;
  font-family: Lato, "Noto Sans JP", sans-serif;
  font-size: calc(1.1rem * 1.5);
  letter-spacing: .1rem;
  text-align: center;
  text-decoration: none;
  border: 1px solid #505050;
  color: #505050;
}
p.seriesBtn:hover {
  opacity: 1 !important;
  color: #fff !important;
  background: #505050;
}

/* utility
------------------------------ */
.br_pc { display: block !important; }
.br_sp { display: none !important; }
.pc_display { display: block !important; }
.sp_display { display: none !important; }


/* --------------------------------
 * Note PC (max-width: 1380px)
 * -------------------------------- */
@media screen and (max-width: 1380px) {
  .wrapper_top { padding: 0; }
  .wrapper_first,
  .wrapper_second,
  .wrapper_third,
  .wrapper_fourth,
  .wrapper_fifth,
  .wrapper_sixth { padding: 0 5%; }
}


/* --------------------------------
 * Tablet (max-width: 1100px)
 * -------------------------------- */
@media screen and (max-width: 1100px) {
  .wrapper_top,
  .wrapper_first,
  .wrapper_second,
  .wrapper_third,
  .wrapper_fourth,
  .wrapper_fifth,
  .wrapper_sixth { padding: 0; }
}


/* --------------------------------
 * SP (max-width: 639px)
 * -------------------------------- */
@media screen and (max-width: 639px) {
  /* EC課ルール: SP時 .heading_sub 前のスペース */
  * + .heading_sub { margin-top: 7%; }

  /* wrapper - SP時は左右5%余白 */
  .wrapper_top { padding: 0; }
  .wrapper_first,
  .wrapper_second,
  .wrapper_third,
  .wrapper_fourth,
  .wrapper_fifth,
  .wrapper_sixth { padding: 0 5%; }
  .wrapper_footer { width: 100%; margin: 0 auto 8%; padding: 0; }

  /* wrap - SP時の段落下部余白は 7%（EC課ルール） */
  .wrap_top { padding: 0 0 7%; }
  .wrap_first,
  .wrap_second,
  .wrap_third,
  .wrap_fourth,
  .wrap_fifth,
  .wrap_sixth { padding: 0 0 7%; }
  .wrap_footer { padding: 0 0 7%; }

  .ColumnBox_footer__01,
  .ColumnBox_footer__02 { padding: 0 5%; }

  /* 2カラム → 1カラム積み重ね */
  .flexBox_01 {
    flex-direction: column;
    column-gap: 0;
  }
  .textBox_01,
  .imgBox_02 {
    width: 100%;
    margin: 0 auto;
  }
  .imgBox_02 { margin: 5% 0; }

  /* textBlock_01 */
  .textBlock_01 { padding: 3% 0; }

  /* contents */
  .contents_top { padding: 0 0 5%; }
  .contents_logo { width: 60%; padding: 0 0 2%; }
  .contents_title { padding: 0; }
  .contents_lead { padding: 4% 7% 2%; }
  .contents_heading { padding: 8% 0 7%; }
  .contents_explain { padding: 5% 0; }
  .contents_button {
    width: 100%;
    margin: 0 auto;
    padding: 5% 2%;
  }

  /* h2 heading */
  .heading {
    font-size: calc(1.4rem * 1.5);
    line-height: calc(2rem * 1.5);
  }
  .heading::before { content: "〜"; margin: 0 .5rem 0 0; display: inline-block; }
  .heading::after  { content: "〜"; margin: 0 0 0 .5rem; display: inline-block; }

  /* h3 heading_sub */
  .heading_sub {
    font-size: calc(1.2rem * 1.5);
    line-height: calc(1.8rem * 1.5);
    padding-left: 4%;
  }

  /* catchcopy */
  p.catchcopy {
    font-size: calc(1.3rem * 1.5);
    line-height: calc(2.2rem * 1.5);
    letter-spacing: .08rem;
  }

  /* p text */
  p.lead {
    font-size: calc(1rem * 1.5);
    line-height: calc(1.6rem * 1.5);
    letter-spacing: .08rem;
  }
  p.text_01 {
    font-size: calc(1rem * 1.5);
    line-height: calc(1.5rem * 1.5);
    letter-spacing: .08rem;
  }

  /* shop_info - SPはdt/ddを縦積み */
  .shop_info {
    grid-template-columns: 1fr;
    row-gap: 1%;
    padding: 5% 4%;
  }
  .shop_info dt {
    font-size: calc(1.05rem * 1.5);
    padding-top: 3%;
  }
  .shop_info dt:first-child { padding-top: 0; }
  .shop_info dd {
    font-size: calc(1rem * 1.5);
    line-height: calc(1.6rem * 1.5);
    padding-left: 3%;
  }

  /* contents_press - SP */
  .contents_press {
    margin: 0 auto 6%;
    padding: 0 5%;
  }

  /* 代表コメント */
  .ceo_quote {
    font-size: calc(1.1rem * 1.5);
    line-height: calc(1.9rem * 1.5);
  }
  .ceo_name { font-size: calc(1rem * 1.5); }

  /* btn */
  p.seriesBtn {
    padding: 5% 0;
    font-size: calc(1.1rem * 1.5);
  }

  /* utility */
  .br_pc { display: none !important; }
  .br_sp { display: block !important; }
  .pc_display { display: none !important; }
  .sp_display { display: block !important; }

  /* 連続ボタン縦gap (二重防止) */
  .contents_button + .contents_button { margin-top: 0; }
  .ColumnBox_footer__01 + .ColumnBox_footer__02 { margin-top: 3%; }
}
