/*
Theme Name: トラ吉 (Torakichi)
Theme URI: https://rolex-kouka-kaitori-torakichi.com/
Author: トラ吉
Author URI: https://rolex-kouka-kaitori-torakichi.com/
Description: 銀座のロレックス・高級時計買取専門店「トラ吉」公式WordPressテーマ。ダークラグジュアリー調のデザインで、トップページに加え、リクエスト販売、業者様（提携募集）、Recruit、FC加盟店募集の各専用テンプレートを搭載。
Version: 1.0.6
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: torakichi
*/


:root{
  --bg-deep:#0a0807;
  --bg:#12100e;
  --bg-elev:#1a1714;
  --line:#2a241d;
  --line-soft:#1f1b16;
  --gold:#c9a45c;
  --gold-bright:#e8c889;
  --gold-deep:#8b6f3a;
  --green:#1d4e3c;
  --green-rolex:#006039;
  --red:#8b1c1c;
  --ink:#f3ece0;
  --ink-soft:#c9bfae;
  --ink-mute:#8a8175;
  --shadow:0 30px 80px -20px rgba(0,0,0,.6);
  --serif:"Shippori Mincho","Noto Serif JP",serif;
  --serif-en:"Cormorant Garamond",serif;
  --sans:"Jost","Noto Serif JP",sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--serif);
  font-weight:400;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

body::before{
  content:"";position:fixed;inset:0;
  background:
    radial-gradient(ellipse at 20% 10%, rgba(201,164,92,.08), transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(0,96,57,.06), transparent 50%);
  pointer-events:none;z-index:0;
}
body::after{
  content:"";position:fixed;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 .8 0 0 0 0 .65 0 0 0 0 .35 0 0 0 .04 0'/></filter><rect width='180' height='180' filter='url(%23n)'/></svg>");
  pointer-events:none;z-index:1;opacity:.4;mix-blend-mode:overlay;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container{max-width:1280px;margin:0 auto;padding:0 32px;position:relative;z-index:2}

/* ===== ヘッダー ===== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  background:rgba(10,8,7,.7);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--line-soft);
}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:14px;transition:opacity .3s}
.logo:hover{opacity:.85}
.logo-img{width:48px;height:48px;display:block;border-radius:50%;object-fit:cover;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.logo-text{display:flex;flex-direction:column;line-height:1.2}
.logo-jp{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--ink);letter-spacing:.04em}
.logo-en{font-family:var(--serif-en);font-size:10px;color:var(--gold);letter-spacing:.28em;text-transform:uppercase;margin-top:2px}
.nav{display:flex;gap:32px;align-items:center}
.nav a{font-family:var(--serif);font-size:14px;color:var(--ink-soft);position:relative;padding:6px 0;transition:color .3s}
.nav a:hover{color:var(--gold-bright)}
.nav a::after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold);transition:width .4s ease}
.nav a:hover::after{width:100%}
.nav-current{color:var(--gold-bright) !important}
.nav-current::after{width:100% !important;background:var(--gold) !important}
.nav-cta{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-bright) 100%);
  color:var(--bg-deep) !important;
  padding:10px 22px;font-weight:600;font-size:13px;letter-spacing:.1em;
  border-radius:2px;transition:transform .3s,box-shadow .3s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 30px -10px rgba(201,164,92,.5)}
.nav-cta::after{display:none}
.menu-toggle{display:none;background:none;border:none;color:var(--ink);font-size:24px;cursor:pointer}

/* ===== ヒーロー ===== */
.hero{position:relative;min-height:100vh;padding:160px 0 100px;display:flex;align-items:center;overflow:hidden}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    /* テキストの可読性を確保するためのオーバーレイ（左から右へ濃→淡） */
    linear-gradient(90deg, rgba(10,8,7,.92) 0%, rgba(10,8,7,.78) 35%, rgba(10,8,7,.5) 70%, rgba(10,8,7,.35) 100%),
    /* 上下のヴィネット */
    linear-gradient(180deg, rgba(10,8,7,.4) 0%, transparent 30%, transparent 70%, rgba(10,8,7,.6) 100%),
    /* 金色の光芒 */
    radial-gradient(circle at 75% 50%, rgba(201,164,92,.18), transparent 55%),
    /* ロレックス デイトナの背景画像 */
    url("assets/images/hero-index.jpg") center/cover no-repeat,
    /* フォールバック */
    linear-gradient(180deg, var(--bg-deep) 0%, var(--bg) 100%);
  background-color:var(--bg-deep);
}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:0;align-items:center;width:100%;max-width:760px}
/* 背景に実画像があるのでSVG時計は非表示 */
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--serif-en);font-size:13px;letter-spacing:.35em;
  color:var(--gold);text-transform:uppercase;margin-bottom:36px;
  opacity:0;animation:fadeUp .8s .2s forwards;
}
.hero-eyebrow::before{content:"";width:40px;height:1px;background:var(--gold)}
.hero h1{
  font-family:var(--serif);
  font-size:clamp(40px,5.5vw,76px);
  font-weight:600;line-height:1.15;letter-spacing:.01em;
  margin-bottom:32px;opacity:0;animation:fadeUp .8s .4s forwards;
}
.hero h1 .accent{color:var(--gold-bright);font-style:italic;font-family:var(--serif-en);font-weight:500}
.hero h1 .brand{display:block;font-size:.6em;color:var(--ink-soft);letter-spacing:.4em;margin-bottom:10px;font-weight:300}
.hero-sub{font-size:18px;color:var(--ink-soft);line-height:1.9;margin-bottom:30px;max-width:560px;opacity:0;animation:fadeUp .8s .6s forwards}

