/* Configuration Constants */
:root {
	--space-xs: 0.3125rem;
	--space-sm: 0.625rem;
	--space-md: 0.9375rem;
	--space-lg: 1.25rem;
	--space-xl: 1.5rem;
	--color-border: var(--border-color);
	--color-border-light: rgba(0, 0, 0, 0.2);
	--color-shadow: rgba(0, 0, 0, 0.1);
	--color-background-alt: var(--hover-bg);
	--status-pending: var(--pending-bg);
	--status-scheduled: var(--scheduled-bg);
	--status-published: var(--published-bg);
	--status-failed: var(--failed-bg);
	--success-bg: #d4edda;
	--success-text: var(--mid-shade);
	--error-bg: #f8d7da;
	--error-text: var(--mid-shade);
	--mid-shade: #666;
	--text-color: var(--mid-shade);
}

html:has(.dark-mode-toggle:checked) {
	--color-border: var(--border-color);
	--color-border-light: rgba(255, 255, 255, 0.2);
	--color-background-alt: var(--hover-bg);
	--status-pending: var(--pending-bg);
	--status-scheduled: var(--scheduled-bg);
	--status-published: var(--published-bg);
	--status-failed: var(--failed-bg);
	--success-bg: #155724;
	--success-text: #fff;
	--error-bg: #721c24;
	--error-text: #fff;
	--text-color: #fff;
}

pre { color: #000;}

/* Dashboard specific styles */
.stats-container {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.stat-box {
	padding: 1rem;
	background: var(--card-bg);
	border: 3px solid var(--border-color);
	transform: translate(-3px, -3px);
	position: relative;
}

.stat-box::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 100%;
	height: 100%;
	background: var(--border-color);
	z-index: -1;
}

.stat-box:has(.status.pending) {
	border-top: 6px solid var(--pending-bg);
}

.stat-box:has(.status.scheduled) {
	border-top: 6px solid var(--scheduled-bg);
}

.stat-box:has(.status.published) {
	border-top: 6px solid var(--published-bg);
}

.stat-box:has(.status.failed) {
	border-top: 6px solid var(--failed-bg);
}

.stat-label {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
}

.stat-number {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--mid-shade);
}

.data-table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	margin-top: 1rem;
	overflow: hidden;
	background: var(--table-bg);
	border: 3px solid var(--border-color);
	transform: translate(-3px, -3px);
	position: relative;
}

.data-table::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 100%;
	height: 100%;
	background: var(--border-color);
	z-index: -1;
}

.data-table th {
	text-align: left;
	padding: 0.75rem 1rem;
	font-weight: 700;
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.025em;
	background-color: var(--table-header-bg);
	border-bottom: 3px solid var(--border-color);
}

.data-table thead tr {
	background-color: var(--table-header-bg);
}

.data-table td {
	padding: 0.75rem 1rem;
	border-top: 1px solid var(--border-color);
	font-size: 0.875rem;
}

.data-table tr:nth-child(even) {
	background-color: var(--table-alt-bg);
}

.data-table tr:hover {
	background-color: var(--hover-bg);
	transition: transform 0.1s ease;
}

.api-credentials {
	background-color: var(--card-bg);
	padding: 1rem;
	margin-bottom: 1.5rem;
	border: 3px solid var(--border-color);
	border-left: 8px solid var(--pending-bg);
	transform: translate(-3px, -3px);
	position: relative;
}

.api-credentials::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: calc(100% - 5px);
	height: 100%;
	background: var(--border-color);
	z-index: -1;
}

/* Action Buttons */
.action-buttons {
	display: flex;
	gap: 0.5rem;
	justify-content: flex-end;
}

.btn {
	padding: 0.5rem 0.75rem;
	font-size: 0.8rem;
	font-weight: 700;
	border: 2px solid var(--border-color);
	cursor: pointer;
	color: var(--mid-shade);
	transform: translate(-2px, -2px);
	position: relative;
	transition: transform 0.1s ease;
}

