/*
Theme Name: K2 Salon
Theme URI: https://k-2.salon
Author: K2 Corporation
Description: Hair Salon K2 ＆ Beauty Salon K2 公式サイト用テーマ（黒×ゴールド ラグジュアリーデザイン）
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: k2-salon
*/

:root {
  --bg: #050403;
  --bg2: #0c0a07;
  --gold: #c9a566;
  --gold-l: #e8d5ae;
  --ink: #f2ede3;
  --gray: #b9b2a6;
  --line: rgba(201,165,102,.35);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: "Shippori Mincho", "Noto Serif CJK JP", "Hiragino Mincho ProN", serif;
  font-size: 16px;
  line-height: 2;
  letter-spacing: .08em;
  -webkit-font-smoothing: antialiased;
}
img { display:block; width:100%; height:auto; }
a { color: var(--gold-l); text-decoration:none; transition: opacity .3s; }
a:hover { opacity:.7; }
.en { font-family: "Cormorant Garamond", "Garamond", serif; }

/* ===== Header ===== */
header {
  position: fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding: 18px 36px;
  background: linear-gradient(180deg, rgba(5,4,3,.92), rgba(5,4,3,.65) 70%, transparent);
  backdrop-filter: blur(4px);
}
.logo { font-size:26px; letter-spacing:.18em; color:#fff; }
.logo span { color: var(--gold-l); }
nav { display:flex; gap:30px; font-size:13px; letter-spacing:.22em; }
nav a { color: var(--ink); }
.nav-reserve {
  border:1px solid var(--gold); color: var(--gold-l); padding: 8px 22px;
  font-size:12px; letter-spacing:.3em;
}
@media (max-width:820px){ nav { display:none; } }

/* ===== Hero ===== */
.hero { position:relative; }
.hero img { width:100%; }
.hero-scroll {
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
  font-size:11px; letter-spacing:.5em; color:var(--gold); padding-left:.5em;
}
.hero-scroll::after {
  content:""; display:block; width:1px; height:42px; margin:10px auto 0;
  background: linear-gradient(180deg, var(--gold), transparent);
}

/* ===== Shared section pieces ===== */
section { padding: 110px 24px; position:relative; }
.inner { max-width: 1040px; margin: 0 auto; }
.eyebrow {
  font-size:13px; letter-spacing:.55em; color:var(--gold);
  text-transform:uppercase; text-align:center; padding-left:.55em;
}
h2 {
  font-size: clamp(26px, 4vw, 38px); font-weight:600; letter-spacing:.16em;
  text-align:center; margin: 18px 0 0; color:#fff;
}
.divider { display:flex; align-items:center; justify-content:center; gap:14px; margin:34px auto; }
.divider i { width:90px; height:1px; }
.divider .l1 { background: linear-gradient(90deg, transparent, var(--gold)); }
.divider .l2 { background: linear-gradient(90deg, var(--gold), transparent); }
.divider b { width:8px; height:8px; background:var(--gold); transform:rotate(45deg); }
.lead { text-align:center; color:var(--gray); max-width: 640px; margin:0 auto; }

/* ===== Concept ===== */
.concept { background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(201,165,102,.07), transparent 60%); }
.concept-copy {
  text-align:center; font-size: clamp(19px, 2.6vw, 24px); letter-spacing:.2em;
  line-height: 2.6; color:#fff; margin-bottom: 36px;
}

/* ===== Salon cards ===== */
.salons { display:grid; grid-template-columns:1fr 1fr; gap:48px; margin-top:64px; }
@media (max-width:820px){ .salons { grid-template-columns:1fr; } }
.salon-card { border:1px solid var(--line); padding:14px; background:var(--bg2); }
.salon-card figure { overflow:hidden; }
.salon-card img { transition: transform .6s ease; }
.salon-card:hover img { transform: scale(1.03); }
.salon-body { padding: 30px 20px 24px; }
.salon-body h3 { font-size:21px; letter-spacing:.14em; color:var(--gold-l); font-weight:600; }
.salon-body .en-sub { font-size:12px; letter-spacing:.4em; color:var(--gold); margin-top:6px; }
.salon-body p { font-size:14.5px; color:var(--gray); margin-top:18px; }
.salon-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:20px; }
.salon-tags span {
  font-size:11px; letter-spacing:.18em; color:var(--gold-l);
  border:1px solid var(--line); padding:4px 12px;
}