.hero-badges{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:40px;
  opacity:0;animation:fadeUp .8s .7s forwards;
}
.hero-badge{
  font-family:var(--serif);font-size:12px;font-weight:500;
  padding:6px 14px;border:1px solid var(--gold-deep);color:var(--gold-bright);
  letter-spacing:.08em;
}

.hero-cta-group{display:flex;gap:20px;align-items:center;margin-bottom:50px;opacity:0;animation:fadeUp .8s .8s forwards;flex-wrap:wrap}
.btn-primary{
  display:inline-flex;align-items:center;gap:12px;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-bright) 50%,var(--gold) 100%);
  background-size:200% 100%;color:var(--bg-deep);
  padding:18px 38px;font-family:var(--serif);font-weight:700;font-size:16px;letter-spacing:.08em;
  border:none;border-radius:2px;cursor:pointer;position:relative;overflow:hidden;
  transition:all .5s;box-shadow:0 15px 40px -15px rgba(201,164,92,.6);
}
.btn-primary:hover{background-position:100% 0;transform:translateY(-2px);box-shadow:0 20px 50px -10px rgba(201,164,92,.7)}
.btn-primary svg{transition:transform .3s}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;color:var(--ink);
  padding:18px 28px;border:1px solid var(--line);
  font-family:var(--serif);font-size:15px;letter-spacing:.05em;transition:all .3s;
}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold-bright)}

.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
  padding-top:40px;border-top:1px solid var(--line-soft);
  opacity:0;animation:fadeUp .8s 1s forwards;
}
.hero-stat-num{font-family:var(--serif-en);font-size:42px;color:var(--gold-bright);font-weight:500;line-height:1;margin-bottom:8px}
.hero-stat-label{font-size:13px;color:var(--ink-mute);letter-spacing:.1em}


.scroll-indicator{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-family:var(--serif-en);font-size:11px;letter-spacing:.3em;
  color:var(--ink-mute);writing-mode:vertical-rl;
  opacity:0;animation:fadeIn 1s 1.4s forwards;
}
.scroll-indicator::after{content:"";display:block;width:1px;height:50px;background:linear-gradient(to bottom,var(--gold),transparent);margin:14px auto 0;animation:scrollDown 2s ease infinite}

