/* ============================================================
   ウイニング公式サイト 共通スタイル（全ページ共通）
   ※色やサイズを変えたいときは、下の「変数」を直すだけで
     サイト全体に反映されます
   ============================================================ */
:root{
  --ink:#1b1b1b;          /* 基本の文字色 */
  --muted:#6b6b6b;        /* 補足文字の色 */
  --accent:#a31621;       /* 差し色（深い赤） */
  --gold:#b08d2e;         /* 飾りの金色 */
  --line:#e6e2da;         /* 罫線の色 */
  --bg:#ffffff;           /* 背景色 */
  --bg-soft:#faf9f6;      /* やわらかい背景色 */
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:"Noto Sans JP",sans-serif;
  color:var(--ink); background:var(--bg);
  line-height:1.8; font-size:15px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.en{font-family:"Cormorant Garamond",serif;letter-spacing:.12em}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* ---------- ヘッダー ---------- */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:16px}
.brand img{height:38px;width:auto}
.brand .tagline{
  font-family:"Yu Mincho","YuMincho","Hiragino Mincho ProN",serif;
  font-size:13.5px;letter-spacing:.22em;color:var(--ink);font-weight:500;
}
nav.global{display:flex;gap:30px;font-size:13.5px;font-weight:500;letter-spacing:.08em}
nav.global a{padding:6px 0;border-bottom:2px solid transparent;transition:.25s}
nav.global a:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- ヒーロー（トップの横長画像） ---------- */
.hero-img{border-bottom:1px solid var(--line);background:var(--bg-soft)}
.hero-img img{width:100%;max-width:1280px;margin:0 auto}