/* ===== Feature (Rune Chair) ===== */
.feature { background: var(--bg2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.feature-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap:60px; align-items:center; margin-top:60px; }
@media (max-width:820px){ .feature-grid { grid-template-columns:1fr; gap:36px; } }
.feature-grid figure { border:1px solid var(--line); padding:12px; }
.feature-text h3 { font-size:24px; color:#fff; letter-spacing:.14em; font-weight:600; line-height:1.7; }
.feature-text h3 em { font-style:normal; color:var(--gold-l); }
.feature-text p { font-size:14.5px; color:var(--gray); margin-top:22px; }
.feature-points { list-style:none; margin-top:26px; }
.feature-points li {
  font-size:14px; color:var(--ink); padding:13px 0 13px 26px; position:relative;
  border-bottom:1px solid rgba(201,165,102,.18);
}
.feature-points li::before {
  content:""; position:absolute; left:4px; top:24px; width:7px; height:7px;
  background:var(--gold); transform:rotate(45deg);
}

/* ===== Subscription ===== */
.subsc-box {
  max-width:760px; margin:60px auto 0; border:1px solid var(--gold);
  padding:54px 36px; text-align:center; position:relative; background:var(--bg);
}
.subsc-box::before, .subsc-box::after {
  content:""; position:absolute; width:34px; height:34px; border-color:var(--gold-l);
}
.subsc-box::before { top:-1px; left:-1px; border-top:2px solid var(--gold-l); border-left:2px solid var(--gold-l); }
.subsc-box::after { bottom:-1px; right:-1px; border-bottom:2px solid var(--gold-l); border-right:2px solid var(--gold-l); }
.subsc-price { font-size: clamp(40px, 6vw, 58px); color:var(--gold-l); letter-spacing:.06em; margin:14px 0 4px; }
.subsc-price small { font-size:.4em; color:var(--gray); letter-spacing:.2em; }
.subsc-note { font-size:13px; color:var(--gray); margin-top:20px; }

/* ===== Menu ===== */
.menu-cols { display:grid; grid-template-columns:1fr 1fr; gap:60px; margin-top:60px; }
@media (max-width:820px){ .menu-cols { grid-template-columns:1fr; } }
.menu-col h3 {
  font-size:15px; letter-spacing:.4em; color:var(--gold); font-weight:500;
  border-bottom:1px solid var(--line); padding-bottom:14px; margin-bottom:6px; text-align:center;
}
.menu-row { display:flex; justify-content:space-between; align-items:baseline; gap:14px;
  padding:15px 4px; border-bottom:1px solid rgba(201,165,102,.16); font-size:14.5px; }
.menu-row .name { color:var(--ink); }
.menu-row .dots { flex:1; border-bottom:1px dotted rgba(201,165,102,.4); transform:translateY(-4px); }
.menu-row .price { color:var(--gold-l); white-space:nowrap; }
.menu-note { text-align:center; font-size:12.5px; color:var(--gray); margin-top:34px; }

/* ===== News ===== */
.news-list { max-width:760px; margin:50px auto 0; }
.news-item { display:flex; gap:28px; padding:20px 6px; border-bottom:1px solid rgba(201,165,102,.18); font-size:14.5px; }
.news-item time { color:var(--gold); letter-spacing:.12em; white-space:nowrap; }
@media (max-width:600px){ .news-item { flex-direction:column; gap:4px; } }

/* ===== Access ===== */
.access-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; margin-top:60px; }
@media (max-width:820px){ .access-grid { grid-template-columns:1fr; } }
.access-grid figure { border:1px solid var(--line); padding:12px; }
.access-table { width:100%; border-collapse:collapse; font-size:14.5px; }
.access-table th, .access-table td { text-align:left; padding:15px 6px; border-bottom:1px solid rgba(201,165,102,.18); vertical-align:top; }
.access-table th { color:var(--gold); font-weight:500; letter-spacing:.2em; width:7.5em; white-space:nowrap; }
.access-table td { color:var(--ink); }

/* ===== CTA / Footer ===== */
.cta { text-align:center; background: radial-gradient(ellipse 70% 80% at 50% 100%, rgba(201,165,102,.1), transparent 60%); }
.cta-btn {
  display:inline-block; margin-top:44px; border:1px solid var(--gold);
  padding:18px 70px; font-size:14px; letter-spacing:.4em; color:var(--gold-l);
  transition: background .3s, color .3s;
}
.cta-btn:hover { background:var(--gold); color:#000; opacity:1; }
footer { border-top:1px solid var(--line); padding:54px 24px 40px; text-align:center; }
footer .logo { font-size:22px; }
footer p { font-size:12px; color:var(--gray); margin-top:16px; letter-spacing:.14em; }
footer .copy { font-size:11px; color:rgba(185,178,166,.55); margin-top:30px; letter-spacing:.3em; }

.sample-band {
  position:fixed; bottom:14px; right:-44px; transform:rotate(-45deg); z-index:200;
  background:var(--gold); color:#000; font-size:11px; letter-spacing:.3em;
  padding:5px 56px; opacity:.85; pointer-events:none;
}