@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scrollDown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ===== セクション共通 ===== */
section{padding:120px 0;position:relative;z-index:2}
.section-head{text-align:center;margin-bottom:80px}
.section-eyebrow{font-family:var(--serif-en);font-size:13px;letter-spacing:.4em;color:var(--gold);text-transform:uppercase;margin-bottom:20px;display:inline-block}
.section-eyebrow::before,.section-eyebrow::after{content:"";display:inline-block;width:30px;height:1px;background:var(--gold);vertical-align:middle;margin:0 16px}
.section-title{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:600;line-height:1.3;letter-spacing:.02em;margin-bottom:24px}
.section-title .accent{color:var(--gold-bright);font-family:var(--serif-en);font-style:italic;font-weight:500}
.section-lead{font-size:17px;color:var(--ink-soft);max-width:680px;margin:0 auto;line-height:1.9}

/* ===== ブランドストリップ ===== */
.brands{
  background:var(--bg-deep);
  padding:80px 0 90px;
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.brands-label{
  text-align:center;
  font-family:var(--serif-en);
  font-size:12px;letter-spacing:.4em;
  color:var(--gold);margin-bottom:50px;
}
.brands-label::before,.brands-label::after{content:"";display:inline-block;width:50px;height:1px;background:var(--gold-deep);vertical-align:middle;margin:0 18px}
.brand-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.brand-item{
  text-align:center;
  border:1px solid var(--line-soft);
  transition:all .4s;
  background:#fff;
  /* 元サイトと同じ横長カード */
  aspect-ratio:16/9;
  display:flex;align-items:center;justify-content:center;
  padding:18px 24px;
  position:relative;
  overflow:hidden;
}
.brand-item:hover{
  border-color:var(--gold);
  transform:translateY(-3px);
  box-shadow:0 18px 40px -15px rgba(201,164,92,.3);
}
.brand-item img{
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  object-fit:contain;
  transition:transform .4s;
}
.brand-item:hover img{transform:scale(1.05)}
.brand-item-etc{
  background:#fff;
  color:#1a1a1a;
}
.brand-etc{
  font-family:var(--serif);
  font-size:36px;
  font-weight:600;
  letter-spacing:.1em;
  color:#1a1a1a;
}
/* スクリーンリーダー用の英字ブランド名は視覚的に隠す */
.brand-name{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* ===== 強み ===== */
.strengths{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-deep) 100%);position:relative}
.strengths::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent)}
.strength-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.strength-card{
  background:var(--bg-elev);
  border:1px solid var(--line);
  padding:50px 40px;position:relative;
  transition:all .5s;overflow:hidden;
}
.strength-card::before{
  content:"";position:absolute;top:0;left:0;
  width:100%;height:2px;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright),var(--gold-deep));
  transform:scaleX(0);transform-origin:left;transition:transform .6s;
}
.strength-card:hover::before{transform:scaleX(1)}
.strength-card:hover{transform:translateY(-8px);border-color:var(--gold-deep)}
.strength-num{font-family:var(--serif-en);font-size:80px;font-weight:300;color:var(--gold);line-height:1;margin-bottom:24px;opacity:.4}
.strength-card h3{font-family:var(--serif);font-size:24px;font-weight:600;margin-bottom:18px;line-height:1.5}
.strength-card h3 .em{color:var(--gold-bright)}
.strength-card p{font-size:15px;color:var(--ink-soft);line-height:1.9}

/* ===== カテゴリ：時計 ===== */
.watches{background:var(--bg-deep)}
.watch-brand-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.watch-brand-card{
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);
  padding:40px 32px;position:relative;
  transition:all .4s;overflow:hidden;
}
.watch-brand-card::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at top right,rgba(201,164,92,.06),transparent 60%);
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.watch-brand-card:hover{border-color:var(--gold-deep);transform:translateY(-4px)}
.watch-brand-card:hover::after{opacity:1}
.wbc-num{font-family:var(--serif-en);font-size:12px;color:var(--gold);letter-spacing:.3em;margin-bottom:18px;position:relative;z-index:1}
.wbc-logo{
  aspect-ratio:16/9;
  background:#fff;
  border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  padding:18px 24px;
  margin-bottom:24px;
  position:relative;z-index:1;
  transition:transform .4s, box-shadow .4s;
  overflow:hidden;
}
.wbc-logo img{
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  object-fit:contain;
  transition:transform .4s;
}
.watch-brand-card:hover .wbc-logo{
  transform:translateY(-2px);
  box-shadow:0 12px 30px -10px rgba(201,164,92,.3);
}
.watch-brand-card:hover .wbc-logo img{transform:scale(1.04)}
.wbc-en{font-family:var(--serif-en);font-size:22px;font-weight:500;color:var(--gold-bright);letter-spacing:.05em;margin-bottom:6px;position:relative;z-index:1}
.wbc-jp{font-family:var(--serif);font-size:17px;font-weight:600;margin-bottom:18px;position:relative;z-index:1}
.wbc-text{font-size:14px;color:var(--ink-soft);line-height:1.9;margin-bottom:22px;position:relative;z-index:1}
.wbc-models{font-size:12px;color:var(--ink-mute);font-family:var(--sans);letter-spacing:.05em;position:relative;z-index:1}
.wbc-models span{color:var(--gold);margin-right:6px}

