/**
 * Custom Blocks Styles
 * Styling for Randonneurs custom blocks and patterns
 */

/* ==========================================================================
   Section Utilities
   ========================================================================== */

.rs-section {
	padding: var(--space-8) 0;
}

.rs-section--welcome {
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* ==========================================================================
   Block Preview (in Editor)
   ========================================================================== */

.rs-block-preview {
	padding: var(--space-6);
	background: var(--color-light);
	border: 2px dashed var(--color-gray);
	border-radius: var(--radius);
	text-align: center;
}

.rs-block-preview__icon {
	font-size: 3rem;
	margin-bottom: var(--space-3);
}

/* ==========================================================================
   Cards Grid/List
   ========================================================================== */

.rs-cards {
	display: grid;
	gap: var(--space-4);
	margin-top: var(--space-6);
	/* prevent full-bleed: constrain width and center */
	/*max-width: calc(100% - 4rem);*/
	margin-left: auto;
	margin-right: auto;
	/*padding-left: 1.5rem;*/
	/*padding-right: 1.5rem;*/
}

.rs-cards--grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rs-cards--list {
	grid-template-columns: 1fr;
}

@media (max-width: 1024px) {
	.rs-cards--grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 768px) {
	.rs-cards--grid {
		grid-template-columns: 1fr;
	}
}

/* Card visuals are standardized in assets/css/main.css (.card and .rs-card). */

/* ==========================================================================
   Badge Component
   ========================================================================== */

.rs-badge {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	font-size: 0.875rem;
	font-weight: 600;
	white-space: nowrap;
}

.rs-badge--primary {
	background-color: var(--color-primary);
	color: white;
}

.rs-badge--secondary {
	background-color: var(--color-secondary);
	color: white;
}

.rs-badge--light {
	background-color: var(--color-light);
	color: var(--color-text);
}

/* ==========================================================================
   Button Component
   ========================================================================== */

.rs-button {
	display: inline-block;
	padding: 0.625rem 1.25rem;
	font-size: 1rem;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	border: 2px solid transparent;
	border-radius: 6px;
	cursor: pointer;
	transition: all 0.2s ease;
	line-height: 1.5;
}

.rs-button--primary {
	background-color: var(--color-primary);
	color: white;
	border-color: var(--color-primary);
}

.rs-button--primary:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: white;
}

.rs-button--secondary {
	background-color: var(--color-secondary);
	color: white;
	border-color: var(--color-secondary);
}

.rs-button--secondary:hover {
	background-color: var(--color-secondary-dark, #0284c7);
	border-color: var(--color-secondary-dark, #0284c7);
	color: white;
}

.rs-button--outline {
	background-color: transparent;
	color: var(--color-primary);
	border-color: var(--color-primary);
}

.rs-button--outline:hover {
	background-color: var(--color-primary);
	color: white;
}

.rs-button--lg {
	padding: 0.875rem 1.75rem;
	font-size: 1.125rem;
}

.rs-button--sm {
	padding: 0.5rem 1rem;
	font-size: 0.875rem;
}

/* ==========================================================================
   Block CTA
   ========================================================================== */

.rs-block-cta {
	margin-top: var(--space-6);
	text-align: center;
}

/* ==========================================================================
   Empty State
   ========================================================================== */

.rs-empty-state {
	padding: var(--space-8) var(--space-4);
	text-align: center;
	color: var(--color-gray);
}

.rs-empty-state p {
	margin-bottom: var(--space-4);
	font-size: 1.125rem;
}

/* ==========================================================================
   Calendar Block
   ========================================================================== */

.rs-block-calendar {
	margin-top: var(--space-6);
}

.rs-block-calendar__title {
	margin-bottom: var(--space-4);
	text-align: center;
}

.rs-calendar-embed {
	position: relative;
	width: 100%;
	max-width: 100%;
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.rs-calendar-embed iframe {
	display: block;
	width: 100%;
}

.rs-calendar-shortcode {
	margin-top: var(--space-4);
}

.rs-calendar-link {
	text-align: center;
	padding: var(--space-6);
	background: var(--color-light);
	border-radius: var(--radius);
}

.rs-calendar-link p {
	margin-bottom: var(--space-4);
	font-size: 1.125rem;
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 768px) {
	.rs-section {
		padding: var(--space-6) 0;
	}
	
	.rs-button--lg {
		padding: 0.75rem 1.5rem;
		font-size: 1rem;
	}
	
	.rs-cards {
		gap: var(--space-3);
	}
	
	.rs-card__content {
		padding: var(--space-3);
		gap: var(--space-2);
	}
}

/* ==========================================================================
   Editor Specific Styles
   ========================================================================== */

.block-editor-block-list__block .rs-block-preview {
	min-height: 150px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

/* ==========================================================================
   WordPress Block Button - Match rs-button styles
   ========================================================================== */

.wp-block-button__link.wp-element-button {
	display: inline-block;
	padding: 0.625rem 1.25rem;
	font-size: 1rem;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	background-color: var(--color-primary, #007cba);
	color: white;
	border: 2px solid var(--color-primary, #007cba);
	border-radius: 6px;
	cursor: pointer;
	transition: all 0.2s ease;
	line-height: 1.5;
}

.wp-block-button__link.wp-element-button:hover {
	background-color: var(--color-primary-dark, #1e40af);
	border-color: var(--color-primary-dark, #1e40af);
	color: white;
}

/* ==========================================================================
   Block Notice Component (Plugin Dependency Notices)
   ========================================================================== */

.rs-block-notice {
	padding: var(--space-3);
	margin: var(--space-3) 0;
	border-radius: var(--radius-md);
	border-left: 4px solid var(--color-primary);
	background-color: var(--color-surface-2, #f8fafc);
}

.rs-block-notice p {
	margin: 0;
	font-size: 0.9375rem;
	color: var(--color-text);
}

.rs-block-notice--warning {
	border-left-color: var(--color-warning, #f59e0b);
	background-color: #fffbeb;
}

.rs-block-notice--error {
	border-left-color: var(--color-error, #ef4444);
	background-color: #fef2f2;
}

.rs-block-notice--success {
	border-left-color: var(--color-success, #10b981);
	background-color: #ecfdf5;
}
