@charset "UTF-8";

/* ===========================
   Visibility helpers
   =========================== */
.pc-area { display: block; }
.sp-area { display: none; }

@media (max-width: 768px) {
  .pc-area { display: none; }
  .sp-area { display: block; }
}

/* ===========================
   Base typography
   =========================== */
body {
  font-family: 'Noto Serif JP', 'Yu Mincho', 'Hiragino Mincho ProN',
               'Hiragino Mincho', 'MS Mincho', serif;
  font-size: 14px;
  line-height: 2;
  color: #333;
}
p { margin: 0; }
a:hover {
  cursor: pointer;
  text-decoration: none;
}
h1, h2, h3, dt { font-weight: normal; }
h1, h2, h3 { letter-spacing: .02em;}
ul { padding: 0; }

.en-text, .en-text_b, .en-text_w, .notes { font-size: 13px; }
.en-text, .notes { color: #999; }
.en-text_b { color: #333; }
.en-text_w { color: #fff; }

.ttl-bdr { font-size: 24px; line-height: 1.6; }
.ttl-bdr_w { font-size: 24px; line-height: 1.6; color: #fff; }

.list-ttl { font-size: 18px; }

.img-center { text-align: center; }
.img50 { width: 50%; }
.img70 { width: 70%; }

.bmb1 { margin-top: 1em; }
.bmb2 { margin-top: 2em; }
.bmb3 { margin-top: 3em; }
.bmb4 { margin-top: 4em; }
.bmb5 { margin-top: 5em; }

.mb1 { margin-bottom: 1em; }
.mb2 { margin-bottom: 2em; }
.mb3 { margin-bottom: 3em; }
.mb4 { margin-bottom: 4em; }
.mb5 { margin-bottom: 5em; }

@media (max-width: 768px) {
  body { font-size: 0.72rem; line-height: 1.8; }
  .ttl-bdr, .ttl-bdr_w { margin-bottom: 1.5em; font-size: 1.2rem; }
  .en-text, .en-text_b, .en-text_w, .notes { font-size: 0.64rem; }
  .list-ttl { font-size: 0.96rem; }
}

/* ===========================
   Main content spacing
   =========================== */
main { padding-top: 8em; } /* ナビ分のスペース */
main h1 { text-align: center; }

@media (max-width: 768px) {
  main { padding-top: 4em; }
}

.sub-page { margin: 1em auto 0; max-width: 840px; }

@media (max-width: 768px) {
  .sub-page { max-width: 90%; margin-top: 4em }
}

.wrapper { margin-left: auto; margin-right: auto; margin-bottom: 6em; }

@media (max-width: 768px) {
  .wrapper { margin-bottom: 4em; }
}

/* ===========================
   Header / Navbar
   =========================== */
header.top-page {
  height: auto;
  overflow: visible;
  padding-right: 0;
  padding-left: 0;
}
.navbar {
  position: fixed;
  width: 100%;
  top: 0;
  padding: 0.5rem 1rem;
  line-height: 1;
  background-color: #000028;
  z-index: 10000;
}
a.nav-link {
  position: relative;
  color: #fff !important;
}
a.nav-link::after {
  position: absolute;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  bottom: 0;
  left: 0;
  transform: scale(0, 1);
  transform-origin: center top;
  transition: all .56s ease;
}
a.nav-link:hover::after { transform: scale(0.85, 1); }
.nav-link img { height: 16px; margin: -0.3em 4px 0 0; }
header .navbar-brand { width: 8.5%; margin-right: 2%; }
header .navbar-brand .logo { width: 100%; }
.fixed { position: fixed; width: 100%; top: 0; z-index: 1000; }

@media (max-width: 768px) {
  header.top-page { height: auto; }
  header .navbar-brand { width: 25%; }
  a.nav-link::after { display: none; }
  .navbar-toggler { border: none; }
}

/* ===========================
   Footer (Multi-Column + SNS)
   =========================== */
:root {
  --footer-bg: #e5e5e5; /* 背景色 */
  --footer-fg: #000028; /* 文字色 */
  --footer-muted: #999; /* サブテキスト */
  --footer-link: #000028; /* リンク色 */
  --footer-link-hover: #ccc; /* ホバー色 */
  --footer-border: rgba(0,0,0,.1);
}

.footer {
  background: var(--footer-bg);
  color: var(--footer-fg);
  font-size: 13px;
  line-height: 1.8;
}
.footer .container {
  padding-top: 3rem;
  padding-bottom: 2.25rem;
}
.footer .row { font-family: "Noto Sans JP", "Hiragino Sans", "Helvetica Neue", Arial, sans-serif; }
.footer .list-unstyled {
  margin: 0;
  padding: 0;
  list-style: none;
}
.footer .list-unstyled a {
  display: inline-block;
  padding: 0.2rem 0;
  color: var(--footer-link);
  text-decoration: none;
  transition: color 0.2s ease, text-decoration 0.2s ease;
}
.footer .list-unstyled a:hover,
.footer .list-unstyled a:focus {
  color: var(--footer-link-hover);
}
.footer .social.no-border a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  border: none;
  margin-left: 0.25rem;
  opacity: 0.9;
  background: none;
}
.footer .social.no-border a:hover { opacity: 1; }
.footer .social.no-border img { width: 24px; height: 24px; }
.footer .col-md-3.d-flex {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.footer .divider {
  border-top: 1px solid var(--footer-border);
  margin-top: 2rem;
  padding-top: 1.25rem;
}

@media (max-width: 768px) {
  .footer { font-size: 0.72rem; }
  .footer .container { padding-top: 2.25rem; padding-bottom: 1.75rem; }
  .footer .col-md-3.d-flex { align-items: flex-start !important; margin-top: 1rem; }
  .footer .list-unstyled a { padding: 0.15rem 0; }
}

/* ===========================
   2 Column DL (Border Line)
   =========================== */
.dl-border {
  display: grid;
  grid-template-columns: 1fr 3fr;
  border-top: 1px solid #e6e6e6;
}
.dl-border dt,
.dl-border dd {
  margin: 0;
  padding: 20px 15px;
  border-bottom: 1px solid #e6e6e6;
  display: flex;
  align-items: center;
  min-height: 64px;
}
.dl-border dt { letter-spacing: .02em; }
.dl-border dd { line-height: 1.8; }

@media (max-width: 768px) {
  .dl-border { grid-template-columns: 1fr; }
  .dl-border dt { border-bottom: none; padding-bottom: 0.2em; min-height: auto; }
  .dl-border dd { padding-top: 0; }
}

/* ===========================
   Parallax
   =========================== */
.parallax {
  background-attachment: fixed;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  height: auto;
}

@media (max-width: 768px) {
  .parallax {
    background-attachment: inherit;
    background-size: auto 100%;
    height: auto;
  }
}

/* ===========================
   FAQ（アコーディオン）
   =========================== */
.mc-qa { border-bottom: 1px solid #e5e5e5; } /* 下線 */
.mc-qa summary {
  display: flex;
  padding: 1.2rem .2rem;
  list-style: none;
  cursor: pointer;
  align-items: center;
}
.mc-qa summary::-webkit-details-marker { display: none; }
.mc-qa summary::before {
  content: "";
  width: 11px; height: 11px;
  margin-right: .6rem;
  border-right: 1px solid #888;
  border-bottom: 1px solid #888;
  transform: rotate(-45deg);
  transition: transform .22s ease;
  flex: 0 0 11px;
}
.mc-qa[open] summary::before { transform: rotate(45deg); }
.mc-qa .mc-answer {
  padding: 0 0 1rem 1.6rem;
  color: #333;
}

/* ===========================
   Slider / Hero
   =========================== */
.hero {
  position: relative;
  overflow: hidden;
  height: 95vh;
}
.slider {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: 100%;
  background-color: #000;
}
.slider .center_img {
  position: absolute;
  top: 50px;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 240px;
  height: 240px;
  z-index: 999;
}
.slider .image {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

.slider .image:nth-of-type(1) { background-image: url("../img/index/pc_slid_01.jpg"); }
.slider .image:nth-of-type(2) { background-image: url("../img/index/pc_slid_02.jpg"); }
.slider .image:nth-of-type(3) { background-image: url("../img/index/pc_slid_03.jpg"); }
.slider .image:nth-of-type(4) { background-image: url("../img/index/pc_slid_04.jpg"); }
.slider .image:nth-of-type(5) { background-image: url("../img/index/pc_slid_05.jpg"); }

@media (max-width: 768px) {
  .hero { height: 86vh; }
  .slider .image:nth-of-type(1) { background-image: url("../img/index/sp_slid_01.jpg"); }
  .slider .image:nth-of-type(2) { background-image: url("../img/index/sp_slid_02.jpg"); }
  .slider .image:nth-of-type(3) { background-image: url("../img/index/sp_slid_03.jpg"); }
  .slider .image:nth-of-type(4) { background-image: url("../img/index/sp_slid_04.jpg"); }
  .slider .image:nth-of-type(5) { background-image: url("../img/index/sp_slid_05.jpg"); }
  .slider .center_img { width: 25vh; height: 25vh; }
}

#asnakami1 { animation: fadeinout 25s 0s infinite; }
#asnakami2 { animation: fadeinout 25s 5s infinite; }
#asnakami3 { animation: fadeinout 25s 10s infinite; }
#asnakami4 { animation: fadeinout 25s 15s infinite; }
#asnakami5 { animation: fadeinout 25s 20s infinite; }

@keyframes fadeinout {
  0% { left:0%; opacity:0; }
  5% { left:0%; opacity:1; }
  20% { left:0%; opacity:1; }
  25% { left:0%; opacity:0; }
  26% { opacity:0; left:100%; }
  99.99% { opacity:0; left:100%; }
  100% { opacity:0; left:0%; }
}

/* ===========================
   Intro
   =========================== */
.intro { width: 720px; }
.intro p:first-of-type { text-align: center; line-height: 2.4; }

@media (max-width: 768px) {
  .intro { width: 84%; }
  .intro p:first-of-type { text-align: left; line-height: 2; }
}

/* ===========================
   Process (About section)
   =========================== */
.process-ttl {
  width: 1200px;
  height: 400px;
  margin: auto;
  padding-top: 10em;
  background-image: url("../img/index/about_ttl_bg01.jpg");
  background-size: cover;
}
.process-ttl p {
  padding-top: 1.5em;
  line-height: 1.6;
  color: #fff;
}
.process-list ul {
  max-width: 840px;
  margin: 8em auto 8em;
  padding: 0;
  list-style: none;
}
.process-item {
  display: flex;
  align-items: center;
  gap: 48px;
  margin-bottom: 5em;
}
.process-figure {
  flex: 0 0 400px;
  max-width: 400px;
}
.process-figure img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.process-text { flex: 1; }
.process-text p {
  margin: 0;
  line-height: 1.8;
}
/* 1番目だけ画像余白 */
.process-item:nth-child(1) .process-figure { padding: 0 67px; }
/* 偶数番目は左右反転（PC交互） */
.process-item:nth-child(even) { flex-direction: row-reverse; }

@media (max-width: 768px) {
  .process-ttl {
    display: table-cell;
    vertical-align: middle;
    width: 100%;
    height: 50vh;
    padding: 0 10%;
  }
  .process-ttl p { padding-top: 0; }
  .process-list ul { max-width: 100%; margin: 5em auto; padding: 0 12%; }
  .process-item { flex-direction: column !important; gap: 1.5em; margin-bottom: 3em; }
  .process-figure { flex: none; padding: 0; }
}

/* ===========================
   Made In Green
   =========================== */
.mig { background-image: url("../img/index/about_ttl_bg02_pc.jpg"); }
.mig-inner { width: 840px; margin: 0 auto; }
.mig-content {
  box-sizing: border-box;
  display: table-cell;
  vertical-align: middle;
  height: 80vh;
}
.mig-content p { margin: 0; padding-top: 1.5em; color: #000; }
.mig-content p a { color: #000; text-decoration: underline; }
.Oeko-Tex_link { display: grid; justify-content: right; margin-top: 1em; }
.Oeko-Tex_link a { width: 60px; }

@media (max-width: 768px) {
  .mig { background-image: url("../img/index/about_ttl_bg02_sp.jpg"); }
  .mig-inner { width: 100%; margin: 0; padding: 0 10%; }
  .mig-content { height: 70vh; }
  .mig-content p { padding-top: 0; }
  .Oeko-Tex_link a { width: 3.5rem; }
}

/* ===========================
   Collection
   =========================== */
.collection { width: 920px; }
.collection-list h3 { margin: 2em 0 1em; font-size: 21px; }
.collection-list li { margin-bottom: 5em; list-style: none; text-align: center; }
.online_link { display: grid; justify-content: right; text-decoration: underline; }
.online_link a { color: #333; }

@media (max-width: 768px) {
  .collection { width: 90%; }
  .collection-list h3 { font-size: 1rem; }
  .collection-list li { margin-bottom: 3em; }
}

/* ===========================
   Media page
   =========================== */
.cp_card {
  overflow: hidden;
  border-radius: 3px;
  margin: 2rem auto;
  position: relative;
  background-color: #fff;
  box-shadow: 0 3px 7px -3px rgba(0, 0, 0, 0.3);
  transition: all 0.25s ease-in;
  border-bottom: 5px solid transparent;
  height: 380px;
}
.cp_card .photo { height: 200px; overflow: hidden; }
.cp_card:hover {
  transform: translateY(-5px);
  border: none;
  border-bottom: 5px solid #9f9f98;
}
.cp_card .details { display: flex; padding: 1em 1em 0; font-size: 0.8em; }
.cp_card .date { flex: 1; text-align: right; }
.cp_card .description { padding: 1em; }
.cp_card .description h1 { font-size: 1.2em; margin: 0 0 0.5em; }
.cp_card .description .text p { margin: 0; font-size: 0.9em; }
.madia_img { width: 100%; }

/* ===========================
   Shoplist
   =========================== */

/* ===========================
   お手入れ方法
   =========================== */
.care-faq { font-family: "Noto Sans JP", "Hiragino Sans", "Helvetica Neue", Arial, sans-serif; }
#care h2 { padding-bottom: 0.5em; border-bottom: dotted 2px #3D6688; }
.care-hero { overflow: hidden; }
.care-hero img { display: block; width: 100%; height: auto; }
.care-step { margin-bottom: 3.5em; }
.care-step ul { list-style: none; font-family: "Noto Sans JP", "Hiragino Sans", "Helvetica Neue", Arial, sans-serif; }
/* ===========================
   Company
   =========================== */
#company dt { color: #666; }

/* ===========================
   Misc
   =========================== */
iframe { width: 100%; height: 450px; }