/* ===== Instagram連携セクション ===== */
.insta-section{
  background:linear-gradient(180deg,var(--bg-deep) 0%,var(--bg) 100%);
  position:relative;
  overflow:hidden;
}
.insta-section::before{
  content:"#ロレックスマラソン";
  position:absolute;top:60px;right:-80px;
  font-family:var(--serif);
  font-size:140px;font-weight:300;
  color:var(--gold);opacity:.03;
  letter-spacing:.05em;white-space:nowrap;
}
.insta-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:60px;gap:40px;
}
.insta-head-left{flex:1}
.insta-head h2{
  font-family:var(--serif);
  font-size:clamp(30px,3.5vw,46px);
  font-weight:600;line-height:1.3;
  margin-bottom:18px;
}
.insta-head h2 .accent{color:var(--gold-bright);font-family:var(--serif-en);font-style:italic}
.insta-head p{font-size:15px;color:var(--ink-soft);line-height:1.9;max-width:620px}
.insta-handle{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--serif-en);font-size:13px;color:var(--gold);
  letter-spacing:.2em;margin-bottom:14px;
}
.insta-handle::before{
  content:"";width:30px;height:1px;background:var(--gold);
}
.insta-follow{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;
  background:linear-gradient(135deg,#833ab4 0%,#fd1d1d 50%,#fcb045 100%);
  color:#fff;font-family:var(--serif);font-weight:600;font-size:14px;
  letter-spacing:.05em;border-radius:2px;flex-shrink:0;
  transition:transform .3s,box-shadow .3s;
}
.insta-follow:hover{transform:translateY(-2px);box-shadow:0 15px 35px -10px rgba(253,29,29,.5)}

/* Instagram公式埋め込み（embed.js）のレイアウト */
.insta-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:40px;
}
/* Instagramのblockquoteは白背景なので、ダーク背景に馴染ませる枠を回す */
.insta-grid .instagram-media{
  margin:0 auto !important;
  min-width:0 !important;
  width:100% !important;
  max-width:100% !important;
  border:1px solid var(--line) !important;
  border-radius:4px !important;
  background:#fff !important;
  box-shadow:0 20px 40px -20px rgba(0,0,0,.5) !important;
  transition:transform .4s, box-shadow .4s, border-color .4s;
}
.insta-grid .instagram-media:hover{
  transform:translateY(-4px);
  border-color:var(--gold) !important;
  box-shadow:0 30px 60px -20px rgba(201,164,92,.25) !important;
}
/* embed.js 読み込み前のプレースホルダ調整（リンクは表示維持） */
.insta-grid blockquote.instagram-media:not(.instagram-media-rendered){
  padding:24px !important;
  min-height:320px;
  color:#333;
}

.insta-more{
  text-align:center;
  padding-top:20px;
}
.insta-more a{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--serif-en);font-size:13px;color:var(--gold);
  letter-spacing:.25em;
  padding:14px 32px;
  border:1px solid var(--gold-deep);
  transition:all .3s;
}
.insta-more a:hover{
  background:rgba(201,164,92,.08);
  color:var(--gold-bright);
}
.insta-more a svg{transition:transform .3s}
.insta-more a:hover svg{transform:translateX(4px)}

