/* ============================================================
   DESIGN L — マガジン / MAGAZINE  (editorial, photo-led)
   All rules scoped under .L. Brand colors via theme vars only.
   ============================================================ */

.L { background: var(--page-bg); color: var(--text); font-family: var(--sans-jp); }
.L a { color: inherit; text-decoration: none; }
.L img, .L svg { display: block; }

/* shared serif display headings */
.L h1, .L h2, .L h3 { font-family: "Shippori Mincho", var(--serif-jp); font-weight: 500; }
.L .sec-no {
  display: inline-block; font-family: var(--display); font-size: 13px;
  letter-spacing: .28em; color: var(--accent); font-weight: 600; margin-bottom: 14px;
}

/* ---------- masthead / header ---------- */
.L-hd { background: var(--page-bg); padding-top: 30px; }
.L-hd-in {
  max-width: 1180px; margin: 0 auto; padding: 8px 40px 18px;
  display: flex; align-items: center; gap: 24px;
}
.L-brand { display: flex; align-items: center; gap: 12px; }
.L-brand .name { font-family: "Shippori Mincho", var(--serif-jp); font-weight: 600; font-size: 21px; letter-spacing: .05em; line-height: 1.1; }
.L-brand .name small { display: block; font-family: var(--display); font-size: 9.5px; letter-spacing: .4em; color: var(--text-soft); margin-top: 3px; font-weight: 500; }
.L-nav { margin-left: auto; display: flex; gap: 26px; }
.L-nav a { font-size: 13.5px; letter-spacing: .06em; color: var(--text); position: relative; padding: 4px 0; transition: color .2s; }
.L-nav a::after { content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 1px; background: var(--accent); transition: width .25s; }
.L-nav a:hover { color: var(--brand); }
.L-nav a:hover::after { width: 100%; }
.L-tel { display: inline-flex; align-items: center; gap: 8px; padding-left: 24px; border-left: 1px solid var(--line); }
.L-tel .num { font-family: var(--display); font-size: 21px; font-weight: 600; letter-spacing: .02em; color: var(--brand); }

.L-masthead {
  max-width: 1180px; margin: 0 auto; padding: 0 40px 22px;
  display: flex; align-items: center; gap: 20px;
}
.L-masthead .line { flex: 1; height: 1px; background: var(--line); }
.L-masthead .ttl { font-family: var(--display); font-size: 15px; letter-spacing: .46em; color: var(--brand); font-weight: 600; }
.L-masthead .sub { font-size: 10.5px; letter-spacing: .22em; color: var(--text-soft); }

/* ---------- hero ---------- */
.L-hero { position: relative; }
.L-hero-media { position: relative; width: 100%; height: 78vh; min-height: 540px; max-height: 780px; }
.L-hero-media .ph { position: absolute; inset: 0; }
.L-hero-media::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(90deg, rgba(10,14,22,.62) 0%, rgba(10,14,22,.2) 46%, transparent 70%);
}
.L-hero-cap {
  position: absolute; right: 20px; bottom: 18px; z-index: 3;
  font-family: var(--display); font-size: 11px; letter-spacing: .16em; color: rgba(255,255,255,.7);
}
.L-hero-copy {
  position: absolute; z-index: 4; left: max(40px, calc((100% - 1180px)/2 + 40px)); bottom: -56px;
  max-width: 620px; padding: 44px 48px 40px; background: var(--page-bg);
  box-shadow: 0 30px 70px rgba(13,24,38,.16); border-top: 3px solid var(--accent);
}
.L-hero-copy .kicker { font-family: var(--display); font-size: 12.5px; letter-spacing: .3em; color: var(--accent); font-weight: 600; }
.L-hero-copy h1 { font-size: 46px; line-height: 1.42; letter-spacing: .04em; margin: 16px 0 20px; color: var(--brand-ink); }
.L-hero-copy h1 .q { font-style: normal; color: var(--brand); }
.L-hero-copy .lead { font-size: 15px; line-height: 2; color: var(--text-soft); max-width: 500px; }
.L-hero-copy .meta { display: flex; align-items: center; gap: 14px; margin-top: 24px; font-size: 12px; letter-spacing: .1em; color: var(--text-soft); }
.L-hero-copy .meta .vol { font-family: var(--display); font-size: 15px; letter-spacing: .12em; color: var(--brand); font-weight: 600; }
.L-hero-copy .meta .sep { width: 30px; height: 1px; background: var(--brand-line); }

