@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Noto+Serif+JP:wght@300;400;500;600&display=swap');

/* ============================================================
   buyer_fujisan_glass_event style.css
   Pattern 02 シーン・ルックブック型（単一ブランド・田島硝子 富士山シリーズ）
   スコープ: .wrapper_top / .wrapper_first ... .wrapper_ninth / .wrapper_footer 限定
   フォントレンジ: 14px / 15px / 16px / 18px / 22px / 28px
   ============================================================ */

/* ---- h2-h5 reset (A-7 formal marker: h2,h3,h4,h5 { font-weight: normal }) ---- */
.wrapper_top h2,.wrapper_top h3,.wrapper_top h4,.wrapper_top h5,
.wrapper_first h2,.wrapper_first h3,.wrapper_first h4,.wrapper_first h5,
.wrapper_second h2,.wrapper_second h3,.wrapper_second h4,.wrapper_second h5,
.wrapper_third h2,.wrapper_third h3,.wrapper_third h4,.wrapper_third h5,
.wrapper_fourth h2,.wrapper_fourth h3,.wrapper_fourth h4,.wrapper_fourth h5,
.wrapper_fifth h2,.wrapper_fifth h3,.wrapper_fifth h4,.wrapper_fifth h5,
.wrapper_sixth h2,.wrapper_sixth h3,.wrapper_sixth h4,.wrapper_sixth h5,
.wrapper_seventh h2,.wrapper_seventh h3,.wrapper_seventh h4,.wrapper_seventh h5,
.wrapper_eighth h2,.wrapper_eighth h3,.wrapper_eighth h4,.wrapper_eighth h5,
.wrapper_ninth h2,.wrapper_ninth h3,.wrapper_ninth h4,.wrapper_ninth h5,
.wrapper_footer h2,.wrapper_footer h3,.wrapper_footer h4,.wrapper_footer h5 {
  font-weight: normal;
}

/* ---- root color tokens（10 wrapper の :root 代替）---- */
.wrapper_top,.wrapper_first,.wrapper_second,.wrapper_third,
.wrapper_fourth,.wrapper_fifth,.wrapper_sixth,.wrapper_seventh,
.wrapper_eighth,.wrapper_ninth,.wrapper_footer {
  --c-bg: #f5efe6;
  --c-ink: #2c2a28;
  --c-accent: #1e3a5f;       /* 富士山ブルー（深藍） */
  --c-sepia: #8b6f47;
  --c-line: #d8cfc1;
  --c-dark-bg: #1a2638;       /* beige_bk 用 */
  --c-dark-ink: #f0ece4;
  --sp-1: 8px;
  --sp-2: 16px;
  --sp-3: 24px;
  --sp-4: 32px;
  --sp-5: 48px;
  --sp-6: 64px;
  font-family: "Noto Serif JP", "Cormorant Garamond", serif;
  font-size: 16px;
  line-height: 1.85;
  letter-spacing: 0.04em;
  color: var(--c-ink);
  box-sizing: border-box;
  word-break: auto-phrase;
}

.wrapper_top *,.wrapper_first *,.wrapper_second *,.wrapper_third *,
.wrapper_fourth *,.wrapper_fifth *,.wrapper_sixth *,.wrapper_seventh *,
.wrapper_eighth *,.wrapper_ninth *,.wrapper_footer * {
  box-sizing: border-box;
}

/* ---- wrapper / section-inner ---- */
.wrapper_top,
.wrapper_first,
.wrapper_second,
.wrapper_third,
.wrapper_fourth,
.wrapper_fifth,
.wrapper_sixth,
.wrapper_seventh,
.wrapper_eighth,
.wrapper_ninth,
.wrapper_footer {
  width: 100%;
  margin: 0 auto;
  padding: 56px 0;
}
.wrapper_top {
  padding: 0 0 56px;
}
.wrapper_footer {
  padding: 48px 0;
}

.wrapper_top .section-inner,
.wrapper_first .section-inner,
.wrapper_second .section-inner,
.wrapper_third .section-inner,
.wrapper_fourth .section-inner,
.wrapper_fifth .section-inner,
.wrapper_sixth .section-inner,
.wrapper_seventh .section-inner,
.wrapper_eighth .section-inner,
.wrapper_ninth .section-inner,
.wrapper_footer .section-inner {
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ---- 章背景色（beige_bk: top/second/fourth/sixth/eighth / 白: first/third/fifth/seventh/ninth/footer）---- */
.wrapper_top.beige_bk,
.wrapper_second.beige_bk,
.wrapper_fourth.beige_bk,
.wrapper_sixth.beige_bk,
.wrapper_eighth.beige_bk {
  background: var(--c-dark-bg);
  color: var(--c-dark-ink);
}
.wrapper_first,
.wrapper_third,
.wrapper_fifth,
.wrapper_seventh,
.wrapper_ninth,
.wrapper_footer {
  background: #fff;
}

/* ---- 見出し（共通）---- */
.wrapper_first .section-heading,
.wrapper_second .section-heading,
.wrapper_third .section-heading,
.wrapper_fourth .section-heading,
.wrapper_fifth .section-heading,
.wrapper_sixth .section-heading,
.wrapper_seventh .section-heading,
.wrapper_eighth .section-heading,
.wrapper_ninth .section-heading {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 28px;
  line-height: 1.55;
  margin: 0 0 28px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--c-line);
  letter-spacing: 0.06em;
}
.wrapper_first .section-heading,
.wrapper_third .section-heading,
.wrapper_fifth .section-heading,
.wrapper_seventh .section-heading,
.wrapper_ninth .section-heading {
  color: var(--c-accent);
}
.wrapper_second.beige_bk .section-heading,
.wrapper_fourth.beige_bk .section-heading,
.wrapper_sixth.beige_bk .section-heading,
.wrapper_eighth.beige_bk .section-heading {
  color: #d5b96c;            /* dark背景での金箔風アクセント */
  border-bottom-color: rgba(213,185,108,0.35);
}