/* ===== 時計以外の買取 ===== */
.others{background:var(--bg)}
.others-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.other-card{
  position:relative;aspect-ratio:3/4;
  border:1px solid var(--line);
  background:var(--bg-elev);
  display:flex;flex-direction:column;
  overflow:hidden;transition:all .4s;
}
.other-card:hover{
  border-color:var(--gold);
  transform:translateY(-4px);
  box-shadow:0 30px 60px -20px rgba(0,0,0,.6);
}
.other-img{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#0a0807;
}
.other-img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .8s;
}
.other-card:hover .other-img img{transform:scale(1.06)}
.other-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(10,8,7,.4) 100%);
  pointer-events:none;
}
.other-content{
  flex:1;
  padding:24px 24px 28px;
  display:flex;flex-direction:column;justify-content:flex-start;
  position:relative;z-index:1;
}
.other-en{font-family:var(--serif-en);font-size:22px;font-weight:500;color:var(--gold-bright);letter-spacing:.1em;margin-bottom:4px}
.other-jp{font-family:var(--serif);font-size:16px;font-weight:600;margin-bottom:12px}
.other-text{font-size:13px;color:var(--ink-soft);line-height:1.8}

/* ===== 流れ ===== */
.flow{background:linear-gradient(180deg,var(--bg-deep) 0%,var(--bg) 100%)}
.flow-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;position:relative}
.flow-step{text-align:center;padding:0 12px;position:relative}
.flow-step:not(:last-child)::after{
  content:"";position:absolute;top:38px;right:-20px;
  width:40px;height:1px;background:linear-gradient(90deg,var(--gold-deep),transparent);
}
.flow-num{
  width:78px;height:78px;margin:0 auto 28px;
  border:1px solid var(--gold-deep);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif-en);font-size:28px;color:var(--gold-bright);
  position:relative;background:var(--bg);
}
.flow-num::before{
  content:"STEP";position:absolute;top:-10px;
  font-family:var(--serif-en);font-size:9px;color:var(--ink-mute);
  letter-spacing:.3em;background:var(--bg);padding:0 8px;
}
.flow-step h4{font-family:var(--serif);font-size:17px;font-weight:600;margin-bottom:12px}
.flow-step p{font-size:13px;color:var(--ink-soft);line-height:1.8}

/* ===== 方法選択 ===== */
.methods{background:var(--bg)}
.method-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:900px;margin:0 auto}
.method-card{
  border:1px solid var(--line);padding:48px 36px;text-align:center;
  position:relative;transition:all .4s;
  background:linear-gradient(180deg,var(--bg-elev) 0%,var(--bg) 100%);
}
.method-card:hover{border-color:var(--gold);transform:translateY(-5px)}
.method-card.featured{border-color:var(--gold);background:linear-gradient(180deg,rgba(201,164,92,.08) 0%,var(--bg-elev) 100%)}
.method-card.featured::before{
  content:"推奨";position:absolute;top:20px;right:20px;
  font-family:var(--serif);font-size:11px;color:var(--bg-deep);
  background:var(--gold-bright);padding:4px 12px;letter-spacing:.15em;
}
.method-icon{width:80px;height:80px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;color:var(--gold-bright)}
.method-card h4{font-family:var(--serif);font-size:22px;font-weight:600;margin-bottom:12px}
.method-card .feat{font-family:var(--serif-en);font-size:12px;color:var(--gold);letter-spacing:.2em;margin-bottom:20px}
.method-card p{font-size:14px;color:var(--ink-soft);line-height:1.9;margin-bottom:28px}
.method-card .btn-secondary{font-size:13px;padding:14px 24px}

