:root {
  --bg: #fffdfa;
  --bg-soft: #faf5eb;
  --ink: #322d27;
  --muted: #74685d;
  --gold: #b18a49;
  --gold-deep: #96723a;
  --line: #e6d6ba;
  --footer: #403a33;
  --serif: "Noto Serif JP", "Hiragino Mincho ProN", serif;
  --display: "Cormorant Garamond", Georgia, serif;
  --shadow: 0 12px 32px rgba(72, 58, 38, .045);
}
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--bg); font-family: var(--serif); font-size: 15px; line-height: 1.9; letter-spacing: .045em; }
a { color: inherit; text-decoration: none; transition: color .25s, opacity .25s, background-color .25s, border-color .25s; }
a:hover { color: var(--gold-deep); }
img { max-width: 100%; height: auto; vertical-align: middle; }
.container { width: min(1180px, calc(100% - 80px)); margin-inline: auto; }
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255,253,250,.96); border-bottom: 1px solid #eee5d7; backdrop-filter: blur(12px); }
.header-inner { min-height: 82px; display: flex; justify-content: space-between; align-items: center; gap: 44px; }
.brand { display: flex; align-items: baseline; gap: 18px; color: var(--gold-deep); white-space: nowrap; }
.brand-main { font-family: var(--display); font-size: clamp(29px,3vw,36px); letter-spacing: .03em; font-weight: 500; }
.brand-sub { font-size: 12px; letter-spacing: .15em; }
.global-nav { display: flex; align-items: center; gap: clamp(18px, 2.6vw, 36px); font: 500 15px/1 var(--display); letter-spacing: .08em; }
.global-nav a { position: relative; padding: 12px 0; }
.global-nav .is-current { color: var(--gold-deep); }
.global-nav .is-current::after { content:""; position:absolute; left:0; right:0; bottom:0; height:1px; background:var(--gold); }
.hero { position: relative; min-height: clamp(500px, 48vw, 700px); overflow: hidden; }
.hero-image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center right; }
.hero::after { content:""; position: absolute; inset:0; background: linear-gradient(90deg, rgba(255,253,250,.28) 0%, rgba(255,253,250,.12) 46%, transparent 65%); }
.hero-content { position: relative; z-index: 1; min-height: clamp(500px, 48vw, 700px); display: flex; justify-content: center; flex-direction: column; align-items: flex-start; padding-bottom: 24px; color: var(--gold-deep); }
.hero-copy { margin: 0 0 20px 64px; font-size: clamp(22px,2.1vw,32px); letter-spacing: .24em; }
.hero-rule { width: clamp(230px, 27vw, 335px); height: 1px; margin: 0 0 30px 88px; background: var(--gold); position: relative; }
.hero-rule::after { content: "◇"; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); background: rgba(255,253,250,.8); padding-inline: 12px; font-size: 14px; }
.hero h1 { margin: 0 0 0 24px; font-weight: 400; }
.hero-title-en { display:block; font: italic 500 clamp(68px,7vw,108px)/.86 var(--display); letter-spacing: .01em; }
.hero-title-jp { display:block; margin: 34px 0 0 54px; font-size: clamp(18px,1.8vw,27px); letter-spacing: .3em; font-weight: 400; }
.section { padding: 52px 0 0; }
.frame { border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow); }
.section-heading { color: var(--gold-deep); margin-bottom: 24px; }
.section-heading h2 { display: inline-block; margin: 0; font: 500 32px/1 var(--display); letter-spacing: .07em; color: var(--gold-deep); }
.section-heading span { display:inline-block; margin-left: 18px; color: var(--gold); font-size: 12px; letter-spacing: .18em; }
.section-heading-row { display:flex; align-items: center; justify-content: space-between; gap: 24px; margin-bottom: 26px; }
.text-link { font-size: 13px; color: var(--gold-deep); white-space: nowrap; letter-spacing: .13em; }
.profile-grid { padding: 22px; display:grid; grid-template-columns: 39% 1fr; gap: 54px; align-items: center; }
.profile-photo { margin:0; overflow:hidden; aspect-ratio: 1.34; }
.profile-photo img { width:100%; height:100%; object-fit:cover; object-position: center; }
.profile-body { padding-right: clamp(20px, 4vw, 72px); }
.profile-body h3 { font-size: 21px; font-weight: 500; letter-spacing: .17em; margin: 0 0 22px; }
.profile-body p { color: #51483e; margin: 0 0 12px; font-size: 14px; }
.button { display:inline-flex; align-items:center; justify-content:center; min-width: 176px; min-height: 48px; padding: 10px 22px; font-size: 13px; letter-spacing: .15em; margin-top: 20px; }
.button-outline { border: 1px solid var(--gold); color: var(--gold-deep); }
.button-outline:hover { background: var(--bg-soft); }
.button-fill { background: linear-gradient(100deg, #bd9958, #a67f3f); color: #fff; min-width: 270px; }
.button-fill:hover { color: #fff; opacity: .84; }
.section-concert { padding-top: 54px; }
.concert-list { display:grid; grid-template-columns: repeat(3,1fr); gap: 19px; }
.concert-card { display:grid; grid-template-columns: 80px 1fr; gap: 20px; padding: 18px 18px 17px; min-height: 242px; border:1px solid var(--line); background:#fff; }
.date { align-self: start; background: var(--gold); color:#fff; min-height: 90px; display:flex; flex-direction:column; align-items:center; justify-content:center; font-family: var(--display); line-height:1.05; }
.date span { font-size:15px; }
.date strong { font-size:31px; font-weight:500; letter-spacing:.03em; }
.date small { font-size:12px; margin-top:4px; }
.concert-info h3 { margin:0 0 12px; min-height:56px; font-size:16px; line-height:1.65; font-weight:500; letter-spacing:.07em; }
.concert-info p { margin:0 0 4px; font-size:12px; color:#554c43; line-height:1.7; }
.concert-info .button { min-width:146px; min-height:39px; margin-top:15px; padding:4px 12px; font-size:12px; }
.media-section { padding-top: 50px; }
.media-grid { border-top: 1px solid #eee2ce; padding-top: 34px; display:grid; grid-template-columns: 1.03fr 1fr; gap: 43px; }
.movie-list { display:grid; grid-template-columns:repeat(3, 1fr); gap:14px; }
.movie-card { margin:0; }
.thumb { position:relative; aspect-ratio: 1.33; overflow:hidden; background:var(--bg-soft); }
.thumb img { width:100%; height:100%; object-fit:cover; }
.play { position:absolute; display:grid; place-items:center; width:39px; height:39px; left:50%; top:50%; transform:translate(-50%,-50%); border-radius:50%; background: rgba(255,255,255,.92); color:var(--gold-deep); font-size:13px; padding-left:2px; }
.movie-card p { font-size:12px; line-height:1.65; margin:12px 0 0; color:#403930; letter-spacing:.04em; }
.movie-card small { font-size:11px; color:var(--muted); }
.gallery-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:10px; }
.gallery-grid img { width:100%; aspect-ratio:1.45; object-fit:cover; }
.section-news { padding: 48px 0 30px; }
.news-list { list-style:none; padding:0; margin:0; border:1px solid var(--line); background:#fff; }
.news-list li { display:grid; grid-template-columns: 148px 1fr 20px; align-items:center; gap: 30px; min-height:57px; padding:0 24px; border-bottom:1px solid #eee4d5; font-size:14px; }
.news-list li:last-child { border-bottom:0; }
.news-list time { font-family:var(--display); color:var(--gold-deep); font-size:17px; letter-spacing:.06em; }
.news-list span { color: var(--gold); font-size:23px; }
.contact-banner { margin-top: 12px; padding: 0 0 34px; }
.contact-inner { background:var(--bg-soft); min-height:124px; padding: 25px clamp(30px, 8vw, 118px); display:flex; justify-content:center; align-items:center; gap: clamp(40px, 11vw, 150px); }
.contact-inner h2 { margin:0 0 5px; font-size:21px; font-weight:500; letter-spacing:.14em; }
.contact-inner p { margin:0; color: var(--muted); font-size:13px; }
.site-footer { background:var(--footer); color:#efe8db; padding: 34px 0 32px; }
.footer-grid { display:grid; grid-template-columns: 270px 1fr 320px; align-items:center; gap:40px; }
.footer-brand { display:flex; flex-direction:column; color:#f1e3c9; }
.footer-brand span { font: italic 500 30px/1.2 var(--display); }
.footer-brand small { margin-top:7px; font-size:11px; letter-spacing:.18em; }
.footer-nav { display:flex; flex-wrap:wrap; gap: 10px 24px; font: 14px/1.5 var(--display); letter-spacing:.1em; }
.copyright { margin:0; color:#d3c8b8; font:14px var(--display); letter-spacing:.06em; text-align:right; }
@media (max-width: 1060px) {
  .container { width: min(100% - 42px, 900px); }
  .header-inner { flex-wrap: wrap; padding-block: 16px 12px; gap: 10px; }
  .global-nav { width: 100%; justify-content:center; padding-top:8px; border-top:1px solid #eee5d7; gap:22px; }
  .hero-content { justify-content:flex-start; padding-top: 66px; }
  .hero-copy, .hero-rule, .hero h1, .hero-title-jp { margin-left:0; }
  .concert-list, .media-grid { grid-template-columns:1fr; }
  .profile-grid { gap:30px; }
  .footer-grid { grid-template-columns:1fr; text-align:center; }
  .footer-nav { justify-content:center; }
  .copyright { text-align:center; }
}
@media (max-width: 720px) {
  body { font-size:14px; }
  .container { width: min(100% - 30px, 540px); }
  .brand { flex-direction:column; gap:0; }
  .global-nav { justify-content:flex-start; overflow-x:auto; white-space:nowrap; padding-bottom:8px; }
  .hero { min-height:560px; }
  .hero-image { object-position: 73% center; opacity:.62; }
  .hero::after { background:rgba(255,253,250,.44); }
  .hero-content { min-height:560px; padding-top:44px; }
  .hero-copy { font-size:18px; letter-spacing:.17em; }
  .hero-title-en { font-size:58px; }
  .hero-title-jp { margin-top:25px; font-size:16px; letter-spacing:.2em; }
  .profile-grid { grid-template-columns:1fr; padding:14px; }
  .profile-body { padding: 0 8px 15px; }
  .section-heading h2 { font-size:28px; }
  .concert-list { grid-template-columns:1fr; }
  .concert-card { grid-template-columns:72px 1fr; }
  .movie-list { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .news-list li { grid-template-columns:1fr 18px; gap:4px 12px; padding:13px 15px; }
  .news-list time { grid-column:1; }
  .news-list a { grid-column:1; }
  .news-list span { grid-column:2; grid-row:1 / 3; }
  .contact-inner { flex-direction:column; align-items:flex-start; gap:16px; padding:25px 22px; }
}