/* ---------- about ---------- */
.L-about { padding: 132px 0 96px; }
.L-about-in {
  max-width: 1180px; margin: 0 auto; padding: 0 40px;
  display: grid; grid-template-columns: 1.05fr 1fr; gap: 60px; align-items: center;
}
.L-about-fig { position: relative; margin: 0; }
.L-about-fig .ph { width: 100%; aspect-ratio: 4 / 5; box-shadow: 0 24px 60px rgba(13,24,38,.18); }
.L-about-fig figcaption {
  position: absolute; left: 0; bottom: -30px; font-family: var(--display);
  font-size: 12px; font-style: italic; letter-spacing: .06em; color: var(--text-soft);
}
.L-about-fig::before {
  content: ""; position: absolute; top: -22px; left: -22px; width: 96px; height: 96px;
  border-top: 2px solid var(--accent); border-left: 2px solid var(--accent);
}
.L-about-body h2 { font-size: 34px; line-height: 1.5; letter-spacing: .04em; color: var(--brand-ink); margin-bottom: 26px; }
.L-about-body p { font-size: 15px; line-height: 2.15; color: var(--text-soft); margin-bottom: 18px; }
.L-about-body .drop .dropcap {
  float: left; font-family: "Shippori Mincho", var(--serif-jp); font-size: 62px; line-height: .82;
  color: var(--brand); margin: 6px 12px 0 0; font-weight: 600;
}
.L-about-body .sign { margin-top: 30px; padding-top: 22px; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 4px; }
.L-about-body .sign .role { font-size: 11.5px; letter-spacing: .12em; color: var(--text-soft); }
.L-about-body .sign .nm { font-family: "Shippori Mincho", var(--serif-jp); font-size: 22px; letter-spacing: .16em; color: var(--brand-ink); }

/* ---------- services / features ---------- */
.L-serv { padding: 20px 0 104px; }
.L-serv-hd { max-width: 1180px; margin: 0 auto 44px; padding: 0 40px; text-align: center; }
.L-serv-hd h2 { font-size: 32px; letter-spacing: .1em; color: var(--brand-ink); }
.L-serv-hd p { margin-top: 12px; font-size: 14px; color: var(--text-soft); letter-spacing: .04em; }
.L-serv-grid {
  max-width: 1180px; margin: 0 auto; padding: 0 40px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px 32px;
}
.L-feat { display: flex; flex-direction: column; }
.L-feat-media { position: relative; display: block; overflow: hidden; }
.L-feat-media .ph { width: 100%; aspect-ratio: 5 / 6; transition: transform .6s ease; }
.L-feat-media:hover .ph { transform: scale(1.05); }
.L-feat-media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,14,22,.5) 100%);
}
.L-feat-n {
  position: absolute; top: 16px; left: 16px; z-index: 2; font-family: var(--display);
  font-size: 44px; line-height: 1; font-weight: 500; color: #fff; text-shadow: 0 2px 20px rgba(0,0,0,.4);
}
.L-feat-cap {
  position: absolute; left: 16px; bottom: 14px; z-index: 2; font-family: var(--display);
  font-size: 11.5px; letter-spacing: .1em; color: rgba(255,255,255,.85);
}
.L-feat-body { padding: 22px 4px 0; }
.L-feat-body .en { font-family: var(--display); font-size: 11.5px; letter-spacing: .24em; color: var(--accent); font-weight: 600; }
.L-feat-body h3 { font-size: 21px; letter-spacing: .06em; color: var(--brand-ink); margin: 8px 0 12px; }
.L-feat-body p { font-size: 13.5px; line-height: 1.95; color: var(--text-soft); }
.L-feat-body .more {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 16px;
  font-family: var(--display); font-size: 12px; letter-spacing: .18em; font-weight: 600; color: var(--brand);
}
.L-feat-body .more svg { transition: transform .25s; }
.L-feat:hover .more svg { transform: translateX(4px); }