.btn::after {
	content: "";
	position: absolute;
	top: 2px;
	left: 2px;
	width: 100%;
	height: 100%;
	background: var(--border-color);
	z-index: -1;
}

.btn:hover {
	transform: translate(0, 0);
}

.btn-approve {
	background-color: var(--published-bg);
}

.btn-approve:hover {
	background-color: var(--published-bg);
}

.btn-edit {
	background-color: var(--pending-bg);
}

.btn-edit:hover {
	background-color: var(--pending-bg);
}

.btn-reject {
	background-color: var(--failed-bg);
}

.btn-reject:hover {
	background-color: var(--failed-bg);
}

/* Status Badges */
.status-badge {
	display: inline-block;
	padding: 0.25rem 0.5rem;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	border: 2px solid var(--border-color);
	transform: rotate(-1deg);
	color: var(--mid-shade);
}

.status-pending {
	background-color: var(--pending-bg);
}

.status-scheduled {
	background-color: var(--scheduled-bg);
}

.status-published {
	background-color: var(--published-bg);
}

.status-failed {
	background-color: var(--failed-bg);
}

/* Form Styles */
.form-group {
	margin-bottom: 1.5rem;
}

.form-label {
	display: block;
	margin-bottom: 0.5rem;
	font-size: 0.875rem;
	font-weight: 700;
}

.form-control {
	display: block;
	width: 100%;
	padding: 0.75rem 1rem;
	font-size: 0.875rem;
	border: 3px solid var(--border-color);
	background-color: var(--content-bg);
	color: var(--text-color);
	transition: border-color var(--transition-speed) ease;
	transform: translate(-3px, -3px);
	position: relative;
}

.form-control::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 100%;
	height: 100%;
	background: var(--border-color);
	z-index: -1;
}

.form-control:focus {
	border-color: var(--pending-bg);
	outline: none;
}

.btn-primary {
	background-color: var(--pending-bg);
	color: var(--mid-shade);
	border: 3px solid var(--border-color);
	padding: 0.75rem 1rem;
	font-size: 0.875rem;
	font-weight: 700;
	cursor: pointer;
	transition: transform var(--transition-speed) ease;
	transform: translate(-3px, -3px);
	position: relative;
}

.btn-primary::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 100%;
	height: 100%;
	background: var(--border-color);
	z-index: -1;
}

.btn-primary:hover {
	background-color: var(--hover-bg);
	transform: translate(0, 0);
}


/* Common */
.samcast-dashboard {
	margin: var(--space-lg) 0;
	font-family: system-ui, sans-serif;
	color: var(--text-color);
}

/* Stats Cards */
.samcast-stats {
	display: flex;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
}

@media (max-width: 600px) {
	.samcast-stats {
		flex-direction: column;
	}
}

.samcast-status-card {
	flex: 1;
	padding: var(--space-lg);
	background: var(--card-bg-1);
	border: 3px solid var(--color-border);
	transform: translate(-3px, -3px);
	position: relative;
	transition: transform 0.1s ease;
}

.samcast-status-card:hover {
	transform: translate(-5px, -5px);
}

.samcast-status-card h4 {
	margin: 0 0 var(--space-xs) 0;
	font-weight: 800;
	text-transform: uppercase;
}

.samcast-status-card span {
	font-size: 1.5rem;
	font-weight: 800;
}

.samcast-status-card.samcast-status-pending {
	border-left: 8px solid var(--status-pending);
}

.samcast-status-card.samcast-status-scheduled {
	border-left: 8px solid var(--status-scheduled);
}

.samcast-status-card.samcast-status-published {
	border-left: 8px solid var(--status-published);
}

.samcast-status-card.samcast-status-failed {
	border-left: 8px solid var(--status-failed);
}

/* Posts Table */
.samcast-posts-table {
	background: var(--table-bg);
	border: 3px solid var(--color-border);
	transform: translate(-3px, -3px);
	position: relative;
}