/* ===== 体験談 ===== */
.testimonials{background:var(--bg-deep);position:relative;overflow:hidden}
.testimonials::before{
  content:"VOICE";position:absolute;top:80px;right:-20px;
  font-family:var(--serif-en);font-size:180px;font-weight:300;
  color:var(--gold);opacity:.03;letter-spacing:.1em;
}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.testimonial{background:var(--bg-elev);border:1px solid var(--line);padding:40px 32px;position:relative}
.testimonial-quote{font-family:var(--serif-en);font-size:60px;color:var(--gold);line-height:.5;margin-bottom:14px;opacity:.5}
.testimonial-text{font-size:15px;color:var(--ink-soft);line-height:1.9;margin-bottom:24px;min-height:135px}
.testimonial-meta{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--line-soft)}
.testimonial-avatar{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-deep),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:700;color:var(--bg-deep);
}
.testimonial-name{font-family:var(--serif);font-weight:600;font-size:15px}
.testimonial-info{font-size:12px;color:var(--ink-mute);margin-top:2px}
.testimonial-model{position:absolute;top:32px;right:32px;font-family:var(--serif-en);font-size:10px;color:var(--gold);letter-spacing:.2em;border:1px solid var(--gold-deep);padding:4px 10px}

/* ===== FAQ ===== */
.faq{background:var(--bg)}
.faq-list{max-width:880px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;background:none;border:none;padding:30px 0;
  display:flex;align-items:center;gap:24px;cursor:pointer;
  font-family:var(--serif);font-size:17px;color:var(--ink);
  text-align:left;transition:color .3s;font-weight:500;
}
.faq-q:hover{color:var(--gold-bright)}
.faq-q-mark{font-family:var(--serif-en);font-size:24px;color:var(--gold);font-weight:300;flex-shrink:0}
.faq-q-text{flex:1}
.faq-toggle{
  width:30px;height:30px;border:1px solid var(--line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:all .4s;flex-shrink:0;
}
.faq-item.open .faq-toggle{background:var(--gold);border-color:var(--gold);transform:rotate(180deg)}
.faq-item.open .faq-toggle svg{stroke:var(--bg-deep)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s ease}
.faq-item.open .faq-a{max-height:400px}
.faq-a-inner{padding:0 0 30px 50px;display:flex;gap:24px}
.faq-a-mark{font-family:var(--serif-en);font-size:24px;color:var(--gold-bright);font-weight:300}
.faq-a-text{flex:1;font-size:15px;color:var(--ink-soft);line-height:1.9}

/* ===== 関連サービス ===== */
.services-link{background:var(--bg-deep)}
.services-link-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-link-card{
  border:1px solid var(--line);padding:50px 36px;
  position:relative;transition:all .4s;overflow:hidden;
  background:linear-gradient(135deg,var(--bg-elev) 0%,var(--bg) 100%);
}
.service-link-card:hover{border-color:var(--gold);transform:translateY(-4px)}
.service-link-num{position:absolute;top:20px;right:24px;font-family:var(--serif-en);font-size:14px;color:var(--gold-deep);letter-spacing:.2em}
.service-link-card h4{font-family:var(--serif);font-size:22px;font-weight:600;margin-bottom:14px;color:var(--gold-bright)}
.service-link-card .en{font-family:var(--serif-en);font-size:11px;color:var(--gold);letter-spacing:.3em;text-transform:uppercase;margin-bottom:20px}
.service-link-card p{font-size:14px;color:var(--ink-soft);line-height:1.9;margin-bottom:24px;min-height:90px}
.service-link-arrow{font-family:var(--serif-en);font-size:13px;color:var(--gold);letter-spacing:.15em;display:inline-flex;align-items:center;gap:8px;transition:gap .3s}
.service-link-card:hover .service-link-arrow{gap:16px}

/* ===== CTA ===== */
.cta-section{
  background:radial-gradient(ellipse at center, rgba(201,164,92,.15), transparent 70%),var(--bg-deep);
  text-align:center;position:relative;overflow:hidden;
}
.cta-section::before{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:600px;height:600px;border:1px solid var(--line);border-radius:50%;opacity:.3;
}
.cta-section::after{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:800px;border:1px solid var(--line-soft);border-radius:50%;opacity:.2;
}
.cta-inner{position:relative;z-index:2}
.cta-section h2{font-family:var(--serif);font-size:clamp(32px,4.5vw,56px);font-weight:600;line-height:1.3;margin-bottom:28px}
.cta-section h2 .accent{color:var(--gold-bright);font-family:var(--serif-en);font-style:italic}
.cta-section p{font-size:17px;color:var(--ink-soft);max-width:580px;margin:0 auto 50px;line-height:1.9}
.cta-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
.btn-line{
  display:inline-flex;align-items:center;gap:12px;
  background:#06c755;color:#fff;padding:18px 38px;
  font-family:var(--serif);font-weight:700;font-size:16px;letter-spacing:.05em;
  border-radius:2px;transition:all .3s;box-shadow:0 15px 40px -15px rgba(6,199,85,.5);
}
.btn-line:hover{transform:translateY(-2px);box-shadow:0 20px 50px -10px rgba(6,199,85,.6)}

/* ===== 店舗情報 ===== */
.access{background:var(--bg);padding:120px 0}
.access-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.access-info h3{font-family:var(--serif);font-size:32px;font-weight:600;margin-bottom:30px}
.access-info h3 .accent{color:var(--gold-bright);font-family:var(--serif-en);font-style:italic}
.access-row{
  display:grid;grid-template-columns:130px 1fr;
  padding:20px 0;border-bottom:1px solid var(--line-soft);
}
.access-row dt{font-family:var(--serif-en);font-size:12px;color:var(--gold);letter-spacing:.2em;text-transform:uppercase}
.access-row dd{font-size:15px;color:var(--ink-soft);line-height:1.8}
.access-row dd strong{color:var(--ink);font-weight:600}
.access-visual{
  aspect-ratio:1;
  border:1px solid var(--gold-deep);
  position:relative;overflow:hidden;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.5), inset 0 0 0 1px rgba(201,164,92,.1);
}
.access-map{
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  width:100%;height:100%;
  overflow:hidden;
  display:block;
}
.access-map iframe{
  display:block;
  position:absolute;
  top:0;left:0;
  width:100%;height:100%;
  border:0;
  margin:0;padding:0;
  /* ダークラグジュアリーに馴染ませるためにフィルター調整 */
  filter:grayscale(.4) brightness(.85) contrast(1.05);
  transition:filter .4s ease;
}
.access-map:hover iframe{
  filter:grayscale(0) brightness(1) contrast(1);
}
.access-map-label{
  position:absolute;top:18px;left:22px;
  font-family:var(--serif-en);font-size:13px;color:var(--gold);letter-spacing:.4em;
  background:rgba(10,8,7,.85);padding:6px 14px;
  border:1px solid var(--gold-deep);
  pointer-events:none;z-index:2;
  text-shadow:0 1px 4px rgba(0,0,0,.8);
}

