/* =========================================
   基本トークン（白×青／モダン）
   ========================================= */
:root{
  /* メインカラー */
  --pcdx-blue: #2563eb;        /* 既存より少し落ち着いた青 */
  --pcdx-blue-600: #1d4ed8;
  --pcdx-navy: #0f172a;         /* 文字の基調（ほぼ黒） */
  --pcdx-muted: #64748b;        /* 説明文 */
  --ring: rgba(37, 99, 235, .14);

  /* サーフェス */
  --bg: #f8fafc;                /* ページ背景（明るいグレー） */
  --card: #ffffff;              /* カード面 */
  --line: #e2e8f0;              /* 枠線 */

  /* レイアウト */
  --radius-xl: 16px;            /* 角丸 */
  --radius: 12px;
  --shadow: 0 10px 30px rgba(2,6,23,.08);
  --max: 560px;                 /* カード横幅 */
}

/* =========================================
   ページ背景＆中央寄せ
   ========================================= */
body .impersonate-wrap{
  font-family: "Inter", "Noto Sans JP", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  min-height: 72vh;
  display:grid;
  place-items:center;
  padding:48px 16px;
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(37,99,235,.08), transparent 60%),
    radial-gradient(900px 500px at 110% 0%, rgba(37,99,235,.06), transparent 60%),
    var(--bg);
}

/* =========================================
   カード（余白・影・角丸）
   ========================================= */
.imp-card{
  width:100%;
  max-width:var(--max);
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:var(--radius-xl);
  padding:28px;
}

/* =========================================
   ヘッダー（タイトル＋バッジ）
   ========================================= */
.imp-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:8px;
}
.imp-badge{
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:linear-gradient(180deg, var(--pcdx-blue), var(--pcdx-blue-600));
  color:#fff;font-weight:700;
  box-shadow:0 8px 20px rgba(37,99,235,.25);
}
.imp-title{
  margin:0;color:var(--pcdx-navy);font-size:22px;font-weight:800;letter-spacing:.2px;
}
.imp-sub{
  margin:6px 0 22px;color:var(--pcdx-muted);font-size:13px;line-height:1.6;
}

/* =========================================
   フィールド
   ========================================= */
.imp-field{ margin-bottom:16px; }
.imp-label{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12.5px;color:var(--pcdx-muted);margin:0 0 6px;
}
.imp-hint{ font-size:12px;color:#94a3b8; }

.imp-input{
  width:100%;font-size:15px;color:var(--pcdx-navy);
  background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:13px 14px;
  outline: none; transition: box-shadow .15s ease, border-color .15s ease;
}
.imp-input::placeholder{ color:#b6c2cf; }
.imp-input:focus{
  border-color: var(--pcdx-blue);
  box-shadow: 0 0 0 6px var(--ring);
}

/* パスワード表示切替 */
.imp-pass-wrap{ position:relative; }
.imp-pass-toggle{
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  padding:6px 10px; border-radius:8px; border:1px solid var(--line);
  background:#fff; color:var(--pcdx-blue); font-weight:700; font-size:12px;
  cursor:pointer;
}
.imp-pass-toggle:hover{ border-color:#cbd5e1; }

/* =========================================
   ボタン
   ========================================= */
.imp-actions{ display:flex; gap:12px; margin-top:8px; }
.imp-btn{
  flex:1; padding:12px 14px; border-radius:12px; border:1px solid transparent;
  font-weight:700; font-size:14px; cursor:pointer; transition: transform .06s ease, box-shadow .15s ease, background .15s ease;
}
.imp-btn:active{ transform: translateY(1px); }
.imp-btn-primary{
  color:#fff; background:linear-gradient(180deg, var(--pcdx-blue), var(--pcdx-blue-600));
  box-shadow:0 10px 24px rgba(37,99,235,.22);
}
.imp-btn-primary:hover{ filter:saturate(1.05) brightness(1.02); }
.imp-btn-ghost{
  background:#fff; color:var(--pcdx-navy); border-color: var(--line);
}
.imp-btn-ghost:hover{ background:#f8fafc; }

/* =========================================
   トースト
   ========================================= */
#imp-toast{
  display:none; position:fixed; left:50%; transform:translateX(-50%);
  bottom:28px; background:#fff; border:2px solid #cfe0ff;
  padding:12px 16px; border-radius:12px; box-shadow:var(--shadow);
  z-index:10000; font-weight:700; color:var(--pcdx-navy); text-align:center;
  max-width:92%;
}

/* =========================================
   細かなレスポンシブ
   ========================================= */
@media (max-width: 520px){
  .imp-card{ padding:22px; }
  .imp-title{ font-size:20px; }
  .imp-btn{ font-size:13.5px; padding:11px 12px; }
}

/* 表示切替ユーティリティ */
.is-hidden { display:none; }
.is-visible { display:block; }