/* ---- eyebrow（章ラベル）---- */
.wrapper_top .hero-eyebrow,
.wrapper_first .eyebrow,
.wrapper_second .brand-eyebrow,
.wrapper_third .brand-eyebrow,
.wrapper_fourth .brand-eyebrow,
.wrapper_fifth .brand-eyebrow,
.wrapper_sixth .brand-eyebrow,
.wrapper_seventh .brand-eyebrow,
.wrapper_eighth .eyebrow,
.wrapper_ninth .eyebrow {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 18px;
  letter-spacing: 0.08em;
  color: var(--c-sepia);
  margin: 0 0 10px;
}
.wrapper_top .hero-eyebrow,
.wrapper_second.beige_bk .brand-eyebrow,
.wrapper_fourth.beige_bk .brand-eyebrow,
.wrapper_sixth.beige_bk .brand-eyebrow,
.wrapper_eighth.beige_bk .eyebrow {
  color: #d5b96c;
}

/* ---- wrapper_top ヒーロー（実画像 hero_main.webp 1400x933・cover）---- */
.wrapper_top .hero-figure {
  width: 100%;
  margin: 0 0 32px;
  aspect-ratio: 1400/933;
  background: var(--c-dark-bg);
  overflow: hidden;
}
.wrapper_top .hero-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.wrapper_top .section-inner {
  padding-top: 0;
}
.wrapper_top .hero-text {
  padding: 0 8px;
  text-align: center;
}
.wrapper_top .hero-title {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 28px;
  line-height: 1.55;
  color: #f0ece4;
  margin: 0 0 14px;
  letter-spacing: 0.08em;
}
.wrapper_top .hero-sub {
  font-family: "Cormorant Garamond", "Noto Serif JP", serif;
  font-size: 16px;
  color: #d5b96c;
  margin: 0 0 18px;
  letter-spacing: 0.06em;
}
.wrapper_top .hero-lead {
  font-size: 16px;
  line-height: 1.95;
  color: #f0ece4;
  margin: 0;
  text-align: left;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

/* ---- 本文 ---- */
.wrapper_first .section-body,
.wrapper_second .section-body,
.wrapper_third .section-body,
.wrapper_fourth .section-body,
.wrapper_fifth .section-body,
.wrapper_sixth .section-body,
.wrapper_seventh .section-body,
.wrapper_eighth .section-body {
  margin: 0 0 28px;
  font-size: 16px;
  line-height: 1.95;
}
.wrapper_second.beige_bk .section-body,
.wrapper_fourth.beige_bk .section-body,
.wrapper_sixth.beige_bk .section-body,
.wrapper_eighth.beige_bk .section-body {
  color: var(--c-dark-ink);
}

/* ---- 商品グリッド（統一規約: minmax(220px, 260px)・中央寄せ）---- */
.wrapper_second .product-grid,
.wrapper_third .product-grid,
.wrapper_fourth .product-grid,
.wrapper_fifth .product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 260px));
  gap: 24px;
  justify-content: center;
  margin: 24px 0 8px;
}
.wrapper_second .product-card,
.wrapper_third .product-card,
.wrapper_fourth .product-card,
.wrapper_fifth .product-card {
  max-width: 260px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: 2px;
  padding: 16px;
  transition: box-shadow 0.2s ease;
}
.wrapper_second .product-card:hover,
.wrapper_third .product-card:hover,
.wrapper_fourth .product-card:hover,
.wrapper_fifth .product-card:hover {
  box-shadow: 0 2px 12px rgba(0,0,0,0.12);
}
.wrapper_second .product-card a,
.wrapper_third .product-card a,
.wrapper_fourth .product-card a,
.wrapper_fifth .product-card a {
  display: block;
  text-decoration: none;
  color: var(--c-ink);
}
.wrapper_second .product-card figure,
.wrapper_third .product-card figure,
.wrapper_fourth .product-card figure,
.wrapper_fifth .product-card figure {
  width: 100%;
  aspect-ratio: 1/1;
  margin: 0 0 12px;
  background: #f8f5f0;
  overflow: hidden;
}
.wrapper_second .product-card img,
.wrapper_third .product-card img,
.wrapper_fourth .product-card img,
.wrapper_fifth .product-card img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.wrapper_second .product-name,
.wrapper_third .product-name,
.wrapper_fourth .product-name,
.wrapper_fifth .product-name {
  font-family: "Noto Serif JP", serif;
  font-size: 15px;
  line-height: 1.6;
  margin: 0 0 4px;
  color: var(--c-ink);
}