/* ---------- news ---------- */
.L-news { background: var(--surface); padding: 88px 0; }
.L-news-in { max-width: 940px; margin: 0 auto; padding: 0 40px; }
.L-news-hd { display: flex; align-items: baseline; gap: 20px; margin-bottom: 20px; }
.L-news-hd h2 { font-size: 26px; letter-spacing: .12em; color: var(--brand-ink); }
.L-news-list { border-top: 1px solid var(--line); }
.L-news-row {
  display: grid; grid-template-columns: 118px 92px 1fr 22px; align-items: center; gap: 8px;
  padding: 20px 6px; border-bottom: 1px solid var(--line); transition: background .2s;
}
.L-news-row:hover { background: color-mix(in srgb, var(--brand) 5%, transparent); }
.L-news-row .date { font-family: var(--display); font-size: 15px; letter-spacing: .06em; color: var(--brand); font-weight: 600; }
.L-news-row .cat { font-family: var(--display); font-size: 10.5px; letter-spacing: .16em; text-align: center; padding: 4px 0; border: 1px solid var(--brand-line); color: var(--text-soft); }
.L-news-row .ttl { font-size: 14.5px; letter-spacing: .03em; color: var(--text); }
.L-news-row .arw { justify-self: end; opacity: .5; transition: transform .25s, opacity .2s; }
.L-news-row:hover .arw { transform: translateX(4px); opacity: 1; }
.L-news-all {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 28px;
  font-family: var(--display); font-size: 13px; letter-spacing: .16em; font-weight: 600; color: var(--brand);
}

