/* =======================================================
 * praze-ui.css — praze-* ユーティリティ共通クラス
 * 全ページで読み込む（components.css の次）
 * ======================================================= */

/* ── ロゴ ── */
.praze-logo {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--color-navy);
  text-decoration: none;
}
.praze-logo:hover { color: var(--color-blue); }

/* ── ボタン ── */
.praze-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--color-blue);
  color: #fff !important;
  border: none;
  border-radius: var(--radius-md);
  padding: 12px 24px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, box-shadow 0.15s;
  white-space: nowrap;
}
.praze-btn-primary:hover {
  background: var(--color-blue-hover);
  box-shadow: 0 4px 14px rgba(37,99,235,0.35);
}
.praze-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: transparent;
  color: var(--color-text-primary);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: 12px 24px;
  font-size: 15px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s;
}
.praze-btn-secondary:hover { background: var(--color-bg-section); color: var(--color-text-primary); }

.praze-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: transparent;
  color: var(--color-blue);
  border: 1px solid var(--color-blue);
  border-radius: var(--radius-md);
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s;
}
.praze-btn-outline:hover { background: var(--color-blue-light); color: var(--color-blue); }

.praze-btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: transparent;
  color: #dc2626;
  border: 1px solid #dc2626;
  border-radius: var(--radius-md);
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s;
}
.praze-btn-danger:hover { background: #fef2f2; }
.praze-btn-danger:disabled { opacity: 0.6; cursor: not-allowed; }

.praze-btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}
.praze-btn-ghost:hover { background: var(--color-bg-section); color: var(--color-text-primary); }

.praze-btn-block { width: 100%; }

/* ── アラート ── */
.praze-error {
  background: var(--color-error-light, #FEF2F2);
  border: 1px solid var(--color-error, #EF4444);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
  font-size: 14px;
  color: #991B1B;
}
.praze-error p { margin: 4px 0; }

.praze-success {
  background: var(--color-success-light, #ECFDF5);
  border: 1px solid var(--color-success, #10B981);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
  font-size: 14px;
  color: #065F46;
}

.praze-info-box {
  background: var(--color-blue-light, #EFF6FF);
  border: 1px solid var(--color-blue, #2563EB);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  font-size: 14px;
  color: #1E40AF;
  margin-bottom: var(--space-lg);
}

.praze-notice-box {
  background: var(--color-warning-light, #FFFBEB);
  border: 1px solid var(--color-warning, #F59E0B);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  font-size: 14px;
  color: #92400E;
  margin-bottom: var(--space-lg);
}

/* ── フォーム ── */
.praze-form-group {
  margin-bottom: var(--space-lg);
}
.praze-form-group label {
  display: block;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-primary);
  margin-bottom: 6px;
}
.praze-form-group input[type="text"],
.praze-form-group input[type="email"],
.praze-form-group input[type="url"],
.praze-form-group input[type="password"],
.praze-form-group input[type="number"],
.praze-form-group select,
.praze-form-group textarea {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: 15px;
  color: var(--color-text-primary);
  background: #fff;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
  font-family: var(--font-sans);
}
.praze-form-group input:focus,
.praze-form-group select:focus,
.praze-form-group textarea:focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.1);
}
.praze-form-group textarea { min-height: 120px; resize: vertical; }
.praze-form-group small {
  display: block;
  font-size: 12px;
  color: var(--color-text-muted);
  margin-top: 4px;
}

.praze-required { color: var(--color-error, #EF4444); margin-left: 2px; }

.praze-terms-check {
  margin-bottom: var(--space-lg);
  font-size: 13px;
  color: var(--color-text-secondary);
}
.praze-terms-check label {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  cursor: pointer;
}
.praze-terms-check a { color: var(--color-blue); }

/* ── 認証ボックス ── */
.praze-auth-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 200px);
  padding: var(--space-2xl) var(--space-lg);
}
.praze-auth-box {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 48px 40px;
  max-width: 480px;
  width: 100%;
  text-align: center;
  box-shadow: var(--shadow-md);
}
.praze-auth-box .praze-logo { display: block; margin-bottom: var(--space-lg); color: var(--color-navy); }
.praze-auth-box h2 { font-size: 22px; font-weight: 700; margin-bottom: var(--space-md); }
.praze-auth-box p { font-size: 14px; color: var(--color-text-secondary); line-height: 1.7; margin-bottom: var(--space-sm); }

.praze-success-icon { font-size: 48px; margin-bottom: var(--space-lg); }

.praze-login-form { text-align: left; margin-top: var(--space-lg); }
.praze-login-form label {
  display: block;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 6px;
}
.praze-login-form input[type="email"] {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: 15px;
  margin-bottom: var(--space-md);
  box-sizing: border-box;
}
.praze-login-form input:focus { outline: none; border-color: var(--color-blue); }
.praze-login-form .praze-btn-primary { width: 100%; }

/* ── ページラッパー ── */
.praze-page-wrap {
  width: 100%;
  min-height: calc(100vh - 64px);
  background: var(--color-bg-page);
}

/* ── ページ共通ヘッダー（濃紺）── */
.praze-register-header {
  background: var(--color-navy);
  color: #fff;
  text-align: center;
  padding: 48px 20px 40px;
}
.praze-register-header .praze-logo {
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 16px;
  display: block;
}
.praze-register-header h1 {
  font-size: 28px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 12px;
}
.praze-register-header p {
  font-size: 15px;
  color: rgba(255,255,255,0.75);
  line-height: 1.7;
  max-width: 600px;
  margin: 0 auto;
}

/* ── 掲載企業一覧グリッド ── */
.praze-company-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}
.praze-company-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: box-shadow 0.2s, transform 0.2s;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.praze-company-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
  color: inherit;
}
.praze-company-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text-primary);
}
.praze-company-url {
  font-size: 12px;
  color: var(--color-blue);
  word-break: break-all;
}
.praze-company-meta {
  font-size: 12px;
  color: var(--color-text-muted);
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-top: auto;
}

/* ── コンテンツ中央寄せラッパー ── */
.praze-content-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-2xl) var(--space-lg);
}

