/* ====================================
   リクエスト販売ページ専用スタイル
==================================== */
.sub-hero{
  position:relative;z-index:2;
  padding:200px 0 140px;
  min-height:560px;
  display:flex;align-items:center;
  background-color:var(--bg-deep);
  border-bottom:1px solid var(--line-soft);
  overflow:hidden;
}
.sub-hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    /* テキスト可読性確保のオーバーレイ */
    linear-gradient(180deg, rgba(10,8,7,.78) 0%, rgba(10,8,7,.6) 40%, rgba(10,8,7,.7) 100%),
    /* 金色の光芒で高級感を演出 */
    radial-gradient(ellipse at 50% 50%, rgba(201,164,92,.15), transparent 65%),
    /* 実画像（ロレックスデイトナ・ボックス入り） */
    url("../images/hero-request.jpg") center/cover no-repeat;
  background-color:var(--bg-deep);
}
.sub-hero-inner{position:relative;z-index:2;text-align:center;max-width:820px;margin:0 auto}
.sub-hero-eyebrow{
  font-family:var(--serif-en);
  font-size:13px;letter-spacing:.4em;
  color:var(--gold);
  margin-bottom:24px;
  text-transform:uppercase;
}
.sub-hero h1{
  font-family:var(--serif);
  font-size:clamp(36px, 5vw, 60px);
  font-weight:700;line-height:1.3;
  margin-bottom:28px;
  color:var(--ink);
}
.sub-hero h1 .accent{color:var(--gold-bright);font-style:italic}
.sub-hero-lead{
  font-size:16px;line-height:2;color:var(--ink-soft);
  max-width:680px;margin:0 auto;
}
.sub-hero-divider{
  width:60px;height:1px;background:var(--gold);
  margin:40px auto 0;
}

/* セクション共通の見出し */
.req-section{padding:120px 0;position:relative;z-index:2;background:var(--bg)}
.req-section.alt{background:var(--bg-elev)}
.req-section-head{text-align:center;margin-bottom:70px}
.req-section-eyebrow{
  font-family:var(--serif-en);
  font-size:12px;letter-spacing:.4em;
  color:var(--gold);margin-bottom:16px;text-transform:uppercase;
}
.req-section-title{
  font-family:var(--serif);
  font-size:clamp(28px, 4vw, 42px);
  font-weight:700;line-height:1.4;
  color:var(--ink);
}
.req-section-title .accent{color:var(--gold-bright);font-style:italic}
.req-section-lead{
  margin-top:24px;font-size:15px;line-height:2;
  color:var(--ink-soft);max-width:680px;margin-left:auto;margin-right:auto;
}

/* 概要セクション */
.req-about{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.req-about-text h2{
  font-family:var(--serif);
  font-size:32px;font-weight:700;line-height:1.5;
  margin-bottom:24px;color:var(--ink);
}
.req-about-text h2 .accent{color:var(--gold-bright)}
.req-about-text p{
  font-size:15px;line-height:2;color:var(--ink-soft);
  margin-bottom:20px;
}
.req-about-visual{
  position:relative;aspect-ratio:4/5;
  background:var(--bg-deep);
  border:1px solid var(--line);
  overflow:hidden;
}
.req-about-visual img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform 1.2s ease;
  display:block;
}
.req-about-visual:hover img{transform:scale(1.04)}
.req-about-visual::before{
  content:"";position:absolute;inset:20px;
  border:1px solid rgba(201,164,92,.4);
  pointer-events:none;z-index:2;
}
.req-about-visual::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(10,8,7,.5) 100%);
  pointer-events:none;z-index:1;
}
.req-about-visual-label{
  position:absolute;left:32px;bottom:32px;z-index:3;
  font-family:var(--serif-en);font-size:11px;
  letter-spacing:.4em;color:var(--gold-bright);
  text-transform:uppercase;
}
.req-about-visual-label::before{
  content:"";display:inline-block;
  width:24px;height:1px;background:var(--gold);
  vertical-align:middle;margin-right:12px;
}

/* 特徴グリッド */
.req-features{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
}
.req-feature-card{
  background:var(--bg);
  border:1px solid var(--line);
  padding:48px 32px;
  text-align:center;
  transition:all .4s;
  position:relative;
}
.req-feature-card:hover{
  border-color:var(--gold);
  transform:translateY(-4px);
  box-shadow:0 30px 60px -20px rgba(201,164,92,.15);
}
.req-feature-num{
  font-family:var(--serif-en);
  font-size:48px;font-weight:300;
  color:var(--gold-bright);line-height:1;
  margin-bottom:20px;letter-spacing:-.02em;
}
.req-feature-card h3{
  font-family:var(--serif);
  font-size:20px;font-weight:600;
  margin-bottom:16px;color:var(--ink);
  letter-spacing:.04em;
}
.req-feature-card p{
  font-size:14px;line-height:1.9;
  color:var(--ink-soft);
}