/* ===== フッター ===== */
.footer{background:var(--bg-deep);padding:80px 0 30px;border-top:1px solid var(--line);position:relative;z-index:2}
/* フローティングCTAと著作権表記の被りを防止 */
body{padding-bottom:0}
@media (max-width:680px){
  body{padding-bottom:90px}
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr;gap:80px;margin-bottom:60px;align-items:start}
.footer-brand h3{font-family:var(--serif);font-size:24px;font-weight:700;margin-bottom:4px}
.footer-brand .en{font-family:var(--serif-en);font-size:11px;color:var(--gold);letter-spacing:.28em}
.footer-brand-head{display:flex;align-items:center;gap:16px;margin-bottom:22px}
.footer-brand-img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0;box-shadow:0 6px 20px rgba(0,0,0,.5)}
.footer-brand p{font-size:14px;color:var(--ink-soft);line-height:1.9}
.footer-col h5{font-family:var(--serif-en);font-size:12px;color:var(--gold);letter-spacing:.25em;margin-bottom:24px;text-transform:uppercase}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:14px;font-size:14px}
.footer-col a{color:var(--ink-soft);transition:color .3s}
.footer-col a:hover{color:var(--gold-bright)}
.footer-bottom{padding-top:30px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;font-size:12px;color:var(--ink-mute)}
.footer-bottom .en{font-family:var(--serif-en);letter-spacing:.2em}
.footer-social{display:flex;gap:18px;padding:18px 0 24px;justify-content:flex-end}
.footer-social a{
  width:38px;height:38px;
  border:1px solid var(--line);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-soft);
  transition:all .3s;
}
.footer-social a:hover{
  color:var(--gold-bright);
  border-color:var(--gold);
  transform:translateY(-2px);
}