@media (max-width: 767px) {
  .praze-register-header { padding: 32px 16px; }
  .praze-register-header h1 { font-size: 22px; }
  .praze-company-grid { grid-template-columns: 1fr; }
}

/* ── 空状態 ── */
.praze-empty {
  text-align: center;
  padding: 60px var(--space-lg);
  color: var(--color-text-muted);
}
.praze-empty p { font-size: 15px; margin-bottom: var(--space-lg); }

/* ── ページネーション ── */
.praze-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin-top: var(--space-2xl);
  flex-wrap: wrap;
}
.praze-page-link,
.praze-page-current {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  font-size: 14px;
  text-decoration: none;
  transition: background 0.15s;
}
.praze-page-link {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  color: var(--color-text-primary);
}
.praze-page-link:hover { background: var(--color-blue-light); color: var(--color-blue); border-color: var(--color-blue); }
.praze-page-current {
  background: var(--color-blue);
  color: #fff;
  font-weight: 700;
  border: 1px solid var(--color-blue);
}

/* =======================================================
 * マイページ praze-*
 * ======================================================= */
.praze-mypage {
  display: block;
  min-height: calc(100vh - 64px);
  background: var(--color-bg-page);
}
.praze-mypage-body {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-2xl);
}

.praze-mypage-header {
  background: var(--color-navy);
  color: #fff;
  padding: 32px var(--space-2xl);
}
.praze-mypage-header-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-lg);
  flex-wrap: wrap;
}
.praze-mypage-header h1 {
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  margin: 0;
}
.praze-mypage-header p {
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  margin: 4px 0 0;
}

.praze-mypage-stats {
  display: flex;
  gap: var(--space-xl);
  flex-wrap: wrap;
  margin-bottom: var(--space-xl);
}
.praze-stat-pill {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  text-align: center;
  min-width: 100px;
}
.praze-stat-num {
  font-family: var(--font-numeric);
  font-size: 28px;
  font-weight: 700;
  color: var(--color-blue);
  line-height: 1;
}
.praze-stat-label {
  font-size: 12px;
  color: var(--color-text-muted);
  margin-top: 4px;
}

/* タブ */
.praze-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--color-border);
  margin-bottom: var(--space-lg);
  overflow-x: auto;
  scrollbar-width: none;
}
.praze-tabs::-webkit-scrollbar { display: none; }
.praze-tab {
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.praze-tab:hover { color: var(--color-text-primary); }
.praze-tab.active {
  color: var(--color-blue);
  border-bottom-color: var(--color-blue);
  font-weight: 600;
}
.praze-tab-count {
  background: var(--color-bg-section);
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: 700;
  padding: 2px 7px;
  color: var(--color-text-muted);
}
.praze-tab.active .praze-tab-count {
  background: var(--color-blue-light);
  color: var(--color-blue);
}

.praze-tab-content { display: none; }
.praze-tab-content.active { display: block; }

/* 記事セット */
.praze-article-set {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-lg);
  overflow: hidden;
}
.praze-set-header {
  background: var(--color-bg-section);
  padding: var(--space-md) var(--space-lg);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary);
  border-bottom: 1px solid var(--color-border);
}

/* 記事カード（マイページ） */
.praze-article-card {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-md);
  overflow: hidden;
}
.praze-article-card-main {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  padding: var(--space-lg);
  border-bottom: 1px solid var(--color-border);
}
.praze-article-card-main:last-child { border-bottom: none; }
.praze-article-type {
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background: var(--color-bg-section);
  color: var(--color-text-secondary);
}
.praze-article-title {
  display: block !important;
  width: 100% !important;
  font-size: 15px !important;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 4px;
  line-height: 1.5;
  writing-mode: horizontal-tb !important;
}
.praze-article-meta {
  font-size: 12px;
  color: var(--color-text-muted);
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  margin-bottom: var(--space-sm);
}
.praze-article-stats {
  display: flex;
  gap: var(--space-md);
  font-size: 12px;
  color: var(--color-text-muted);
  flex-wrap: wrap;
}
.praze-article-actions {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-top: var(--space-sm);
}