/* 流れセクション（ステップ） */
.req-steps{
  max-width:880px;margin:0 auto;
  display:flex;flex-direction:column;gap:0;
}
.req-step{
  display:grid;grid-template-columns:100px 1fr;
  gap:40px;padding:40px 0;
  border-bottom:1px solid var(--line-soft);
  align-items:start;
}
.req-step:last-child{border-bottom:none}
.req-step-num{
  font-family:var(--serif-en);
  font-size:54px;font-weight:300;
  color:var(--gold);line-height:1;
  letter-spacing:-.04em;
}
.req-step-body h3{
  font-family:var(--serif);
  font-size:22px;font-weight:600;
  margin-bottom:14px;color:var(--ink);
}
.req-step-body p{
  font-size:14px;line-height:2;
  color:var(--ink-soft);
}

/* 取扱範囲（シンプル表示） */
.req-scope{
  text-align:center;max-width:760px;margin:0 auto;
  padding:60px 40px;
  background:var(--bg);
  border:1px solid var(--line);
  position:relative;
}
.req-scope::before, .req-scope::after{
  content:"";position:absolute;
  width:40px;height:1px;background:var(--gold);
}
.req-scope::before{top:30px;left:30px}
.req-scope::after{bottom:30px;right:30px}
.req-scope-label{
  font-family:var(--serif-en);
  font-size:11px;letter-spacing:.4em;
  color:var(--gold);text-transform:uppercase;
  margin-bottom:24px;
}
.req-scope h3{
  font-family:var(--serif);
  font-size:28px;font-weight:700;
  margin-bottom:20px;color:var(--ink);
  line-height:1.5;
}
.req-scope h3 .accent{color:var(--gold-bright);font-style:italic}
.req-scope p{
  font-size:15px;line-height:2;color:var(--ink-soft);
}

/* CTA */
.req-cta{
  padding:120px 0;position:relative;z-index:2;
  background:
    radial-gradient(circle at 50% 0%, rgba(201,164,92,.1), transparent 60%),
    var(--bg-deep);
  text-align:center;border-top:1px solid var(--line-soft);
}
.req-cta-eyebrow{
  font-family:var(--serif-en);
  font-size:12px;letter-spacing:.4em;
  color:var(--gold);margin-bottom:20px;text-transform:uppercase;
}
.req-cta h2{
  font-family:var(--serif);
  font-size:clamp(28px, 4vw, 44px);
  font-weight:700;margin-bottom:24px;
  line-height:1.5;color:var(--ink);
}
.req-cta h2 .accent{color:var(--gold-bright);font-style:italic}
.req-cta-lead{
  font-size:15px;line-height:2;color:var(--ink-soft);
  max-width:580px;margin:0 auto 40px;
}
.req-cta-btn{
  display:inline-flex;align-items:center;gap:14px;
  background:#06c755;color:#fff !important;
  padding:20px 48px;
  font-family:var(--serif);font-size:16px;font-weight:700;
  letter-spacing:.05em;border-radius:50px;
  box-shadow:0 12px 36px rgba(6,199,85,.4);
  transition:all .3s;
}
.req-cta-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 48px rgba(6,199,85,.55);
}
.req-cta-note{
  margin-top:28px;font-size:13px;color:var(--ink-mute);
  letter-spacing:.05em;
}

/* レスポンシブ */
@media (max-width:1024px){
  .req-features{grid-template-columns:1fr 1fr}
  .req-about{gap:50px}
}
@media (max-width:680px){
  .sub-hero{padding:130px 0 70px}
  .req-section{padding:80px 0}
  .req-section-head{margin-bottom:50px}
  .req-about{grid-template-columns:1fr;gap:40px}
  .req-about-visual{aspect-ratio:4/3;max-width:400px;margin:0 auto}
  .req-features{grid-template-columns:1fr;gap:20px}
  .req-feature-card{padding:36px 24px}
  .req-step{grid-template-columns:1fr;gap:12px;padding:28px 0}
  .req-step-num{font-size:42px}
  .req-scope{padding:40px 24px}
  .req-scope h3{font-size:22px}
  .req-cta{padding:80px 0}
  .req-cta-btn{padding:18px 32px;font-size:15px;width:100%;justify-content:center;max-width:340px}
}
