/* Prime ID 共通デザインシステム。公開ページ(ランディング/規約/ポリシー/ログイン)で共有する。 */
:root{
  --bg:#0a0e1c; --bg2:#0e1430; --card:#141a2e; --card2:#171f38;
  --border:#243150; --border2:#2c3a5e;
  --text:#e7ecf5; --muted:#9fb0d0; --faint:#6b7a9c;
  --accent:#5b8cff; --accent2:#8a7bff; --glow:rgba(91,140,255,.35);
  --ok:#9be8c0; --okbg:#10241a; --okbd:#1f5a3a;
  --err:#ffb3c4; --errbg:#3a1622; --errbd:#6b2740;
  color-scheme:dark;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  min-height:100vh; color:var(--text);
  font-family:system-ui,-apple-system,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  line-height:1.6;
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(91,140,255,.16), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(138,123,255,.12), transparent 55%),
    var(--bg);
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{width:min(92vw,1040px);margin:0 auto;padding:0 4px}
.narrow{width:min(92vw,760px);margin:0 auto}

/* ヘッダ */
.site-header{display:flex;align-items:center;justify-content:space-between;padding:22px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;color:var(--text)}
.brand:hover{text-decoration:none}
.brand .logo{width:30px;height:30px;display:block}
.nav{display:flex;gap:18px;align-items:center}
.nav a{color:var(--muted);font-size:14px}
.nav a:hover{color:var(--text);text-decoration:none}

/* ボタン */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 20px;border-radius:12px;border:1px solid transparent;
  font-size:14px;font-weight:600;cursor:pointer;transition:.15s}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 8px 24px var(--glow)}
.btn-primary:hover{filter:brightness(1.07);text-decoration:none}
.btn-ghost{background:transparent;border-color:var(--border2);color:var(--muted)}
.btn-ghost:hover{color:var(--text);border-color:var(--accent);text-decoration:none}

/* カード */
.card{background:linear-gradient(180deg,var(--card),var(--card2));
  border:1px solid var(--border);border-radius:18px;padding:26px 24px;
  box-shadow:0 16px 48px rgba(0,0,0,.4)}

/* ヒーロー */
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;padding:48px 0 28px}
.hero h1{font-size:clamp(28px,5vw,44px);line-height:1.15;margin:0 0 16px;letter-spacing:-.02em}
.hero h1 .grad{background:linear-gradient(120deg,#9bb6ff,#c4b9ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:var(--muted);font-size:16px;margin:0 0 26px;max-width:46ch}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-art{display:grid;place-items:center}
.hero-art svg{width:100%;height:auto;max-width:380px}
@media(max-width:760px){.hero{grid-template-columns:1fr;gap:20px;padding:24px 0}.hero-art{order:-1}}

/* 特徴グリッド */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:18px 0 40px}
@media(max-width:760px){.features{grid-template-columns:1fr}}
.feat{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px}
.feat .ic{width:38px;height:38px;color:var(--accent);margin-bottom:12px}
.feat h3{font-size:15px;margin:0 0 6px}
.feat p{color:var(--muted);font-size:13px;margin:0}

/* セクション見出し */
.section-title{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin:0 0 10px}

/* 文書ページ(規約/ポリシー) */
.doc{padding:18px 0 60px}
.doc h1{font-size:26px;margin:6px 0 6px}
.doc .updated{color:var(--faint);font-size:12px;margin:0 0 26px}
.doc h2{font-size:17px;margin:30px 0 8px;padding-top:8px;border-top:1px solid var(--border)}
.doc p,.doc li{color:var(--muted);font-size:14px}
.doc ul{padding-left:20px}
.doc .note{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;font-size:13px;color:var(--muted)}

/* フッタ */
.site-footer{border-top:1px solid var(--border);margin-top:30px;padding:26px 0;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.site-footer .links{display:flex;gap:18px;flex-wrap:wrap}
.site-footer a{color:var(--muted);font-size:13px}
.site-footer .copy{color:var(--faint);font-size:12px}

/* 認証カード(中央寄せ) */
.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-card{width:min(92vw,400px)}
.auth-card .logo-row{display:flex;justify-content:center;margin-bottom:14px}
.auth-card h1{font-size:19px;text-align:center;margin:0 0 4px}
.auth-card .sub{font-size:13px;color:var(--muted);text-align:center;margin:0 0 20px}
label{display:block;font-size:12px;color:var(--muted);margin:14px 0 6px}
input{width:100%;padding:11px 12px;border-radius:10px;border:1px solid var(--border2);
  background:#0e1426;color:var(--text);font-size:14px}
input:focus{outline:none;border-color:var(--accent)}
.msg{font-size:13px;padding:10px 12px;border-radius:10px;margin-top:14px;word-break:break-all}
.msg.err{background:var(--errbg);border:1px solid var(--errbd);color:var(--err)}
.msg.ok{background:var(--okbg);border:1px solid var(--okbd);color:var(--ok)}
.legal-note{font-size:11px;color:var(--faint);text-align:center;margin-top:18px;line-height:1.6}
.auth-card .logo-row{color:var(--accent)}
.auth-card .btn{width:100%;margin-top:12px}
.auth-card form{margin-top:2px}