/* ---------- ページタイトル（下層ページ用） ---------- */
.page-title{
  text-align:center;padding:58px 24px 50px;
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(ellipse 60% 70% at 50% 0%, #f6f3ec 0%, transparent 70%),
    var(--bg);
}
.page-title .en-title{font-size:32px;font-weight:600;letter-spacing:.18em}
.page-title .jp{display:block;margin-top:4px;color:var(--gold);font-size:12.5px;letter-spacing:.3em;text-indent:.3em}

/* ---------- セクション共通 ---------- */
section{padding:80px 0}
.sec-head{text-align:center;margin-bottom:48px}
.sec-head .en-title{font-size:34px;color:var(--ink);font-weight:600;letter-spacing:.18em}
.sec-head .jp{
  display:block;margin-top:6px;color:var(--gold);
  font-size:12.5px;letter-spacing:.3em;text-indent:.3em;
}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 34px;font-size:14px;font-weight:500;letter-spacing:.12em;
  border:1px solid var(--ink);transition:.3s;
}
.btn:hover{background:var(--ink);color:#fff}
.btn.line{background:#06C755;border-color:#06C755;color:#fff}
.btn.line:hover{opacity:.85}

/* ---------- 新商品（横スクロール） ---------- */
/* 上部に下層ページと同じ薄いグラデーションを敷く */
#news{
  background:
    radial-gradient(ellipse 60% 320px at 50% 0%, #f1ecdf 0%, transparent 70%),
    var(--bg-soft);
}
.news-scroller{
  display:flex;gap:24px;overflow-x:auto;
  padding:4px 4px 22px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.news-scroller::-webkit-scrollbar{height:8px}
.news-scroller::-webkit-scrollbar-track{background:#eee9df;border-radius:4px}
.news-scroller::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px}
.news-card{
  flex:0 0 300px;scroll-snap-align:start;
  background:#fff;border:1px solid var(--line);
  transition:.3s;overflow:hidden;
}
.news-card:hover{box-shadow:0 14px 34px rgba(27,27,27,.10);transform:translateY(-3px)}
.news-card .thumb{aspect-ratio:570/250;overflow:hidden;border-bottom:1px solid var(--line)}
.news-card .thumb img{width:100%;height:100%;object-fit:cover}
.news-card .body{padding:18px 20px 22px}
.news-card .tag{
  display:inline-block;font-size:10.5px;letter-spacing:.2em;
  color:#fff;background:var(--accent);padding:2px 11px;margin-bottom:10px;
}
.news-card h3{font-size:14.5px;font-weight:700;letter-spacing:.04em;line-height:1.5}
.news-card .price{margin-top:6px;color:var(--accent);font-weight:700;font-size:14.5px}
.news-card .spec{margin-top:6px;color:var(--muted);font-size:12px;line-height:1.7}
.news-card .spec a{color:var(--accent);text-decoration:underline}
.news-card details{margin-top:10px;border-top:1px dashed var(--line);padding-top:8px}
.news-card summary{
  cursor:pointer;font-size:12px;color:var(--gold);font-weight:500;
  letter-spacing:.08em;list-style:none;
}
.news-card summary::before{content:"▸ "}
.news-card details[open] summary::before{content:"▾ "}
.news-card details img{margin-top:8px;border:1px solid var(--line);background:#fff}
.scroll-hint{text-align:center;color:var(--muted);font-size:12px;letter-spacing:.15em;margin-top:6px}

/* ---------- メニュー（リンクカード／4等分） ---------- */
/* 上部に下層ページと同じ薄いグラデーションを敷く */
#menu{
  background:
    radial-gradient(ellipse 60% 320px at 50% 0%, #f6f3ec 0%, transparent 70%),
    var(--bg);
}
.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.menu-card{
  position:relative;border:1px solid var(--line);background:#fff;
  padding:30px 24px 46px;transition:.3s;
}
.menu-card::after{
  content:"→";position:absolute;right:28px;bottom:24px;
  color:var(--gold);font-size:18px;transition:.3s;
}
.menu-card:hover{border-color:var(--ink);box-shadow:0 14px 34px rgba(27,27,27,.08)}
.menu-card:hover::after{transform:translateX(6px);color:var(--accent)}
.menu-card .m-en{font-size:18px;font-weight:600;letter-spacing:.12em}
.menu-card .m-jp{margin-top:2px;font-size:14px;font-weight:700;letter-spacing:.08em}
.menu-card p{margin-top:12px;color:var(--muted);font-size:12.5px;line-height:1.9}
.menu-card.has-ext{padding-top:54px}
.menu-card .ext{
  position:absolute;top:16px;right:16px;font-size:10px;color:var(--muted);
  letter-spacing:.15em;border:1px solid var(--line);padding:2px 8px;
  background:#fff;
}

/* ---------- 下層ページ：表組み・リスト ---------- */
.content-block{max-width:840px;margin:0 auto}
.content-block h3{
  font-size:16px;font-weight:700;letter-spacing:.14em;
  padding-bottom:12px;margin:48px 0 22px;border-bottom:1px solid var(--ink);
}
.content-block h3:first-child{margin-top:0}
dl.spec-list{display:grid;grid-template-columns:9em 1fr;row-gap:12px;font-size:14px}
dl.spec-list dt{color:var(--muted)}
.history li{
  list-style:none;display:grid;grid-template-columns:9em 1fr;
  padding:10px 0;border-bottom:1px dashed var(--line);font-size:13.5px;
}
.history li span{color:var(--gold);font-weight:500}

/* PDF・動画リスト */
.dl-list{list-style:none}
.dl-list li{border-bottom:1px solid var(--line)}
.dl-list a{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 8px;transition:.25s;font-size:14.5px;font-weight:500;
}
.dl-list a:hover{background:var(--bg-soft);color:var(--accent)}
.dl-list .pdf-icon{
  flex:0 0 auto;font-size:10.5px;letter-spacing:.15em;color:#fff;
  background:var(--accent);padding:3px 10px;
}
.note{color:var(--muted);font-size:12.5px;margin-top:20px;line-height:1.9}

/* 動画（サムネイル→YouTubeへ） */
.movie-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px}
.movie-item h4{font-size:14.5px;font-weight:700;margin-bottom:12px;letter-spacing:.06em}
.movie-item .frame{
  position:relative;display:block;aspect-ratio:16/9;overflow:hidden;
  border:1px solid var(--line);background:#000;
}
.movie-item .frame img{width:100%;height:100%;object-fit:cover;transition:.3s}
.movie-item .frame:hover img{opacity:.75;transform:scale(1.03)}
.movie-item .play{
  position:absolute;inset:0;margin:auto;width:64px;height:44px;
  background:rgba(163,22,33,.92);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
}
.movie-item .play::after{
  content:"";border-style:solid;border-width:10px 0 10px 17px;
  border-color:transparent transparent transparent #fff;margin-left:3px;
}

/* お問い合わせ */
.contact-box .tel{font-size:26px;font-weight:700;letter-spacing:.06em}
.contact-box .tel small{font-size:12px;color:var(--muted);font-weight:400;margin-left:10px}
.contact-box p{font-size:14px;margin-bottom:14px}
.en-note{color:var(--muted);font-size:12px;line-height:1.7;margin-top:18px;border-top:1px dashed var(--line);padding-top:14px}

/* ---------- 画像の拡大表示（ライトボックス） ---------- */
.news-card .thumb img,
.news-card details img{cursor:zoom-in}
.lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(20,20,20,.86);
  display:flex;align-items:center;justify-content:center;
  padding:24px;cursor:zoom-out;
}
.lightbox img{
  max-width:min(92vw,980px);max-height:88vh;
  width:auto;height:auto;
  background:#fff;padding:10px;
  box-shadow:0 20px 60px rgba(0,0,0,.45);
}

/* ---------- LINE固定ボタン ---------- */
.line-fab{
  position:fixed;right:20px;bottom:20px;z-index:90;
  display:flex;align-items:center;gap:8px;
  background:#06C755;color:#fff;font-size:12.5px;font-weight:700;
  padding:12px 18px;border-radius:999px;
  box-shadow:0 6px 18px rgba(0,0,0,.18);transition:.3s;letter-spacing:.05em;
}
.line-fab:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.25)}

/* ---------- フッター ---------- */
footer{background:var(--ink);color:#cfcabe;padding:50px 0 28px;font-size:12.5px}
.foot-inner{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:center}
.foot-brand{font-size:18px;letter-spacing:.2em;color:#fff}
.foot-brand small{font-size:11px;color:#8a857a;margin-left:10px}
.foot-brand img{height:26px;width:auto;display:block}
.foot-nav{display:flex;gap:26px;flex-wrap:wrap}
.foot-nav a:hover{color:#fff}
.copyright{margin-top:32px;text-align:center;color:#8a857a;letter-spacing:.1em;font-size:11px}

/* ---------- スマートフォン対応 ---------- */
@media (max-width:980px){
  .menu-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .header-inner{height:58px}
  .brand img{height:32px}
  .brand .tagline{display:none}
  nav.global{gap:14px;font-size:11px}
  section{padding:56px 0}
  .news-card{flex-basis:260px}
  .menu-grid{grid-template-columns:1fr}
  dl.spec-list{grid-template-columns:7em 1fr}
  .history li{grid-template-columns:7em 1fr}
}