/* ===== レスポンシブ ===== */
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .strength-grid,.method-grid,.testimonial-grid,.others-grid,.services-link-grid,.watch-brand-grid{grid-template-columns:1fr 1fr}
  .insta-grid{grid-template-columns:repeat(2,1fr)}
  .brand-grid{grid-template-columns:repeat(3,1fr)}
  .brand-item{padding:14px 20px}
  .flow-steps{grid-template-columns:1fr 1fr;gap:40px 20px}
  .flow-step:not(:last-child)::after{display:none}
  .footer-grid,.access-inner{grid-template-columns:1fr;gap:40px}
  .insta-head{flex-direction:column;align-items:flex-start;gap:24px}
}
@media (max-width:680px){
  .container{padding:0 22px}
  /* ハンバーガーメニュー：ドロワー方式 */
  .nav{
    display:flex;flex-direction:column;
    position:fixed;top:0;right:-100%;
    width:78%;max-width:340px;height:100vh;
    background:var(--bg-deep);
    border-left:1px solid var(--line);
    padding:90px 28px 30px;
    gap:0;
    transition:right .35s ease;
    z-index:98;
    overflow-y:auto;
    box-shadow:-20px 0 50px rgba(0,0,0,.5);
  }
  .nav.open{right:0}
  .nav a{
    font-size:15px;padding:18px 0;
    border-bottom:1px solid var(--line-soft);
    letter-spacing:.05em;
  }
  .nav a::after{display:none}
  /* ドロワー背景オーバーレイ */
  .nav-overlay{
    position:fixed;inset:0;
    background:rgba(0,0,0,.6);
    opacity:0;pointer-events:none;
    transition:opacity .35s;
    z-index:97;
  }
  .nav-overlay.show{opacity:1;pointer-events:auto}
  .menu-toggle{display:block;position:relative;z-index:99;transition:transform .3s}
  .menu-toggle.open{transform:rotate(90deg)}
  section{padding:80px 0}
  .hero{padding:120px 0 60px;min-height:auto}
  .hero-stats{grid-template-columns:1fr;gap:24px;text-align:center;padding-top:30px}
  .hero-stat-num{font-size:36px}
  .scroll-indicator{display:none}
  .strength-grid,.method-grid,.testimonial-grid,.others-grid,.services-link-grid,.watch-brand-grid{grid-template-columns:1fr}
  .insta-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .brand-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .brand-item{padding:12px 18px}
  .flow-steps{grid-template-columns:1fr;gap:40px}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-bottom{flex-direction:column;gap:10px}
  .footer-social{justify-content:center}
  .hero-cta-group{flex-direction:column;align-items:stretch}
  .btn-primary,.btn-secondary{justify-content:center}
  .section-head{margin-bottom:50px}
  .access{padding:80px 0}
}

.reveal{opacity:0;transform:translateY(40px);transition:all 1s}
.reveal.in{opacity:1;transform:translateY(0)}

.floating-cta{
  position:fixed;bottom:30px;right:30px;z-index:99;
  opacity:0;transform:translateY(20px);transition:all .5s;pointer-events:none;
}
.floating-cta.show{opacity:1;transform:translateY(0);pointer-events:auto}
.floating-btn{
  display:flex;align-items:center;gap:12px;padding:16px 28px;
  border-radius:50px;font-family:var(--serif);font-weight:700;font-size:15px;
  box-shadow:0 12px 36px rgba(6,199,85,.45),0 4px 12px rgba(0,0,0,.3);
  transition:transform .3s, box-shadow .3s;
}
.floating-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 48px rgba(6,199,85,.55),0 6px 16px rgba(0,0,0,.35);
}
.floating-btn.line{background:#06c755;color:#fff}
@media (max-width:680px){
  .floating-cta{bottom:20px;right:16px;left:16px}
  .floating-btn{justify-content:center;font-size:15px;padding:16px}
}
