@import url("../style.css");

/* ══════════════════════════════
   LEGAL DOCUMENT (規約・特商法・プライバシー共通)
   可読性最優先・装飾は最小限
══════════════════════════════ */
body{
  background:radial-gradient(ellipse at top,#2a1a4a,#0f0820 70%);
  min-height:100vh;
}

.legal-app{
  max-width:840px;margin:0 auto;
  padding:0 16px 40px;
  color:var(--ink);
}

/* ── Header ── */
.legal-header{
  padding:24px 8px 18px;
  border-bottom:1px solid #ffffff22;
  margin-bottom:24px;
  text-align:center;
}
.legal-brand{
  font-size:clamp(20px,4vw,28px);
  font-weight:900;letter-spacing:6px;
  background:linear-gradient(90deg,#ffd166,#9b6bff,#5ad7ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 16px #9b6bff44);
  margin:0 0 6px;
  display:inline-block;
}
.legal-brand a{color:inherit;text-decoration:none}
.legal-doc-type{
  font-size:13px;color:var(--ink-dim);letter-spacing:3px;
  margin-top:4px;
}

/* ── Title ── */
.legal-title{
  font-size:clamp(22px,4.5vw,30px);
  color:var(--accent);
  letter-spacing:2px;
  margin:8px 0 24px;
  text-align:center;
  line-height:1.5;
}

/* ── Sections ── */
.legal-content{
  background:linear-gradient(180deg,#ffffff0a,#ffffff03);
  border:1px solid #ffffff18;
  border-radius:14px;
  padding:24px clamp(16px,3vw,32px);
  box-shadow:var(--shadow);
}
.legal-content h2{
  font-size:18px;
  color:var(--accent3);
  letter-spacing:2px;
  margin:28px 0 12px;
  padding-bottom:6px;
  border-bottom:1px solid #ffffff22;
}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{
  font-size:15px;
  color:var(--accent);
  margin:18px 0 8px;
  letter-spacing:1px;
}
.legal-content p{
  font-size:15px;
  line-height:1.95;
  color:var(--ink);
  margin:8px 0 14px;
}
.legal-content ul,
.legal-content ol{
  font-size:15px;
  line-height:1.95;
  color:var(--ink);
  padding-left:24px;
  margin:8px 0 16px;
}
.legal-content li{margin-bottom:6px}
.legal-content li::marker{color:var(--accent2)}
.legal-content strong{color:var(--accent);font-weight:700}

/* ── Definition list (特商法表記用) ── */
.legal-dl{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  margin:14px 0;
  border:1px solid #ffffff22;
  border-radius:10px;
  overflow:hidden;
}
.legal-dl-row{
  display:grid;
  grid-template-columns:1fr;
  border-bottom:1px solid #ffffff14;
}
.legal-dl-row:last-child{border-bottom:none}
.legal-dl dt{
  background:#ffffff0c;
  padding:12px 16px;
  font-weight:700;
  color:var(--accent3);
  font-size:14px;
  letter-spacing:1px;
  border-bottom:1px solid #ffffff14;
}
.legal-dl dd{
  margin:0;
  padding:14px 16px;
  font-size:15px;
  line-height:1.9;
  color:var(--ink);
}
@media(min-width:680px){
  .legal-dl-row{grid-template-columns:220px 1fr}
  .legal-dl dt{
    border-bottom:none;
    border-right:1px solid #ffffff14;
  }
}

/* ── Pending marker (★暫定★) ── */
.legal-pending{
  display:inline-block;
  background:#ff6b9b22;
  color:#ffb3c8;
  border:1px dashed #ff6b9b88;
  padding:2px 10px;
  border-radius:6px;
  font-size:13px;
  font-weight:700;
  letter-spacing:1px;
}

/* ── Notice box (注意書き) ── */
.legal-notice{
  background:#ffd16615;
  border-left:4px solid var(--accent);
  border-radius:0 10px 10px 0;
  padding:14px 18px;
  margin:18px 0;
  font-size:14px;
  line-height:1.9;
  color:var(--ink);
}
.legal-notice strong{color:var(--accent)}

/* ── Disclaimer (冒頭の免責) ── */
.legal-disclaimer{
  background:#5ad7ff11;
  border:1px solid #5ad7ff44;
  border-radius:10px;
  padding:12px 16px;
  margin:0 0 24px;
  font-size:13px;
  color:var(--ink-dim);
  line-height:1.85;
}

/* ── Footer ── */
.legal-footer{
  margin-top:32px;
  padding:20px 8px 12px;
  border-top:1px solid #ffffff22;
  text-align:center;
  font-size:13px;
  color:var(--ink-dim);
  line-height:1.95;
}
.legal-footer-links{
  display:flex;flex-wrap:wrap;gap:8px 16px;
  justify-content:center;
  margin:10px 0 14px;
}
.legal-footer-links a{
  color:var(--accent3);
  text-decoration:none;
  border-bottom:1px dotted #5ad7ff66;
  padding:2px 0;
  font-size:13px;
  letter-spacing:1px;
}
.legal-footer-links a:hover{color:var(--accent);border-bottom-color:var(--accent)}
.legal-footer-meta{font-size:12px;opacity:.8;margin-top:6px}
.legal-footer-meta a{color:var(--accent3);text-decoration:none}
.legal-footer-meta a:hover{text-decoration:underline}

/* ── Back link ── */
.legal-back{
  display:inline-block;
  margin-bottom:16px;
  color:var(--ink-dim);
  font-size:13px;
  text-decoration:none;
  letter-spacing:1px;
}
.legal-back:hover{color:var(--accent)}

/* Mobile */
@media(max-width:600px){
  .legal-content{padding:18px 14px}
  .legal-content h2{font-size:16px}
  .legal-content p,
  .legal-content ul,
  .legal-content ol,
  .legal-dl dd{font-size:14px}
}