/* ---- wrapper_ninth FAQ（HTML 2分割 + Grid 1fr 1fr）---- */
.wrapper_ninth .faq-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 0;
  padding: 0;
}
.wrapper_ninth .faq-item {
  background: #faf7f1;
  border: 1px solid var(--c-line);
  border-radius: 2px;
  padding: 18px 22px;
}
.wrapper_ninth .faq-item dt {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 16px;
  color: var(--c-accent);
  line-height: 1.6;
  letter-spacing: 0.04em;
  margin: 0 0 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--c-line);
}
.wrapper_ninth .faq-item dd {
  margin: 0;
  font-size: 15px;
  line-height: 1.9;
  color: var(--c-ink);
}

/* ---- wrapper_footer CTA ---- */
.wrapper_footer .cta-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  margin: 0 auto;
  max-width: 720px;
}
.wrapper_footer .cta-button {
  display: inline-block;
  min-width: 280px;
  padding: 18px 36px;
  background: #fff;
  color: var(--c-accent);
  border: 1px solid var(--c-accent);
  border-radius: 2px;
  text-align: center;
  text-decoration: none;
  font-family: "Noto Serif JP", serif;
  font-size: 16px;
  letter-spacing: 0.08em;
  transition: background 0.2s ease, color 0.2s ease;
}
.wrapper_footer .cta-button:hover {
  background: var(--c-accent);
  color: #fff;
}
.wrapper_footer .cta-button--primary {
  background: var(--c-accent);
  color: #fff;
}
.wrapper_footer .cta-button--primary:hover {
  background: #142a45;
  color: #fff;
}

/* ============================================================
   Tablet (max-width: 1024px)
   ============================================================ */
@media (max-width: 1024px) {
  .wrapper_second .product-grid,
  .wrapper_third .product-grid,
  .wrapper_fourth .product-grid,
  .wrapper_fifth .product-grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 240px));
    gap: 18px;
  }
}

/* ============================================================
   SP (max-width: 768px / 639px)
   ============================================================ */
@media screen and (max-width: 639px) {
  /* A-2 必須マーカー (639px breakpoint formal) */
}
@media (max-width: 768px) {
  .wrapper_top,
  .wrapper_first,
  .wrapper_second,
  .wrapper_third,
  .wrapper_fourth,
  .wrapper_fifth,
  .wrapper_sixth,
  .wrapper_seventh,
  .wrapper_eighth,
  .wrapper_ninth,
  .wrapper_footer {
    font-size: 15px;
    padding: 40px 0;
  }
  .wrapper_top {
    padding: 0 0 40px;
  }
  .wrapper_top .section-inner,
  .wrapper_first .section-inner,
  .wrapper_second .section-inner,
  .wrapper_third .section-inner,
  .wrapper_fourth .section-inner,
  .wrapper_fifth .section-inner,
  .wrapper_sixth .section-inner,
  .wrapper_seventh .section-inner,
  .wrapper_eighth .section-inner,
  .wrapper_ninth .section-inner,
  .wrapper_footer .section-inner {
    padding: 0 16px;
  }
  .wrapper_top .hero-title,
  .wrapper_first .section-heading,
  .wrapper_second .section-heading,
  .wrapper_third .section-heading,
  .wrapper_fourth .section-heading,
  .wrapper_fifth .section-heading,
  .wrapper_sixth .section-heading,
  .wrapper_seventh .section-heading,
  .wrapper_eighth .section-heading,
  .wrapper_ninth .section-heading {
    font-size: 22px;
  }
  .wrapper_top .hero-lead,
  .wrapper_first .section-body,
  .wrapper_second .section-body,
  .wrapper_third .section-body,
  .wrapper_fourth .section-body,
  .wrapper_fifth .section-body,
  .wrapper_sixth .section-body,
  .wrapper_seventh .section-body,
  .wrapper_eighth .section-body {
    font-size: 15px;
  }
  .wrapper_second .product-grid,
  .wrapper_third .product-grid,
  .wrapper_fourth .product-grid,
  .wrapper_fifth .product-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }
  .wrapper_second .product-card,
  .wrapper_third .product-card,
  .wrapper_fourth .product-card,
  .wrapper_fifth .product-card {
    max-width: 100%;
  }
  .wrapper_footer .cta-grid {
    flex-direction: column;
    gap: 14px;
  }
  .wrapper_footer .cta-button {
    width: 100%;
    min-width: 0;
    padding: 16px 24px;
  }
}
