/* ============================================================
   Nihongo — shared styles for static content pages
   (Legal hub, Privacy, Terms, Disclaimers, Community,
    DMCA, Refunds, Attributions, FAQ)
   Theme tokens mirror docs/redesign/dict-detail.html exactly.
   ============================================================ */
:root{
  --bg:#EEF1F5; --surface:#FFFFFF; --surface-2:#F5F7FA; --ink:#14161C; --ink-soft:#5A6373; --ink-faint:#9AA2B1;
  --line:#E6EAF0; --indigo:#5B6CFF; --indigo-soft:#EEF0FF; --green:#16A34A; --green-soft:#E7F7ED; --amber:#D97706; --amber-soft:#FDF3E3; --red:#DC2626; --red-soft:#FBEAEA; --pink:#EC4899; --purple:#7C3AED; --purple-soft:#F2EBFE; --blue:#2563EB; --blue-soft:#E6EEFE; --slate:#64748B; --slate-soft:#EEF1F5;
  --shadow:0 8px 24px rgba(20,22,28,.10); --shadow-sm:0 2px 8px rgba(20,22,28,.06);
}
body[data-theme="dark"]{
  --bg:#0E0F13; --surface:#171A21; --surface-2:#1E222B; --ink:#ECEDF0; --ink-soft:#9AA2B1; --ink-faint:#5C6470;
  --line:#232833; --indigo:#8A97FF; --indigo-soft:#20243a; --green:#4ADE80; --green-soft:#16261c; --amber:#FBBF24; --amber-soft:#2a2113; --red:#F87171; --red-soft:#2a1717; --pink:#F472B6; --purple:#A855F7; --purple-soft:#241730; --blue:#60A5FA; --blue-soft:#15233d; --slate:#94A3B8; --slate-soft:#1b2029;
  --shadow:8px 8px 18px rgba(0,0,0,.55); --shadow-sm:4px 4px 10px rgba(0,0,0,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter','Noto Sans JP',system-ui,sans-serif;background:#23262e;color:#cfd3da;padding:24px;min-height:100vh;display:flex;flex-direction:column;align-items:center}
h1{font-size:18px;font-weight:700;color:#fff;text-align:center}
.sub2{font-size:12.5px;color:#9aa2b1;text-align:center;margin:5px 0 14px;max-width:560px;line-height:1.5}
.toggle{display:inline-flex;align-items:center;gap:7px;cursor:pointer;background:#3a3e48;color:#fff;border:none;padding:9px 15px;border-radius:999px;font-family:inherit;font-size:13px;font-weight:600;margin-bottom:16px}
.toggle .material-symbols-rounded{font-size:18px}
.material-symbols-rounded{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;vertical-align:middle}
ruby rt{font-size:.5em;color:var(--ink-faint);font-weight:500}
#screen.nofuri rt{display:none}

/* phone frame */
.phone{width:364px;height:790px;background:var(--bg);border-radius:34px;overflow:hidden;box-shadow:0 24px 50px rgba(0,0,0,.45);position:relative;transition:background .25s}
.screen{position:absolute;inset:0;overflow-y:auto}
.screen::-webkit-scrollbar{width:0}

/* top bar (back + title) */
.topbar{position:sticky;top:0;z-index:8;display:flex;align-items:center;gap:12px;padding:14px 16px 12px;background:var(--bg);border-bottom:1px solid var(--line)}
.topbar .bk{font-size:22px;color:var(--ink-soft);cursor:pointer;text-decoration:none;display:flex}
.topbar .ti{font-size:15px;font-weight:800;color:var(--ink)}
.topbar .sp{margin-left:auto}
.topbar .gj{font-family:'Noto Sans JP';font-size:11px;color:var(--ink-faint);font-weight:600}

/* document body */
.doc{padding:14px 17px 40px}
.eff{font-size:11px;color:var(--ink-faint);line-height:1.7;margin-bottom:14px}
.eff b{color:var(--ink-soft);font-weight:700}
.doc .lead{font-size:13px;color:var(--ink-soft);line-height:1.65;margin-bottom:16px}
.doc h2{font-size:14.5px;font-weight:800;color:var(--ink);margin:22px 0 8px;display:flex;align-items:center;gap:8px;scroll-margin-top:60px}
.doc h2 .num{font-size:11px;font-weight:800;color:#fff;background:var(--indigo);min-width:20px;height:20px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.doc h2:first-child{margin-top:4px}
.doc h3{font-size:12.5px;font-weight:800;color:var(--ink-soft);margin:14px 0 5px}
.doc p{font-size:13px;color:var(--ink);line-height:1.62;margin:7px 0}
.doc ul,.doc ol{margin:7px 0 7px 2px;padding-left:18px}
.doc li{font-size:13px;color:var(--ink);line-height:1.6;margin:5px 0}
.doc a{color:var(--indigo);text-decoration:none;font-weight:600}
.doc strong,.doc b{font-weight:700;color:var(--ink)}
.doc .muted{color:var(--ink-soft)}
.doc .caps{font-size:11.5px;color:var(--ink-soft);line-height:1.6;letter-spacing:.2px}

/* callout boxes */
.callout{border-radius:12px;padding:12px 13px;margin:14px 0;font-size:12px;line-height:1.6;display:flex;gap:9px;align-items:flex-start}
.callout .material-symbols-rounded{font-size:18px;flex:0 0 auto;margin-top:1px}
.callout.warn{background:var(--amber-soft);color:var(--ink)} .callout.warn .material-symbols-rounded{color:var(--amber)}
.callout.info{background:var(--indigo-soft);color:var(--ink)} .callout.info .material-symbols-rounded{color:var(--indigo)}
.callout.danger{background:var(--red-soft);color:var(--ink)} .callout.danger .material-symbols-rounded{color:var(--red)}
.callout b{color:var(--ink)}

/* fill-me placeholder chip */
.ph{display:inline-block;font-family:'SFMono-Regular',ui-monospace,monospace;font-size:11px;font-weight:700;color:var(--amber);background:var(--amber-soft);border:1px dashed var(--amber);border-radius:6px;padding:1px 6px;white-space:nowrap}
body[data-theme="dark"] .ph{color:var(--amber)}

/* source / attribution cards */
.srcgrp{margin:16px 0}
.srcgrp .gh{font-size:12px;font-weight:800;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.6px;margin:0 0 9px;display:flex;align-items:center;gap:7px}
.srcgrp .gh .material-symbols-rounded{font-size:16px;color:var(--purple)}
.src{background:var(--surface);border-radius:13px;box-shadow:var(--shadow-sm);padding:12px 13px;margin-bottom:9px}
.src .st{display:flex;align-items:flex-start;gap:8px;flex-wrap:wrap}
.src .sname{font-size:13.5px;font-weight:800;color:var(--ink)}
.src .sname .jp{font-family:'Noto Sans JP';font-weight:700}
.src .lic{font-size:9.5px;font-weight:800;padding:2px 7px;border-radius:6px;letter-spacing:.2px;white-space:nowrap}
.lic.bysa{color:var(--purple);background:var(--purple-soft)}
.lic.by{color:var(--green);background:var(--green-soft)}
.lic.pd{color:var(--slate);background:var(--slate-soft)}
.lic.gov{color:var(--blue);background:var(--blue-soft)}
.lic.svc{color:var(--ink-faint);background:var(--surface-2)}
.lic.ofl{color:var(--indigo);background:var(--indigo-soft)}
.src .suse{font-size:12px;color:var(--ink-soft);line-height:1.55;margin-top:6px}
.src .sob{font-size:11.5px;color:var(--ink);line-height:1.55;margin-top:6px;padding-top:7px;border-top:1px solid var(--line)}
.src .sob b{color:var(--purple)}
.src .slink{font-size:11px;color:var(--indigo);font-weight:700;margin-top:6px;display:inline-block}

/* hub list rows */
.hubrow{display:flex;align-items:center;gap:12px;padding:13px 13px;border-radius:13px;background:var(--surface);box-shadow:var(--shadow-sm);margin-bottom:9px;cursor:pointer;text-decoration:none}
.hubrow .hi{width:40px;height:40px;border-radius:12px;background:var(--indigo-soft);color:var(--indigo);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.hubrow .hi .material-symbols-rounded{font-size:21px}
.hubrow .ht{font-size:13.5px;font-weight:800;color:var(--ink)}
.hubrow .hd{font-size:11px;color:var(--ink-soft);margin-top:2px;line-height:1.45}
.hubrow .hc{margin-left:auto;color:var(--ink-faint);font-size:20px;flex:0 0 auto}
.hubrow .req{font-size:8.5px;font-weight:800;color:var(--green);background:var(--green-soft);padding:1px 6px;border-radius:5px;margin-left:6px;vertical-align:middle}

/* section label */
.seclbl{font-size:11px;font-weight:800;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.7px;margin:20px 0 8px}

/* FAQ accordion */
details.faq{background:var(--surface);border-radius:12px;box-shadow:var(--shadow-sm);margin-bottom:8px;overflow:hidden}
details.faq>summary{list-style:none;cursor:pointer;padding:13px 14px;font-size:13px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:9px}
details.faq>summary::-webkit-details-marker{display:none}
details.faq>summary .qi{color:var(--indigo);font-size:18px;flex:0 0 auto}
details.faq>summary .ch{margin-left:auto;color:var(--ink-faint);font-size:20px;transition:transform .2s}
details.faq[open]>summary .ch{transform:rotate(180deg)}
details.faq .ans{padding:0 14px 13px 41px;font-size:12.5px;color:var(--ink-soft);line-height:1.62}
details.faq .ans p{margin:6px 0}
details.faq .ans a{color:var(--indigo);font-weight:600;text-decoration:none}
details.faq .ans ul{margin:6px 0 6px 2px;padding-left:17px}
details.faq .ans li{margin:4px 0}

/* footer note */
.srcnote{font-size:10.5px;color:var(--ink-faint);line-height:1.6;margin:22px 0 0;padding:12px;background:var(--surface-2);border-radius:11px}
.srcnote b{color:var(--ink-soft)}

/* floating furigana pill */
.toggles{position:absolute;right:14px;bottom:16px;z-index:9}
.tgl{font-size:11px;font-weight:700;padding:6px 11px;border-radius:999px;color:var(--ink-soft);cursor:pointer;display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow)}
.tgl.on{background:var(--indigo);color:#fff;border-color:var(--indigo)}
.tgl .material-symbols-rounded{font-size:14px}
