/* Harassmeter legal pages — shared theme (privacy / terms / tokushoho) */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --paper:#faf5f0;--paper2:#fffdf9;--purple:#6421a7;--purple-deep:#4a1880;
  --yellow:#fdcc2c;--yellow-deep:#e0a800;--ink:#26203a;--sub:#7a6f86;
  --stkshadow:rgba(74,24,128,0.22);--line:rgba(100,33,167,0.12);
}
html{scroll-behavior:smooth}
body{
  font-family:'Zen Kaku Gothic New',-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:700;background:var(--paper);color:var(--ink);
  line-height:1.9;letter-spacing:0.02em;-webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:var(--purple);text-decoration:underline;text-underline-offset:2px}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;height:56px;
  display:flex;align-items:center;justify-content:space-between;padding:0 14px;
  background:rgba(250,245,240,0.9);backdrop-filter:saturate(1.2) blur(12px);
  -webkit-backdrop-filter:saturate(1.2) blur(12px);border-bottom:1px solid var(--line);
}
.site-logo{display:flex;align-items:center;gap:9px;font-weight:900;font-size:15px;color:var(--purple);text-decoration:none}
.site-logo img{height:34px;width:34px;border-radius:9px;object-fit:cover;box-shadow:0 2px 5px var(--stkshadow)}
.site-cta{
  display:inline-flex;align-items:center;padding:9px 15px;background:var(--yellow);color:#1a1a1a;
  font-weight:900;font-size:13px;border-radius:999px;box-shadow:0 4px 9px var(--stkshadow);
  text-decoration:none;transition:transform .1s;
}
.site-cta:active{transform:translateY(2px)}

/* Decorations */
.deco{position:absolute;pointer-events:none;user-select:none;z-index:1}
.deco img{display:block;width:100%;height:100%;object-fit:contain}
.deco-bob{animation:bob 3.5s ease-in-out infinite}
.deco-bob2{animation:bob 3.5s ease-in-out infinite;animation-delay:-1.2s}
.deco-pulse{animation:pulse 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.12);opacity:1}}
.icon-inline{display:inline-block;vertical-align:-3px;width:1.05em;height:1.05em;object-fit:contain;margin:0 4px}

/* Hero */
.doc-hero{
  position:relative;overflow:hidden;background:var(--purple);color:#fff;
  padding:42px 20px 42px;text-align:center;border-radius:0 0 28px 28px;
}
.doc-hero-eyebrow{
  display:inline-block;background:#fff;color:var(--purple);font-weight:900;
  font-size:11px;padding:5px 14px;border-radius:999px;margin-bottom:10px;letter-spacing:0.12em;
}
.doc-hero h1{font-weight:900;font-size:30px;color:#fff;letter-spacing:0.03em;line-height:1.25}
.doc-hero p{color:#fff;font-size:13px;margin-top:8px;opacity:.95}

/* Content */
.content{max-width:720px;margin:0 auto;padding:30px 20px 20px}
.content > p{font-size:14px;color:var(--sub);margin-bottom:16px}
.content h2{
  font-weight:900;font-size:18px;color:var(--purple);margin:26px 0 12px;
  display:flex;align-items:center;gap:8px;
}
.content h2::before{content:"";flex-shrink:0;width:8px;height:18px;background:var(--purple);border-radius:4px}
.section-card{
  background:#fff;border:2px solid var(--purple);border-radius:14px;
  padding:18px 20px;margin-bottom:14px;box-shadow:0 5px 12px var(--stkshadow);
}
.section-card p,.section-card ul{font-size:14px;color:var(--ink);font-weight:700}
.section-card p + p,.section-card p + ul,.section-card ul + p{margin-top:10px}
.section-card ul{padding-left:20px}
.section-card li{margin-bottom:4px}

/* Legal table (tokushoho) */
.legal-table{width:100%;border-collapse:collapse;font-size:13.5px;font-weight:700}
.legal-table th,.legal-table td{border:1px solid rgba(100,33,167,.22);padding:11px 13px;text-align:left;vertical-align:top;line-height:1.7}
.legal-table th{background:rgba(100,33,167,.08);color:var(--purple);font-weight:900;width:36%;white-space:nowrap}
@media(max-width:560px){
  .legal-table th{white-space:normal;width:38%}
  .legal-table th,.legal-table td{padding:9px 10px;font-size:12.5px}
}

/* tokushoho definition list */
.info-card{background:#fff;border:2px solid var(--purple);border-radius:14px;overflow:hidden;box-shadow:0 5px 12px var(--stkshadow);margin-bottom:14px}
.info-card .row{padding:14px 18px;border-bottom:1px solid var(--line)}
.info-card .row:last-child{border-bottom:none}
.info-card dt{font-weight:900;font-size:13px;color:var(--purple);margin-bottom:5px}
.info-card dd{font-size:14px;color:var(--ink);font-weight:700;line-height:1.8}
.info-card dd ul{padding-left:20px;margin-top:4px}
.info-card dd li{margin-bottom:3px}
.info-card .note{font-size:12px;color:var(--sub);font-weight:700;margin-top:8px;line-height:1.6}

.updated{font-size:12px;color:var(--sub);text-align:center;margin:24px 0 8px;font-weight:700}
.back-row{text-align:center;padding:8px 0 36px}
.back{
  display:inline-flex;align-items:center;gap:6px;padding:15px 30px;
  background:var(--yellow);color:#1a1a1a;font-weight:900;font-size:15px;border-radius:17px;
  box-shadow:0 4px 0 0 var(--yellow-deep),0 9px 14px var(--stkshadow);text-decoration:none;transition:transform .1s,box-shadow .1s;
}
.back:active{transform:translateY(4px);box-shadow:0 0 0 0 var(--yellow-deep),0 4px 8px var(--stkshadow)}

/* Footer */
footer{background:var(--purple);color:#fff;text-align:center;padding:32px 20px}
.ft-logo{font-weight:900;font-size:20px;color:#fff;margin-bottom:4px}
footer p{font-size:12px;color:rgba(255,255,255,.9);line-height:1.7}
footer a{color:#fff;font-weight:700;text-decoration:underline}
.ft-links{margin-top:8px}
.ft-links a{margin:0 8px;display:inline-block}