/* 品質スコア */
.praze-quality-score {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--color-success-light);
  color: #065F46;
}

/* 永久保存 */
.praze-permanent-box {
  background: var(--color-blue-light);
  border: 1px solid var(--color-blue);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-xl);
}
.praze-permanent-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-md);
}

/* バッジ */
.praze-badge-icon { font-size: 28px; margin-bottom: 8px; }
.praze-badge-permanent { color: var(--color-blue); font-weight: 600; font-size: 13px; }
.praze-badge-pending   { color: var(--color-warning, #F59E0B); font-weight: 600; font-size: 13px; }
.praze-badge-verified  { color: var(--color-success, #10B981); font-weight: 600; font-size: 13px; }

/* モーダル */
.praze-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
}
.praze-modal.is-open { display: flex; }
.praze-modal-inner,
.praze-revision-modal {
  background: var(--color-bg-card);
  border-radius: var(--radius-xl);
  padding: 32px;
  max-width: 560px;
  width: 100%;
  max-height: 80vh;
  overflow-y: auto;
  position: relative;
  box-shadow: var(--shadow-xl, 0 20px 60px rgba(0,0,0,0.3));
}
.praze-revision-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--color-text-secondary);
  line-height: 1;
}

/* ── 公開用記事カード ── */
.praze-article-card--public {
  transition: box-shadow 0.2s, transform 0.2s;
}
.praze-article-card--public:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.praze-article-card-body {
  padding: var(--space-lg);
}
.praze-article-card-footer {
  padding: var(--space-sm) var(--space-lg) var(--space-md);
  border-top: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}
.praze-article-excerpt {
  font-size: 14px;
  color: var(--color-text-secondary);
  line-height: 1.75;
  margin: var(--space-sm) 0 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.praze-article-company {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-blue);
  text-decoration: none;
}
.praze-article-company:hover { text-decoration: underline; }
.praze-article-date {
  font-size: 12px;
  color: var(--color-text-muted);
}
.praze-view-count {
  font-size: 12px;
  color: var(--color-text-muted);
  white-space: nowrap;
}
.praze-btn-sm {
  padding: 6px 12px !important;
  font-size: 12px !important;
}

/* タイプ別バッジカラー */
.praze-type-press {
  background: var(--color-blue-light);
  color: var(--color-blue);
}
.praze-type-lp {
  background: var(--color-success-light);
  color: #065F46;
}
.praze-type-ad {
  background: var(--color-warning-light);
  color: #92400E;
}

/* 有料登録 CTA */
.praze-register-cta {
  background: var(--color-blue-light);
  border: 1px solid var(--color-blue);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-2xl);
  text-align: center;
  margin: var(--space-2xl) auto;
  max-width: 600px;
}

/* プラン選択グループ（有料登録） */
.praze-plan-select-group {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

/* 記事投稿フォームラッパー */
.praze-submit-form-wrap {
  max-width: 760px;
  margin: 0 auto;
  padding: var(--space-2xl) var(--space-lg);
}

/* =======================================================
 * パートナーページ praze-*
 * ======================================================= */
.praze-partners-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}

.praze-partner-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow 0.2s, transform 0.2s;
  display: flex;
  flex-direction: column;
}
.praze-partner-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.praze-partner-badge-icon {
  background: var(--color-bg-section);
  padding: var(--space-xl);
  text-align: center;
  font-size: 48px;
}

.praze-partner-info {
  padding: var(--space-lg);
  flex: 1;
}

.praze-partner-pr {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: var(--space-sm);
}

.praze-partner-url {
  font-size: 12px;
  color: var(--color-blue);
  text-decoration: none;
  word-break: break-all;
}
.praze-partner-url:hover { text-decoration: underline; }

.praze-partner-date {
  font-size: 11px;
  color: var(--color-text-muted);
  margin-top: var(--space-sm);
}

.praze-partner-footer {
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--color-border);
  text-align: center;
}

/* =======================================================
 * SP レスポンシブ
 * ======================================================= */
@media (max-width: 767px) {
  .praze-mypage { grid-template-columns: 1fr; }
  .praze-mypage-header { padding: var(--space-lg); }
  .praze-mypage-stats { gap: var(--space-md); }
  .praze-permanent-grid { grid-template-columns: 1fr; }
  .praze-plan-select-group { grid-template-columns: 1fr; }
  .praze-partners-grid { grid-template-columns: repeat(2, 1fr); }
  .praze-article-card-main { flex-direction: column; }
  .praze-auth-box { padding: 32px 20px; }
  .praze-revision-modal { padding: 24px 16px; }
}
@media (max-width: 480px) {
  .praze-partners-grid { grid-template-columns: 1fr; }
}
