/* ============================================================
   梅里カントリークラブ｜TRACKMAN RANGE × Spectrum
   シネマティック黒白システム（本気で練習したい層向け）
   タイポ: Oswald（英字ディスプレイ）＋ Noto Sans JP
   ============================================================ */

:root{
  --orange:#F26A1B;
  --orange-d:#D2570F;
  --green:#07913F;
  --green-d:#05702F;
  --green-lt:#2FB862;
  --blue:#16A6E0;
  --blue-d:#0B82B8;
  --yellow:#F2C200;

  --black:#0A0B0D;
  --panel:#121417;
  --panel2:#16191D;
  --line:rgba(255,255,255,.12);

  --paper:#FFFFFF;
  --paper2:#F4F5F6;
  --ink:#16191D;
  --ink2:#3c434a;
  --muted:#6f767d;
  --muted-d:#9aa1a7;

  --col:1180px;
  --eng:"Oswald",-apple-system,Arial,sans-serif;
  --jp:"Noto Sans JP",-apple-system,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--jp);background:var(--black);color:#fff;line-height:1.9;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
/* mobile-friendly Japanese line breaks */
h1,h2,h3,h4{text-wrap:balance;line-break:strict}
p,figcaption,.lp-label,.assure p,.cap,.cmp-sec .head p{text-wrap:pretty;line-break:strict}
.nb{display:inline-block}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* ---------- display type ---------- */
.disp{font-family:var(--eng);font-weight:300;letter-spacing:.18em;text-transform:uppercase;line-height:1}
.disp-b{font-family:var(--eng);font-weight:500;letter-spacing:.14em;text-transform:uppercase;line-height:1}
.eyebrow{font-family:var(--eng);font-weight:500;font-size:13px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted-d)}
.eyebrow.o{color:var(--orange)}
.eyebrow.b{color:var(--blue)}
.eyebrow.g{color:var(--muted-d)}
.jp-head{font-family:var(--jp);font-weight:900;letter-spacing:-.01em;line-height:1.5}
.accent{color:var(--orange)}
.accent-b{color:var(--blue)}
.accent-g{color:#fff}

/* ---------- layout ---------- */
.wrap{max-width:var(--col);margin:0 auto;padding:0 28px}
/* アンカー移動時に固定ヘッダーで見出しが隠れないように */
html{scroll-behavior:smooth}
[id]{scroll-margin-top:74px}
/* スクロールで各ブロックがふわっと出現（JSで .in 付与）*/
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.6,.2,1),transform .7s cubic-bezier(.2,.6,.2,1);will-change:opacity,transform}
.reveal.in{opacity:1;transform:none}
.sec{padding:96px 0}
section{position:relative}
.bg-black{background:var(--black)}
.bg-panel{background:var(--panel)}
.bg-paper{background:var(--paper);color:var(--ink)}
.bg-paper2{background:var(--paper2);color:var(--ink)}