/* ---------- contact band ---------- */
.L-contact { position: relative; padding: 108px 0; overflow: hidden; }
.L-contact-media { position: absolute; inset: 0; }
.L-contact-media .ph { position: absolute; inset: 0; }
.L-contact-media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(105deg, color-mix(in srgb, var(--brand-ink) 88%, transparent) 0%, color-mix(in srgb, var(--brand-ink) 55%, transparent) 62%, rgba(10,14,22,.28) 100%);
}
.L-contact-in { position: relative; z-index: 2; max-width: 1180px; margin: 0 auto; padding: 0 40px; color: var(--on-brand); }
.L-contact-in .kicker { font-family: var(--display); font-size: 12.5px; letter-spacing: .3em; color: var(--accent-2); font-weight: 600; }
.L-contact-in h2 { font-size: 38px; line-height: 1.5; letter-spacing: .05em; margin: 16px 0 16px; color: #fff; }
.L-contact-in > p { font-size: 15px; line-height: 1.9; color: rgba(255,255,255,.82); max-width: 520px; }
.L-contact-actions { display: flex; flex-wrap: wrap; gap: 18px; margin-top: 34px; }
.L-contact-actions .tel {
  display: flex; flex-direction: column; gap: 3px; padding: 22px 30px;
  background: color-mix(in srgb, #ffffff 12%, transparent); border: 1px solid rgba(255,255,255,.28); border-radius: 4px;
}
.L-contact-actions .tel .lab { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; letter-spacing: .08em; color: rgba(255,255,255,.85); }
.L-contact-actions .tel .num { font-family: var(--display); font-size: 34px; font-weight: 600; letter-spacing: .03em; color: #fff; }
.L-contact-actions .tel .hrs { font-size: 11.5px; letter-spacing: .08em; color: rgba(255,255,255,.7); }
.L-contact-actions .form {
  display: flex; align-items: center; gap: 14px; padding: 22px 26px;
  background: var(--page-bg); border-radius: 4px; transition: transform .2s;
}
.L-contact-actions .form:hover { transform: translateY(-3px); }
.L-contact-actions .form .ft { display: flex; flex-direction: column; gap: 3px; }
.L-contact-actions .form .t1 { font-size: 15px; font-weight: 700; letter-spacing: .04em; color: var(--brand-ink); }
.L-contact-actions .form .t2 { font-size: 11.5px; letter-spacing: .06em; color: var(--text-soft); }

/* ---------- footer ---------- */
.L-ft { background: var(--brand-ink); color: var(--on-brand); padding: 68px 0 0; }
.L-ft-in {
  max-width: 1180px; margin: 0 auto; padding: 0 40px 44px;
  display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap;
}
.L-ft-brand .L-brand .name { color: var(--on-brand); }
.L-ft-brand .L-brand .name small { color: rgba(255,255,255,.55); }
.L-ft-info { margin-top: 18px; font-size: 12.5px; line-height: 2; color: rgba(255,255,255,.66); }
.L-ft-info .co { display: block; font-size: 14px; color: #fff; margin-bottom: 4px; letter-spacing: .04em; }
.L-ft-nav { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 12px 34px; margin: 0; padding: 0; }
.L-ft-nav a { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; letter-spacing: .04em; color: rgba(255,255,255,.8); transition: color .2s; }
.L-ft-nav a:hover { color: #fff; }
.L-ft-bar {
  border-top: 1px solid rgba(255,255,255,.12); max-width: 1180px; margin: 0 auto; padding: 20px 40px;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.L-ft-bar small { font-family: var(--display); font-size: 11.5px; letter-spacing: .1em; color: rgba(255,255,255,.5); }
.L-top { display: inline-flex; align-items: center; gap: 9px; font-family: var(--display); font-size: 12px; letter-spacing: .16em; color: rgba(255,255,255,.85); }
.L-top .up { width: 30px; height: 30px; border: 1px solid rgba(255,255,255,.4); border-radius: 50%; position: relative; }
.L-top .up::after { content: ""; position: absolute; top: 11px; left: 10px; width: 8px; height: 8px; border-top: 1px solid #fff; border-right: 1px solid #fff; transform: rotate(-45deg); }
.L-top:hover .up { border-color: var(--accent); }

/* ============================================================
   RESPONSIVE — 1280 base, tablet, ≤720 phone single column
   ============================================================ */
@media (max-width: 1080px) {
  .L-hero-copy { position: relative; left: 0; bottom: 0; margin: -48px 24px 0; max-width: none; }
  .L-about-in { grid-template-columns: 1fr; gap: 60px; }
  .L-about-fig { max-width: 460px; }
  .L-serv-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 720px) {
  .L-hd { padding-top: 26px; }
  .L-hd-in { flex-wrap: wrap; gap: 10px 16px; padding: 6px 20px 14px; }
  .L-nav { display: none; }
  .L-tel { margin-left: auto; padding-left: 0; border-left: 0; }
  .L-tel .num { font-size: 19px; }
  .L-masthead { padding: 0 20px 18px; gap: 12px; }
  .L-masthead .sub { display: none; }
  .L-masthead .ttl { font-size: 12px; letter-spacing: .3em; }

  .L-hero-media { height: 60vh; min-height: 400px; }
  .L-hero-copy { margin: -40px 16px 0; padding: 30px 22px 28px; }
  .L-hero-copy h1 { font-size: 29px; line-height: 1.5; }
  .L-hero-copy .lead { font-size: 14px; line-height: 1.95; }

  .L-about { padding: 72px 0 64px; }
  .L-about-in { padding: 0 20px; gap: 48px; }
  .L-about-fig { max-width: none; }
  .L-about-fig::before { width: 64px; height: 64px; top: -14px; left: -14px; }
  .L-about-body h2 { font-size: 26px; }
  .L-about-body .drop .dropcap { font-size: 48px; }

  .L-serv { padding: 8px 0 72px; }
  .L-serv-hd { padding: 0 20px; margin-bottom: 34px; }
  .L-serv-hd h2 { font-size: 26px; }
  .L-serv-grid { grid-template-columns: 1fr; gap: 40px; padding: 0 20px; }
  .L-feat-media .ph { aspect-ratio: 16 / 11; }

  .L-news { padding: 62px 0; }
  .L-news-in { padding: 0 20px; }
  .L-news-row { grid-template-columns: 1fr auto; gap: 4px 12px; padding: 16px 4px; }
  .L-news-row .cat { display: none; }
  .L-news-row .date { grid-row: 1; }
  .L-news-row .arw { grid-row: 1; grid-column: 2; }
  .L-news-row .ttl { grid-column: 1 / -1; grid-row: 2; }

  .L-contact { padding: 72px 0; }
  .L-contact-in { padding: 0 20px; }
  .L-contact-in h2 { font-size: 28px; }
  .L-contact-actions { flex-direction: column; gap: 14px; }
  .L-contact-actions .tel, .L-contact-actions .form { width: 100%; }

  .L-ft { padding: 52px 0 0; }
  .L-ft-in { padding: 0 20px 34px; gap: 30px; }
  .L-ft-nav { gap: 10px 24px; }
  .L-ft-bar { flex-direction: column; align-items: flex-start; padding: 18px 20px; }
}