.samcast-table-header {
	display: grid;
	/* grid-template-columns: 1fr 1fr 2fr 1fr 1fr 2fr; */
	grid-template-columns: 5% 10% 50% 10% 10% 15%;
	font-weight: 700;
	background: var(--table-header-bg);
	border-bottom: 2px solid var(--color-border);
	text-transform: uppercase;
	font-size: 0.8rem;
}

.samcast-post-row {
	display: grid;
	/* grid-template-columns: 1fr 1fr 2fr 1fr 1fr 2fr; */
	grid-template-columns: 5% 10% 50% 10% 10% 15%;
	border-bottom: 1px solid var(--color-border-light);
	transition: transform 0.1s ease;
}
.samcast-table .samcast-post-row {
	display: table-row;
}

.samcast-post-row:nth-child(even) {
	background-color: var(--table-alt-bg);
}

.samcast-post-row:hover {
	background: var(--hover-bg);
}

.samcast-table-header > div {
	padding: var(--space-md);
}

.samcast-post-row > div {
	padding: var(--space-md);
}


















/* Container styles for the card fan */
.samcast-post-images {
    position: relative;
    width: 150px;
    height: 120px;
    display: inline-block;
    transition: width 0.4s ease;
    perspective: 800px;
    cursor: pointer;
}

/* Base card styles */
.samcast-post-image {
    position: absolute;
    width: 100px;
    height: auto;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    transform-origin: bottom left;
    transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), 
                box-shadow 0.3s ease;
    background-color: #fff;
    /* border: 1px solid rgba(0, 0, 0, 0.1); */
}

/* Initial stacked position with subtle offsets */
.samcast-post-image:nth-child(1) { transform: rotate(-6deg); z-index: 10; }
.samcast-post-image:nth-child(2) { transform: rotate(-5deg); z-index: 9; }
.samcast-post-image:nth-child(3) { transform: rotate(-4deg); z-index: 8; }
.samcast-post-image:nth-child(4) { transform: rotate(-3deg); z-index: 7; }
.samcast-post-image:nth-child(5) { transform: rotate(-2deg); z-index: 6; }
.samcast-post-image:nth-child(6) { transform: rotate(-1deg); z-index: 5; }
.samcast-post-image:nth-child(7) { transform: rotate(0deg); z-index: 4; }
.samcast-post-image:nth-child(8) { transform: rotate(1deg); z-index: 3; }
.samcast-post-image:nth-child(9) { transform: rotate(2deg); z-index: 2; }
.samcast-post-image:nth-child(10) { transform: rotate(3deg); z-index: 1; }

/* Expand container on hover to fit the fanned cards */
.samcast-post-images:hover {
    width: 500px;
}