/* ---------- buttons (ghost outline = signature) ---------- */
.btn{font-family:var(--jp);display:inline-flex;align-items:center;justify-content:center;gap:12px;min-height:58px;padding:0 34px;font-weight:700;font-size:15px;letter-spacing:.02em;cursor:pointer;border:1px solid transparent;transition:background .18s,border-color .18s,color .18s,transform .15s;text-align:center;line-height:1.3}
.btn:active{transform:translateY(1px)}
.btn .arr{font-family:var(--eng);font-weight:400;font-size:17px}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{background:#fff;color:var(--black);border-color:#fff}
.btn-ghost-d{background:transparent;border-color:rgba(0,0,0,.32);color:var(--ink)}
.btn-ghost-d:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-orange:hover{background:var(--orange-d);border-color:var(--orange-d)}
.btn-green{background:#fff;color:var(--black);border-color:#fff}
.btn-green:hover{background:#e7e9eb;border-color:#e7e9eb}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-orange:hover{background:var(--orange-d);border-color:var(--orange-d)}
.btn-orange .arr{color:#fff}
.btn-block{width:100%}

/* ---------- Google Reviews（横スライド・伏せ字・Googleアイコン）---------- */
.rv-source{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--muted);margin-top:10px}
.rv-source .g-logo{width:18px;height:18px;flex:0 0 auto}
.rv-stars{color:#F5A623;letter-spacing:.06em;font-size:15px;line-height:1}
/* 横に流れるマーキー（中央寄せ・端はフェード） */
.reviews-marquee{overflow:hidden;position:relative;width:100vw;left:50%;transform:translateX(-50%);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.reviews-track{display:flex;gap:14px;width:max-content;padding:6px 14px;animation:reviews-scroll 48s linear infinite}
.reviews-marquee:hover .reviews-track{animation-play-state:paused}
@keyframes reviews-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.review{flex:0 0 auto;width:285px;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:14px;padding:20px;box-shadow:0 10px 30px -18px rgba(0,0,0,.25);margin:0;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block}
.review:hover{transform:translateY(-3px);box-shadow:0 16px 36px -18px rgba(0,0,0,.32)}
.review p{font-size:13.5px;line-height:1.8;color:var(--ink2);margin:8px 0 12px;font-weight:500}
.review cite{font-style:normal;font-size:12px;color:var(--muted);font-weight:700}
@media (prefers-reduced-motion:reduce){.reviews-marquee{overflow-x:auto;-webkit-overflow-scrolling:touch}.reviews-track{animation:none}}

/* ---------- 施設の特徴チェックリスト ---------- */
.facility-feats{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 22px;padding:0}
.facility-feats li{font-size:12.5px;font-weight:700;color:var(--ink2);background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:999px;padding:7px 13px}
.facility-feats li::before{content:"✓";color:var(--orange);font-weight:900;margin-right:5px}

.txtlink{display:inline-flex;align-items:center;gap:10px;font-family:var(--jp);font-weight:700;font-size:14.5px;letter-spacing:.02em;color:var(--orange)}
.txtlink.b{color:var(--blue-d)}
.txtlink .arr{font-family:var(--eng)}
.txtlink:hover{gap:15px;transition:gap .15s}

/* ---------- header ---------- */
.hd{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:rgba(10,11,13,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:background .25s,padding .25s}
.hd.solid{background:rgba(10,11,13,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:12px 28px}
.hd .logo{display:flex;align-items:center;gap:13px}
.hd .logo img{height:34px;width:auto}
.hd .logo .txt{display:none;flex-direction:column;line-height:1.1}
.hd nav{display:none;gap:30px;align-items:center}
.hd nav a{font-family:var(--eng);font-weight:500;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:#d7dbde;transition:color .15s}
.hd nav a:hover{color:#fff}
.hd nav a.cur{color:#fff}
.hd .hd-cta{font-family:var(--eng);font-weight:500;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;border:1px solid #fff;background:#fff;padding:9px 18px;color:var(--black);transition:.18s}
.hd .hd-cta:hover{background:transparent;color:#fff}
/* ヘッダーの料金は小さめテキストリンク（主CTA=ルートと競合させない） */
.hd .hd-text{font-family:var(--jp);font-weight:500;font-size:13px;letter-spacing:.04em;color:#eef1f3;padding:6px 2px;border-bottom:1px solid rgba(255,255,255,.45);transition:.18s}
.hd .hd-text:hover{color:#fff;border-bottom-color:#fff}

/* ---------- HERO（広角フォト＋没入背景：写真を下まで継続）---------- */
/* ヘッダー（固定）の高さ分を空け、写真をヘッダーの下から始める＝焼き込み数字とロゴが被らない */
.hero{position:relative;display:block;overflow:hidden;padding-top:62px;background:#000}
/* アンビエント背景：同じ写真を暗くぼかして全体に敷く＝写真→黒の完全分離を防ぎ1枚の世界観に */
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:url(../img/umesato-driving-range-hiyoshi.jpg) center 32%/cover no-repeat;filter:blur(22px) brightness(.34);transform:scale(1.12)}
.hero::after{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,rgba(8,9,11,.22) 0%,rgba(8,9,11,.5) 56%,rgba(8,9,11,.9) 100%)}
/* 広角フォト：全景をズームせず見せる（横長を活かし側面の切り落としを最小化） */
.hero-photo{position:relative;z-index:1;margin:0;width:100%;aspect-ratio:3/2;overflow:hidden}
.hero-photo img,.hero-photo video{width:100%;height:100%;object-fit:cover;object-position:50% 46%;display:block}
/* 写真の下端をアンビエントへ溶かす（黒への完全分離を防ぐ） */
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,11,.26) 0%,rgba(8,9,11,0) 24%,rgba(8,9,11,0) 60%,rgba(8,9,11,.72) 100%)}
/* 文字エリア：背景透過でアンビエント写真を見せる（没入感） */
.hero-body{position:relative;z-index:2;background:transparent;padding:26px 0 46px}
.hero-kicker{font-family:var(--eng);font-weight:300;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.7);margin:0 0 18px}
.hero-title{font-family:var(--jp);font-weight:500;font-size:clamp(25px,6.5vw,46px);line-height:1.5;letter-spacing:.04em;color:#fff;margin:0}
.hero-title .nb{white-space:nowrap}
/* EQUIPPED WITH：縦組み（ラベル / ロゴ行 / 全75打席）。2機器を同格に近づける */
.hero-equip{display:flex;flex-direction:column;align-items:flex-start;gap:18px;margin:24px 0 0}
.hero-equip .eq-item{display:flex;flex-direction:column;align-items:flex-start;gap:9px}
.hero-equip .eq-link{text-decoration:none;color:inherit;cursor:pointer;transition:opacity .2s}
.hero-equip .eq-link:hover{opacity:.78}
.hero-equip .eq-lab{font-family:var(--eng);font-weight:500;font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted-d)}
/* 3ブランドを1行に並べる＋薄グレーの帯（横幅が出るためロゴは小さめで均衡）*/
/* 薄グレー帯：画面いっぱい（フルブリード）*/
.hero-equip .eq-row{position:relative;left:50%;transform:translateX(-50%);width:100vw;display:flex;align-items:center;justify-content:center;flex-wrap:nowrap;gap:12px;background:rgba(255,255,255,.07);border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);padding:13px 20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.hero-equip .b-tt{height:21px;width:auto;flex:0 0 auto}
.hero-equip .eq-tt-link{display:inline-block;line-height:0;transition:opacity .2s}
.hero-equip .eq-tt-link:hover{opacity:.8}
/* TRACKMAN RANGE：Trackman社ではなく製品名。横幅を取りすぎるロゴは縮小しRANGEを詰める */
.hero-equip .tmlock{display:inline-flex;align-items:baseline;gap:3px;flex:0 0 auto}
.hero-equip .tmlock .b-tm{height:10px;width:auto}
.hero-equip .tmlock .rg{font-family:var(--eng);font-weight:500;font-size:7px;letter-spacing:.1em;color:#fff;text-transform:uppercase}
.hero-equip .x{color:rgba(255,255,255,.6);font-family:var(--eng);font-weight:300;font-size:13px;line-height:1;flex:0 0 auto}
.hero-equip .b-sp{height:27px;width:auto;flex:0 0 auto}
.hero-equip .eq-units{font-family:var(--jp);font-weight:500;font-size:13px;letter-spacing:.1em;color:rgba(255,255,255,.82);margin:0}
.lp-tech-tm{display:inline-flex;align-items:baseline;gap:5px;margin-top:3px;justify-content:center}
.lp-tech-tm img{height:11px;width:auto;filter:drop-shadow(0 1px 3px rgba(0,0,0,.7))}
.lp-tech-tm b{font-family:var(--eng);font-weight:500;font-size:8px;letter-spacing:.14em;color:#fff;text-transform:uppercase}
.tm-rangelock{display:flex;align-items:baseline;gap:9px;margin-bottom:18px}
.tm-rangelock .brand-logo{height:20px;width:auto;display:block;margin:0}
.tm-rangelock b{font-family:var(--eng);font-weight:500;font-size:13px;letter-spacing:.22em;color:#fff;text-transform:uppercase}
.hero-units{font-family:var(--jp);font-weight:500;font-size:13px;letter-spacing:.1em;color:rgba(255,255,255,.78);margin:12px 0 0}
.hero-cta{display:flex;flex-direction:column;align-items:flex-start;gap:18px;margin-top:30px}
.lux-btn{display:inline-flex;align-items:center;justify-content:center;gap:16px;min-width:220px;font-family:var(--jp);font-weight:500;font-size:15px;letter-spacing:.06em;color:#fff;padding:16px 32px;border:1px solid rgba(255,255,255,.62);background:transparent;transition:background .22s,color .22s,border-color .22s}
.lux-btn:hover{background:#fff;color:var(--black);border-color:#fff}
.lux-btn .arr{font-family:var(--eng);font-weight:300;font-size:17px}
.lux-link{font-family:var(--jp);font-weight:400;font-size:14px;letter-spacing:.04em;color:rgba(255,255,255,.85);border-bottom:1px solid rgba(255,255,255,.38);padding-bottom:3px;transition:color .2s,border-color .2s}
.lux-link:hover{color:#fff;border-bottom-color:#fff}

/* ---------- equipped strip ---------- */
.equip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--panel2)}
.equip .row{display:flex;align-items:center;justify-content:center;gap:clamp(24px,6vw,64px);flex-wrap:wrap;padding:26px 28px}
.equip .lab{font-family:var(--eng);font-weight:500;font-size:12px;letter-spacing:.3em;color:var(--muted)}
.equip img.tm{height:24px;opacity:.92}
.equip img.sp{height:30px;opacity:.95}
.equip .div{width:1px;height:30px;background:var(--line)}

/* ---------- split block (image + text) ---------- */
.split{display:grid;grid-template-columns:1fr;gap:0}
.split .media{position:relative;min-height:64vw;overflow:hidden}
.split .media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
#fitting .media img{object-position:center 18%}
.split .media.contain{background:#0e1013;display:flex;align-items:center;justify-content:center;min-height:auto;padding:32px}
.split .media.contain img{position:static;width:100%;height:auto;object-fit:contain}
.split .media.contain.unit{background:radial-gradient(ellipse 70% 60% at 50% 42%,#22262c 0%,#15171b 48%,#0c0d10 100%);padding:44px 32px}
.split .media.contain.unit img{max-height:380px;width:auto;max-width:100%;filter:drop-shadow(0 30px 50px rgba(0,0,0,.55))}
.split .copy{padding:60px 28px}
.split .copy .eyebrow{display:inline-block;margin-bottom:16px}
.split .copy h2{font-family:var(--jp);font-weight:900;font-size:clamp(24px,5.4vw,34px);line-height:1.5;letter-spacing:-.01em;margin-bottom:18px}
.split .copy p{font-size:15px;line-height:2;color:#cfd4d8;margin-bottom:14px}
.bg-paper .split .copy p,.bg-paper2 .split .copy p{color:var(--ink2)}
.split .copy .btn,.split .copy .txtlink{margin-top:14px}
.split .copy>img,.split .copy .brand-logo{align-self:flex-start;width:auto;max-width:100%}
.tt-badge{display:inline-flex;align-items:center;gap:9px;margin-top:6px;background:rgba(242,106,27,.12);border:1px solid rgba(242,106,27,.45);border-radius:999px;padding:9px 16px;font-family:var(--jp);font-weight:700;font-size:12.5px;color:#f6c8a8;letter-spacing:.01em}
.tt-badge b{font-family:var(--eng);font-weight:600;letter-spacing:.04em;color:var(--orange);font-size:13.5px}
.tt-note{font-size:11px!important;line-height:1.7!important;color:var(--muted-d)!important;margin-top:12px!important}

/* ---------- Titleist-branded fitting section ---------- */
.bg-titleist{background:#0a0a0b;position:relative}
.bg-titleist::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#cf102d;z-index:2}
.bg-titleist .copy h2{font-family:var(--jp);font-weight:900;font-size:clamp(23px,5.2vw,33px);line-height:1.5;letter-spacing:-.01em;margin-bottom:18px;color:#fff}
.bg-titleist .copy p{color:#c7cace}
.bg-titleist .copy p b{color:#fff}
.tt-red{color:#e1112f}
.tt-logo{height:50px;width:auto;max-width:100%;align-self:flex-start;display:block;margin-bottom:22px}
.tt-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12);border-radius:10px;overflow:hidden;margin:22px 0 8px}
.tt-stat{background:#121214;padding:18px 10px;text-align:center;display:flex;flex-direction:column;gap:7px;align-items:center}
.tt-stat .n{font-family:var(--eng);font-weight:600;font-size:26px;line-height:1;color:#e1112f}
.tt-stat .l{font-family:var(--jp);font-weight:700;font-size:11px;line-height:1.45;color:#c7cace}
.btn-titleist{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;background:#cf102d;color:#fff;font-family:var(--jp);font-weight:700;font-size:15px;padding:16px 22px;border-radius:8px;margin-top:16px;box-shadow:0 10px 28px -12px rgba(207,16,45,.7)}
.btn-titleist .arr{font-family:var(--eng)}
.btn-titleist:hover{background:#b40d26}
.badge-free{position:absolute;z-index:3;right:18px;bottom:18px;width:96px;height:96px;border-radius:50%;background:var(--orange);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:900;font-size:18px;line-height:1.25;text-align:center;box-shadow:0 12px 30px -10px rgba(242,106,27,.7)}

/* ---------- data pills (TrackMan 8 values) ---------- */
.data-sec .head{max-width:38em;margin-bottom:34px}
.data-sec .head h2{font-family:var(--jp);font-weight:900;font-size:clamp(22px,5vw,30px);line-height:1.5;letter-spacing:-.01em}
.data-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.pills{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pill{display:flex;align-items:center;gap:10px;background:var(--orange);color:#fff;border-radius:6px;padding:13px 16px;font-weight:700;font-size:14.5px}
.pill .dot{display:flex;flex-direction:column;gap:2px;flex:0 0 auto}
.pill .dot span{width:13px;height:2px;background:rgba(255,255,255,.7);border-radius:2px}
.pill .nm{flex:1}
.pill .unit{font-family:var(--eng);font-weight:500;font-size:12px;letter-spacing:.06em;opacity:.92}
.data-shot{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#0e1013}
.data-shot img{width:100%;display:block}
.data-shot.wide{max-width:820px;margin:0 auto;position:relative;cursor:zoom-in}
/* bay photo band at top of data section (full-bleed) */
.data-sec{padding-top:0}
.bay-band{margin:0 0 44px;overflow:hidden;background:#0e1013}
.bay-band img{width:100%;height:auto;display:block;max-height:62vh;object-fit:cover;object-position:center 38%}
.zoom-hint{position:absolute;right:10px;bottom:10px;display:inline-flex;align-items:center;gap:7px;background:rgba(10,11,13,.82);color:#fff;border:1px solid rgba(255,255,255,.22);border-radius:6px;padding:7px 12px;font-family:var(--jp);font-size:12px;font-weight:700;letter-spacing:.02em;pointer-events:none;backdrop-filter:blur(3px)}
/* lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(6,7,9,.96);display:flex;flex-direction:column}
.lightbox[hidden]{display:none}
.lb-close{align-self:flex-end;margin:12px 14px 4px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2);font-size:26px;line-height:1;cursor:pointer;flex:0 0 auto}
.lb-scroll{flex:1;overflow:auto;-webkit-overflow-scrolling:touch;display:flex;align-items:center;padding:0 12px}
.lb-scroll img{min-width:880px;width:880px;max-width:none;height:auto;margin:auto;border-radius:8px}
.lb-tip{flex:0 0 auto;text-align:center;color:var(--muted-d);font-size:12px;padding:12px 0 calc(14px + env(safe-area-inset-bottom));font-weight:700}

/* ---------- spectrum feature ---------- */
.spec-shot{position:relative;border-radius:8px;overflow:hidden;border:1px solid rgba(0,0,0,.1);box-shadow:0 26px 60px -34px rgba(0,0,0,.5)}
.spec-shot img{width:100%;display:block}

/* ---------- spec band (75打席) ---------- */
.specband{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.specband .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line)}
.specband .cell{background:var(--panel);padding:40px 18px;text-align:center}
.specband .num{font-family:var(--eng);font-weight:600;color:#fff;font-size:clamp(40px,8vw,64px);line-height:1}
.specband .num small{font-size:.4em;font-weight:500;margin-left:4px;color:var(--muted-d)}
.specband .num.o{color:var(--orange)}
.specband .lab{font-size:12.5px;color:var(--muted-d);margin-top:10px;letter-spacing:.04em}

/* ---------- final CTA ---------- */
.final{position:relative;overflow:hidden;text-align:center}
.final .bg{position:absolute;inset:0;z-index:0}
.final .bg img{width:100%;height:100%;object-fit:cover;opacity:.28}
.final .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--black),rgba(10,11,13,.78) 50%,var(--black))}
.final .inner{position:relative;z-index:2}
.final h2{font-family:var(--jp);font-weight:900;font-size:clamp(26px,6.4vw,46px);line-height:1.35;margin:18px 0 14px}
.final p{font-size:15px;color:#cfd4d8;max-width:32em;margin:0 auto 28px}
.final .acts{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.final .acts .btn{min-width:220px}

/* ---------- footer ---------- */
.ft{background:var(--black);border-top:1px solid var(--line);padding:60px 0 120px}
.ft .grid{display:grid;grid-template-columns:1fr;gap:38px}
.ft .logo img{height:40px;margin-bottom:18px}
.ft .desc{font-size:13px;color:var(--muted-d);line-height:1.9}
.ft .desc a{color:#dfe3e6}
.ft .ct dt{font-family:var(--eng);font-weight:500;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.ft .ct dd{font-size:14px;color:#dfe3e6;line-height:1.9}
.ft .hours{font-size:13px;color:var(--muted-d);line-height:1.95}
.ft .hours b{color:#fff;font-weight:700}
.hours-tbl{border-collapse:collapse;font-size:13px;line-height:1.5}
.hours-tbl th{text-align:left;font-weight:700;color:#fff;padding:3px 14px 3px 0;white-space:nowrap;vertical-align:top}
.hours-tbl td{color:#dfe3e6;padding:3px 0}
.hours-tbl .hn{display:inline-block;font-size:10px;font-weight:700;color:var(--muted2);border:1px solid var(--line);border-radius:4px;padding:1px 6px;margin-left:8px}
.hours-note{font-size:11.5px;color:var(--muted-d);line-height:1.8;margin-top:12px}
.ft .tm{margin-top:40px;border-top:1px solid var(--line);padding-top:20px;font-size:11px;color:var(--muted);line-height:1.8}

/* ---------- sticky bottom CTA ---------- */
.sticky{position:fixed;left:0;right:0;bottom:0;z-index:90;display:grid;grid-template-columns:1fr 1.3fr;gap:9px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:rgba(10,11,13,.94);backdrop-filter:blur(12px);border-top:1px solid var(--line);transform:translateY(120%);transition:transform .32s cubic-bezier(.4,0,.2,1)}
.sticky.show{transform:translateY(0)}
.sticky .btn{min-height:52px;font-size:14px;padding:0 16px}

img[data-photo].missing{opacity:.001}

/* ---------- spectrum pictograms ---------- */
.picto-sec .head{text-align:center;max-width:34em;margin:0 auto 36px}
.picto-sec .head h2{font-family:var(--jp);font-weight:900;font-size:clamp(22px,5vw,30px);line-height:1.5;letter-spacing:-.01em}
.picto-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.picto{display:flex;flex-direction:row;align-items:center;text-align:left;gap:13px;padding:16px 16px;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;box-shadow:0 10px 26px -20px rgba(0,0,0,.4)}
.picto .ic{width:42px;height:42px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:9px;box-sizing:border-box;background:rgba(22,166,224,.10);border-radius:11px;color:var(--blue-d)}
.picto .ic svg{width:100%;height:100%;display:block}
.picto .ic .golf-img{width:100%;height:100%;object-fit:contain;display:block}
.picto .t{font-family:var(--jp);font-weight:700;font-size:12.5px;line-height:1.5;color:var(--ink);letter-spacing:.005em}
.picto-note{font-size:11.5px;color:var(--muted);margin-top:18px;text-align:center}
.picto-2cam{display:inline-flex;align-items:center;gap:9px;background:rgba(22,166,224,.1);border:1px solid rgba(22,166,224,.42);border-radius:999px;padding:11px 20px;font-size:12.5px;font-weight:700;color:var(--blue-d);line-height:1.4}
.picto-2cam b{color:var(--blue);font-family:var(--eng);font-weight:600;letter-spacing:.05em}
/* trackman app poster */
.app-poster{max-width:480px;margin:0 auto;border-radius:14px;overflow:hidden;box-shadow:0 30px 70px -34px rgba(0,0,0,.8)}
.app-poster img{width:100%;display:block}
/* spectrum section bay-scene background */
.has-baybg{position:relative;overflow:hidden}
.has-baybg .spec-bg{position:absolute;inset:0;z-index:0}
.has-baybg .spec-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.has-baybg .spec-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(245,246,247,.93) 0%,rgba(245,246,247,.82) 42%,rgba(245,246,247,.9) 100%)}
.has-baybg .wrap{position:relative;z-index:1}
.has-baybg .picto{box-shadow:0 12px 30px -18px rgba(0,0,0,.4)}
.has-baybg .spec-video{box-shadow:0 24px 56px -24px rgba(0,0,0,.6)}
/* spectrum video (GIF) — prominent, centered, above pictograms */
.spec-video{margin:0 auto 26px;max-width:760px;border-radius:10px;overflow:hidden;background:#0e1013;border:1px solid rgba(0,0,0,.08);box-shadow:0 24px 56px -34px rgba(0,0,0,.5)}
.spec-video img{width:100%;height:auto;display:block}
.spec-cap{font-family:var(--jp);font-size:12px;line-height:1.6;color:var(--muted-d);text-align:center;padding:10px 14px 0}
.spec-cap b{color:var(--blue-d)}

/* ---------- comparison table ---------- */
.cmp-sec .head{text-align:center;max-width:32em;margin:0 auto 30px}
.cmp-sec .head h2{font-family:var(--jp);font-weight:900;font-size:clamp(22px,5.2vw,32px);line-height:1.45;letter-spacing:-.01em}
.cmp-sec .head p{font-size:14px;color:var(--ink2);margin-top:12px;line-height:1.85}
.cmp-wrap{overflow:hidden;border-radius:12px;border:1px solid rgba(0,0,0,.09)}
.cmp{width:100%;border-collapse:collapse;table-layout:fixed}
.cmp th,.cmp td{padding:14px 4px;text-align:center;vertical-align:middle;border-bottom:1px solid rgba(0,0,0,.07)}
.cmp col.c-lab{width:25%}
.cmp col.c-us{width:27%}
.cmp col.c-o{width:24%}
.cmp thead th{font-family:var(--jp);font-weight:700;font-size:11.5px;line-height:1.4;color:var(--muted);vertical-align:bottom;padding-top:18px;padding-bottom:14px}
.cmp thead th.us{color:#fff;background:#23282f;font-size:11.5px;font-weight:900;padding:16px 4px}
.cmp thead th.us .nb{white-space:nowrap}
.cmp tbody th{text-align:left;padding-left:14px;font-weight:700;font-size:12px;line-height:1.4;color:var(--ink)}
.cmp td.us{background:rgba(0,0,0,.045)}
.cmp tbody tr:last-child th,.cmp tbody tr:last-child td{border-bottom:none}
.cmp .mk{font-family:var(--eng);font-weight:600;line-height:1}
.cmp .mk.o{color:var(--ink);font-size:20px}
.cmp td.us .mk.o{color:var(--ink)}
.cmp .mk.tri{color:var(--muted-d);font-size:16px}
.cmp .mk.no{color:#cfd2d5;font-size:17px}
.cmp .sm{display:block;font-family:var(--jp);font-size:10px;font-weight:700;color:var(--ink);margin-top:3px;letter-spacing:0}
.cmp-note{font-size:11.5px;color:var(--muted);margin-top:16px;text-align:center}

/* ---------- PDCA pictogram loop ---------- */
.cycle-sec{position:relative;overflow:hidden}
.cyc-bg{position:absolute;inset:0;z-index:0}
.cyc-bg img{width:100%;height:100%;object-fit:cover;opacity:.20}
.cyc-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 42%,rgba(18,20,23,.45) 0%,rgba(18,20,23,.82) 60%,var(--panel) 100%)}
.cycle-sec .wrap{position:relative;z-index:1}
.cycle-sec .head{text-align:center;max-width:32em;margin:0 auto 30px}
.cycle-sec .head h2{font-family:var(--jp);font-weight:900;font-size:clamp(22px,5.4vw,32px);line-height:1.5;letter-spacing:-.01em}
/* サイクル下：フィッティング導線（＋ 最適なクラブ選択で課題改善 → #fitting） */
.cyc-extra{position:relative;z-index:1;margin-top:34px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}
.cyc-extra .plus{font-family:var(--eng);font-weight:300;font-size:26px;line-height:1;color:var(--orange);opacity:.9}
.cyc-extra-txt{font-family:var(--jp);font-weight:700;font-size:clamp(15px,4.2vw,19px);line-height:1.55;color:#fff;margin:0}
.cyc-tt{display:inline-block;line-height:0;transition:opacity .2s}
.cyc-tt:hover{opacity:.8}
.cyc-tt img{height:36px;width:auto;opacity:.96;filter:drop-shadow(0 2px 10px rgba(0,0,0,.6))}
.cyc-extra .btn{margin-top:4px}
.loop{position:relative;width:min(360px,93vw);aspect-ratio:1;margin:40px auto 0}
.loop::before{content:"";position:absolute;inset:12%;border:2px dashed rgba(255,255,255,.16);border-radius:50%;animation:loop-spin 36s linear infinite}
/* ループ演出：点線リング回転／中央↻回転／ノードを01→05へ光が巡る */
@keyframes loop-spin{to{transform:rotate(360deg)}}
@keyframes loop-ro{to{transform:rotate(360deg)}}
@keyframes badge-glow{0%,72%,100%{box-shadow:0 8px 20px -8px rgba(0,0,0,.6)}36%{box-shadow:0 8px 20px -8px rgba(0,0,0,.6),0 0 0 5px rgba(255,255,255,.1),0 0 22px 3px rgba(255,255,255,.35)}}
.loop-center .ro{display:inline-block;animation:loop-ro 7s linear infinite}
.lp-badge{animation:badge-glow 5s ease-in-out infinite}
.lp-node:nth-of-type(1) .lp-badge{animation-delay:0s}
.lp-node:nth-of-type(2) .lp-badge{animation-delay:1s}
.lp-node:nth-of-type(3) .lp-badge{animation-delay:2s}
.lp-node:nth-of-type(4) .lp-badge{animation-delay:3s}
.lp-node:nth-of-type(5) .lp-badge{animation-delay:4s}
.loop-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:34%;aspect-ratio:1;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:2px}
.loop-center .ro{font-family:var(--eng);color:#dfe3e6;font-size:clamp(22px,7vw,30px);line-height:1}
.loop-center .t{font-family:var(--jp);font-weight:900;font-size:clamp(10px,2.8vw,12px);line-height:1.35;color:#fff;letter-spacing:.02em}
.lp-node{position:absolute;width:96px;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;margin:0;list-style:none}
.lp-badge{position:relative;width:58px;height:58px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px -8px rgba(0,0,0,.6)}
.lp-node.b .lp-badge{background:var(--blue-d)}
.lp-node.g .lp-badge{background:#fff}
.lp-node.g .lp-badge svg{color:#1b1e23}
.lp-badge svg{width:28px;height:28px;color:#fff}
.lp-ico-img{width:30px;height:30px;object-fit:contain;display:block}
.lp-badge .no{position:absolute;top:-5px;right:-5px;width:22px;height:22px;border-radius:50%;background:#fff;color:var(--orange);font-family:var(--eng);font-weight:600;font-size:10.5px;display:flex;align-items:center;justify-content:center;border:2px solid var(--panel)}
.lp-node.b .lp-badge .no{color:var(--blue-d)}
.lp-node.g .lp-badge .no{background:#23282f;color:#fff}
.lp-label{font-family:var(--jp);font-weight:700;font-size:11.5px;line-height:1.42;color:#eef0f2}
.lp-label b{color:var(--blue)}
/* first-timer reassurance */
.assure-grid{display:grid;grid-template-columns:1fr;gap:14px;max-width:560px;margin:0 auto}
.assure{display:flex;flex-direction:column;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.assure-photo{aspect-ratio:16/10;overflow:hidden;background:#0e1013}
.assure-photo img{width:100%;height:100%;object-fit:cover;display:block}
.assure-tx{padding:18px 20px}
.assure h3{font-family:var(--jp);font-weight:900;font-size:15.5px;color:#fff;margin:0 0 6px;letter-spacing:.01em}
.assure p{font-size:13px;line-height:1.75;color:var(--muted-d)}
.assure-line{display:flex;align-items:center;flex-wrap:wrap;gap:14px;max-width:560px;margin:14px auto 0;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;padding:16px 20px}
.assure-line p{flex:1 1 200px}
.btn-line{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#06C755;color:#fff;font-family:var(--jp);font-weight:700;font-size:14px;letter-spacing:.02em;padding:13px 22px;border-radius:9px;white-space:nowrap;transition:background .18s}
.btn-line:hover{background:#05b14c}
.assure-line .al-ic{flex:0 0 auto;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.07);border-radius:11px;color:#fff}
.assure-line .al-ic svg{width:23px;height:23px}
.assure-line .al-ic.line{background:none;width:46px;height:46px;border-radius:0}
.assure-line .al-ic.line img{width:100%;height:100%;object-fit:contain;display:block}
.assure-line p{font-size:13px;line-height:1.7;color:var(--muted-d)}
.assure-line p b{color:#fff;font-weight:700}
.lp-tech{height:17px;width:auto;margin-top:3px;opacity:1;filter:drop-shadow(0 1px 3px rgba(0,0,0,.7))}
.loop-note{text-align:center;margin-top:8px;display:flex;flex-direction:column;align-items:center;gap:9px}
.loop-note .tag.o{background:rgba(242,106,27,.12);border-color:rgba(242,106,27,.4);color:#f3c4a4}
.loop-note .tag.o b{color:var(--orange)}
.loop-note .tag{display:inline-flex;align-items:center;gap:9px;background:rgba(22,166,224,.12);border:1px solid rgba(22,166,224,.4);border-radius:999px;padding:10px 18px;font-size:12.5px;font-weight:700;color:#bfe6f7;line-height:1.4}
.loop-note .tag b{color:var(--blue);font-family:var(--eng);font-weight:600;letter-spacing:.04em}

/* ---------- desktop ---------- */
@media (min-width:760px){
  .hero{padding-top:72px}
  .hero-photo{aspect-ratio:16/7;max-height:74vh}
  .hero-body{padding:44px 0 60px}
  .hero-title{font-size:clamp(38px,4.4vw,60px);line-height:1.45}
  .hero-equip .eq-lab{font-size:11px}
  .hero-equip .eq-row{gap:20px}
  .hero-equip .tmlock .b-tm{height:14px}
  .hero-equip .b-sp{height:40px}
  .hero-equip .b-tt{height:40px}
  .hero-cta{flex-direction:row;align-items:center;gap:26px}
  .hd .logo .txt{display:flex}
  .hd .logo .txt b{font-weight:900;font-size:15px}
  .hd .logo .txt span{font-family:var(--eng);font-size:9px;letter-spacing:.22em;color:var(--muted-d);text-transform:uppercase}
  .hd nav{display:flex}
  .hero .lead{font-size:16px}
  .split{grid-template-columns:1fr 1fr;align-items:stretch}
  .split.rev .media{order:2}
  .split .media{min-height:560px}
  .split .copy{padding:84px 56px;display:flex;flex-direction:column;justify-content:center}
  .split.wrap-pad .copy{padding:84px clamp(28px,5vw,90px)}
  .data-grid{grid-template-columns:1.05fr .95fr;gap:48px}
  .specband .grid{grid-template-columns:repeat(4,1fr)}
  .specband .cell{padding:56px 20px}
  .ft .grid{grid-template-columns:1.4fr 1fr 1.1fr;gap:48px}
  .sticky{display:none}
  .picto-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .picto{padding:20px 18px;gap:15px}
  .picto .ic{width:48px;height:48px;padding:11px}
  .picto .t{font-size:14px}
  .cmp th,.cmp td{padding:20px 10px}
  .cmp thead th{font-size:14px}
  .cmp thead th.us{font-size:16px}
  .cmp tbody th{font-size:15px;padding-left:24px}
  .cmp .mk.o{font-size:26px}
  .cmp-wrap{max-width:880px;margin:0 auto}
  .loop{width:440px}
  .loop-center .t{font-size:13px}
  .lp-node{width:118px;gap:11px}
  .lp-badge{width:68px;height:68px}
  .lp-badge svg{width:32px;height:32px}
  .lp-label{font-size:13px}
  .lp-tech{height:20px}
  .assure-grid{grid-template-columns:repeat(3,1fr);gap:16px;max-width:980px}
  .reviews-grid{grid-template-columns:1fr 1fr;gap:16px}
  .assure-tx{padding:22px 22px}
  .assure-line{max-width:980px}
  .lp-ico-img{width:34px;height:34px}
}
@media (min-width:760px) and (max-width:1100px){ .hd nav{gap:20px} }

@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}}
