/* PostPulse Public Widget Styles */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&display=swap');

:root {
	--pp-accent: #6366f1;
}

/* ── Base widget ──────────────────────────────────────────────────────── */
.postpulse-widget {
	font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
	margin: 28px 0;
	border-radius: 14px;
	overflow: hidden;
	position: relative;
}

/* ── Light mode ──────────────────────────────────────────────────────── */
.postpulse-widget.postpulse-mode-light {
	background: #fff;
	border: 1px solid #e5e7eb;
	box-shadow: 0 4px 24px rgba(0,0,0,.06), 0 1px 4px rgba(0,0,0,.04);
}
.postpulse-widget.postpulse-mode-light .postpulse-header {
	background: linear-gradient(135deg, var(--pp-accent) 0%, color-mix(in srgb, var(--pp-accent) 80%, #000 20%) 100%);
}
.postpulse-widget.postpulse-mode-light .postpulse-title { color: #fff; }
.postpulse-widget.postpulse-mode-light .postpulse-icon { color: rgba(255,255,255,.85); }
.postpulse-widget.postpulse-mode-light .postpulse-list { background: #fff; }
.postpulse-widget.postpulse-mode-light .postpulse-list li { color: #374151; border-bottom: 1px solid #f3f4f6; }
.postpulse-widget.postpulse-mode-light .postpulse-list li:last-child { border-bottom: none; }
.postpulse-widget.postpulse-mode-light .postpulse-list-icon { color: var(--pp-accent); }

/* ── Dark mode ──────────────────────────────────────────────────────── */
.postpulse-widget.postpulse-mode-dark {
	background: #1e1b4b;
	border: 1px solid rgba(255,255,255,.08);
	box-shadow: 0 4px 24px rgba(0,0,0,.3);
}
.postpulse-widget.postpulse-mode-dark .postpulse-header {
	background: rgba(0,0,0,.25);
	border-bottom: 1px solid rgba(255,255,255,.07);
}
.postpulse-widget.postpulse-mode-dark .postpulse-title { color: #e0e7ff; }
.postpulse-widget.postpulse-mode-dark .postpulse-icon { color: var(--pp-accent); }
.postpulse-widget.postpulse-mode-dark .postpulse-list li { color: #c7d2fe; border-bottom: 1px solid rgba(255,255,255,.05); }
.postpulse-widget.postpulse-mode-dark .postpulse-list li:last-child { border-bottom: none; }
.postpulse-widget.postpulse-mode-dark .postpulse-list-icon { color: var(--pp-accent); }

/* ── Header ──────────────────────────────────────────────────────────── */
.postpulse-header {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 16px 22px;
}
.postpulse-icon {
	font-size: 18px;
	line-height: 1;
	flex-shrink: 0;
}
.postpulse-title {
	margin: 0;
	padding: 0;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: -.01em;
	border: none;
}

/* ── List ──────────────────────────────────────────────────────────── */
.postpulse-list {
	margin: 0;
	padding: 0;
	list-style: none;
}
.postpulse-list li {
	display: flex;
	align-items: baseline;
	gap: 10px;
	padding: 13px 22px;
	font-size: 14.5px;
	line-height: 1.55;
	transition: background .15s ease;
}
.postpulse-list li:hover { background: rgba(99,102,241,.04); }
.postpulse-list-icon {
	flex-shrink: 0;
	font-size: 13px;
	font-weight: 700;
	min-width: 16px;
	text-align: center;
}

/* Numbered list */
.postpulse-list--numbered {
	counter-reset: pp-counter;
}
.postpulse-list--numbered li {
	counter-increment: pp-counter;
}
.postpulse-list--numbered li::before {
	content: counter(pp-counter);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--pp-accent);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	flex-shrink: 0;
}

/* ── Inline widget (full width) ────────────────────────────────────── */
.postpulse-inline {
	/* inherits .postpulse-widget */
}

/* ── Sidebar widget (float right) ────────────────────────────────── */
.postpulse-sidebar {
	float: right;
	width: 300px;
	margin: 0 0 24px 28px;
}
@media (max-width: 640px) {
	.postpulse-sidebar {
		float: none;
		width: 100%;
		margin: 24px 0;
	}
}

/* ── Popup trigger button ─────────────────────────────────────────── */
.postpulse-popup-trigger {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 22px;
	background: var(--pp-accent);
	color: #fff;
	border: none;
	border-radius: 10px;
	font-family: 'DM Sans', sans-serif;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	margin: 16px 0;
	transition: transform .15s ease, box-shadow .15s ease;
	box-shadow: 0 4px 12px rgba(99,102,241,.35);
}
.postpulse-popup-trigger:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 18px rgba(99,102,241,.45);
}
.postpulse-popup-trigger:active { transform: translateY(0); }

/* ── Popup overlay ────────────────────────────────────────────────── */
.postpulse-popup-overlay {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,.55);
	backdrop-filter: blur(6px);
	z-index: 99999;
	align-items: center;
	justify-content: center;
	padding: 20px;
}
.postpulse-popup-overlay.is-open { display: flex; }

.postpulse-popup-box {
	position: relative;
	width: 100%;
	max-width: 520px;
	max-height: 80vh;
	overflow-y: auto;
	border-radius: 18px;
	animation: pp-slide-up .25s ease;
}
.postpulse-popup-box.postpulse-mode-light {
	background: #fff;
	box-shadow: 0 24px 64px rgba(0,0,0,.18);
}
.postpulse-popup-box.postpulse-mode-dark {
	background: #1e1b4b;
	box-shadow: 0 24px 64px rgba(0,0,0,.5);
}

@keyframes pp-slide-up {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}

.postpulse-popup-close {
	position: absolute;
	top: 14px;
	right: 16px;
	background: none;
	border: none;
	font-size: 22px;
	cursor: pointer;
	color: #9ca3af;
	line-height: 1;
	padding: 2px;
	transition: color .15s ease;
}
.postpulse-popup-close:hover { color: #374151; }
.postpulse-mode-dark .postpulse-popup-close:hover { color: #e0e7ff; }