/* Hover fan-out effect with natural arc/parabola shape */
.samcast-post-images:hover .samcast-post-image:nth-child(1) {
    transform: translateX(0) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(2) {
    transform: translateX(50px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(3) {
    transform: translateX(100px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(4) {
    transform: translateX(150px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(5) {
    transform: translateX(200px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(6) {
    transform: translateX(250px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(7) {
    transform: translateX(300px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(8) {
    transform: translateX(350px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(9) {
    transform: translateX(400px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

.samcast-post-images:hover .samcast-post-image:nth-child(10) {
    transform: translateX(450px) rotate(-15deg);
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

/* Add extra container space for elevated cards */
.samcast-post-images {
    margin-bottom: 20px;
    padding-top: 15px;
}

/* Fix for individual card hover effect */
.samcast-post-images .samcast-post-image {
    transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), 
                box-shadow 0.3s ease,
                z-index 0s;
}

/* Stronger selector to ensure this rule takes precedence */
.samcast-post-images .samcast-post-image:hover {
    box-shadow: 0 15px 25px #FFFFFF33 !important;
}



















.samcast-post-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
}

/* API Section */
.samcast-api-section {
	margin-bottom: var(--space-xl);
	padding: 1.5rem;
	background: var(--bg-color-3);
	border: 3px solid var(--color-border);
	border-left: 8px solid var(--status-pending);
	transform: translate(-3px, -3px);
	position: relative;
}
.samcast-api-section h3 {
	margin-top: 0;
	display: inline-block;
	margin-right: var(--space-sm);
	font-weight: 800;
	text-transform: uppercase;
	border-bottom: 2px solid var(--color-border);
}

.samcast-api-note {
	font-size: 0.8em;
	font-weight: 600;
	margin-top: var(--space-sm);
}

.samcast-api-content {
	margin: var(--space-md) 0;
}

.samcast-api-row {
	margin-bottom: var(--space-sm);
}

.samcast-api-label {
	font-weight: 700;
	min-width: 5rem;
	display: inline-block;
	text-transform: uppercase;
	font-size: 0.8rem;
}

.samcast-api-section code {
	background: #f5f5f5;
	padding: 0.25rem var(--space-sm);
	border: 2px solid var(--color-border);
	font-family: monospace;
	font-weight: 600;
}

html:has(.dark-mode-toggle:checked) .samcast-api-section code {
	background: #2d3748;
}

.samcast-api-desc {
	font-size: 0.9em;
	font-weight: 600;
	margin-top: var(--space-xs);
}

/* Forms */
.samcast-form {
	max-width: 25rem;
}

form {
	max-width: 25rem;
}

.samcast-button {
	background: var(--status-pending);
	color: var(--mid-shade);
	border: 3px solid var(--color-border);
	padding: 0.75rem var(--space-md);
	cursor: pointer;
	font-weight: 700;
	transform: translate(-3px, -3px);
	position: relative;
	transition: transform 0.1s ease;
}

.samcast-button::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 100%;
	height: 100%;
	background: var(--color-border);
	z-index: -1;
}

.samcast-button:hover {
	background: var(--hover-bg);
	transform: translate(0, 0);
}

/* Messages */
.samcast-success-message {
	background: var(--success-bg);
	color: var(--success-text);
	padding: var(--space-md);
	border: 2px solid var(--color-border);
	margin-bottom: var(--space-md);
	font-weight: 600;
	transform: rotate(-0.5deg);
}

.samcast-error-message {
	background: var(--error-bg);
	color: var(--error-text);
	padding: var(--space-md);
	border: 2px solid var(--color-border);
	margin-bottom: var(--space-md);
	font-weight: 600;
	transform: rotate(0.5deg);
}

/* Highlight Effect */
@keyframes highlight-fade {
	from {
		background-color: var(--hover-bg);
		transform: scale(1.02);
	}
	to {
		background-color: transparent;
		transform: scale(1);
	}
}

.highlight {
	animation: highlight-fade 2s ease-out;
}

/* Inputs */
input[type="text"],
input[type="email"],
input[type="password"] {
	width: 100%;
	padding: 0.75rem;
	margin-bottom: var(--space-md);
	border: 3px solid var(--color-border);
	background: var(--content-bg);
	color: var(--text-color);
	transform: translate(-3px, -3px);
	position: relative;
	transition: transform 0.1s ease;
}

input[type="text"]::after,
input[type="email"]::after,
input[type="password"]::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 100%;
	height: 100%;
	background: var(--color-border);
	z-index: -1;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus {
	outline: none;
	border-color: var(--pending-bg);
	transform: translate(-2px, -2px);
}

input[type="submit"] {
	padding: var(--space-md) var(--space-lg);
	background: var(--status-pending);
	color: var(--mid-shade);
	border: 3px solid var(--color-border);
	cursor: pointer;
	font-weight: 700;
	transform: translate(-3px, -3px);
	position: relative;
	transition: transform 0.1s ease;
}

input[type="submit"]::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 100%;
	height: 100%;
	background: var(--color-border);
	z-index: -1;
}

input[type="submit"]:hover {
	background: var(--hover-bg);
	transform: translate(0, 0);
}






#api-output {
    color: #000;;
}