/*
 * Instant Share Page — Manager 画面固有スタイル
 * 共通スタイルは common.css に分離している。
 */

.isp-manager .isp-stage--loading {
	text-align: center;
	padding: 2rem 0;
}

/* ステータスカード */
.isp-status-card {
	margin: 1rem 0 1.5rem;
	padding: 1.25rem;
	background: linear-gradient(135deg, #f8fafc, #ffffff);
	border: 1px solid var(--isp-border);
	border-radius: var(--isp-radius);
}

.isp-status-card__head {
	margin-bottom: 1rem;
}

.isp-status-badge {
	display: inline-block;
	padding: 0.35rem 0.95rem;
	background: var(--isp-bg-soft);
	border: 1px solid var(--isp-border);
	border-radius: 9999px;
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.02em;
}

.isp-status-badge.is-active {
	background: var(--isp-success-soft);
	border-color: #86efac;
	color: #166534;
}

.isp-status-badge.is-expired {
	background: #ffedd5;
	border-color: #fdba74;
	color: #c2410c;
}

.isp-status-badge.is-exhausted {
	background: var(--isp-warning-soft);
	border-color: var(--isp-warning-border);
	color: #92400e;
}

.isp-status-badge.is-deleted {
	background: var(--isp-error-soft);
	border-color: var(--isp-error-border);
	color: var(--isp-error);
}

.isp-status-list {
	margin: 0;
	padding: 0;
}

.isp-status-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	padding: 0.55rem 0;
	border-bottom: 1px dashed var(--isp-border);
}

.isp-status-row:last-child {
	border-bottom: none;
}

.isp-status-row dt {
	margin: 0;
	color: var(--isp-muted);
	font-size: 0.9rem;
	flex-shrink: 0;
}

.isp-status-row dd {
	margin: 0;
	color: var(--isp-fg-strong);
	font-weight: 600;
	font-family: var(--isp-font-mono);
	font-size: 0.9rem;
	text-align: right;
	word-break: break-all;
}

.isp-status-row.is-warning dd {
	color: var(--isp-error);
}

/* 履歴 */
.isp-history {
	margin: 1.5rem 0;
	padding: 1.25rem;
	background: var(--isp-bg-soft);
	border: 1px solid var(--isp-border);
	border-radius: var(--isp-radius-sm);
}

.isp-history__heading {
	display: flex;
	align-items: center;
	gap: 0.45rem;
	margin: 0 0 0.85rem;
	font-size: 1rem;
	color: var(--isp-fg-strong);
}

.isp-history-list {
	margin: 0;
	padding-left: 1.4rem;
	list-style: decimal;
	color: var(--isp-fg);
}

.isp-history-list li {
	margin: 0.3rem 0;
	font-family: var(--isp-font-mono);
	font-size: 0.85rem;
}

/* 削除ボタン */
.isp-actions {
	margin-top: 1.5rem;
	display: flex;
	justify-content: center;
}

.isp-btn--danger {
	background: linear-gradient(135deg, #ef4444, #dc2626);
	color: #ffffff;
	box-shadow: 0 2px 6px rgba(220, 38, 38, 0.25);
	padding: 0.7rem 1.5rem;
}

.isp-btn--danger:hover:not(:disabled) {
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(220, 38, 38, 0.35);
}

.isp-btn--danger:active:not(:disabled) {
	transform: translateY(0);
	box-shadow: 0 2px 4px rgba(220, 38, 38, 0.25);
}

.isp-btn--danger:disabled {
	background: var(--isp-muted-soft);
	color: #ffffff;
	box-shadow: none;
}

/* 削除完了 */
.isp-stage--deleted {
	animation: isp-fade-in 0.3s ease;
}

.isp-success-block {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 2rem 1rem;
	gap: 0.5rem;
}

.isp-success-block .isp-success-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 4rem;
	height: 4rem;
	margin-bottom: 0.5rem;
	background: linear-gradient(135deg, var(--isp-success), #22c55e);
	color: #ffffff;
	border-radius: 50%;
	box-shadow: 0 6px 16px rgba(22, 163, 74, 0.3);
	animation: isp-success-pop 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.isp-success-block .isp-success-icon svg {
	width: 2rem;
	height: 2rem;
}

@keyframes isp-success-pop {
	0%   { opacity: 0; transform: scale(0.3); }
	60%  { opacity: 1; transform: scale(1.08); }
	100% { opacity: 1; transform: scale(1); }
}

@keyframes isp-fade-in {
	from { opacity: 0; transform: translateY(4px); }
	to   { opacity: 1; transform: translateY(0); }
}

.isp-success-text {
	margin: 0;
	font-weight: 600;
	color: var(--isp-fg-strong);
}

/* エラーステージは viewer.css 同等(ここに最低限定義) */
.isp-stage--error {
	text-align: center;
	padding: 1.5rem 0;
}

.isp-error-block {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 0.85rem;
	max-width: 360px;
	margin: 0 auto;
}

.isp-error-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3.5rem;
	height: 3.5rem;
	background: var(--isp-error-soft);
	color: var(--isp-error);
	border-radius: 50%;
}

.isp-error-icon svg {
	width: 1.75rem;
	height: 1.75rem;
}

.isp-error-message {
	margin: 0;
	color: var(--isp-fg);
	font-size: 0.95rem;
	line-height: 1.55;
}

@media (max-width: 600px) {
	.isp-status-row {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.25rem;
	}

	.isp-status-row dd {
		text-align: left;
	}
}
