/* Event RSVP - Frontend Styles */

/* ==========================================================================
   EventOn Event Card - RSVP Standalone Row
   ========================================================================== */

/* Standalone row for RSVP (after description, before time/location) */
.event-rsvp-standalone-row {
	margin: 0;
	padding: 0;
}

.event-rsvp-standalone-row .evocard_box.rsvp {
	width: 100%;
	padding: 0;
}

/* Hide the wrapper that hasn't been repositioned yet */
.event-rsvp-section-wrapper {
	display: block;
}

/* When inside the eventdetails box, give it some spacing */
.evocard_box.eventdetails .event-rsvp-section-wrapper,
#event_eventdetails .event-rsvp-section-wrapper {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid #e5e7eb;
}

/* ==========================================================================
   EventOn Event Card - RSVP Row Styles
   ========================================================================== */

.evo_metarow_rsvp {
	display: flex;
	align-items: center;
	padding: 20px 30px;
	background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
	border-radius: 8px;
	margin-bottom: 10px;
	border: 1px solid #bbf7d0;
}

/* Hide the standalone icon - we'll show it inline with title */
.evo_metarow_rsvp > .evcal_evdata_icons {
	display: none;
}

.evo_metarow_rsvp .evcal_evdata_cell {
	flex: 1;
	width: 100%;
}

/* Horizontal layout for RSVP content */
.evo_metarow_rsvp .event-rsvp-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	width: 100%;
}

/* Left side: Icon + Title + Text */
.evo_metarow_rsvp h3.evo_h3 {
	display: none; /* Hide redundant title */
}

.event-rsvp-invite-text {
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 0;
	font-size: 16px;
	color: #166534;
	font-weight: 500;
	flex: 1;
}

.event-rsvp-invite-text::before {
	content: '\f274'; /* Calendar check icon */
	font-family: 'Font Awesome 5 Free', 'FontAwesome', sans-serif;
	font-weight: 400;
	font-size: 24px;
	color: #16a34a;
}

/* Right side: Button */
.event-rsvp-action {
	flex-shrink: 0;
}

/* ==========================================================================
   Animated Ticker Counter
   ========================================================================== */

.event-rsvp-ticker {
	flex: 1;
	margin: 0;
}

.rsvp-ticker-container {
	display: flex;
	align-items: center;
	gap: 15px;
	padding: 10px 20px;
	background: linear-gradient(135deg, #1e1b4b 0%, #312e81 100%);
	border-radius: 10px;
	box-shadow: 0 4px 15px rgba(30, 27, 75, 0.3);
}

.rsvp-ticker-count {
	display: flex;
	align-items: center;
	gap: 2px;
}

.rsvp-ticker-digit {
	display: inline-block;
	width: 32px;
	height: 44px;
	background: linear-gradient(180deg, #0f0f23 0%, #1a1a3e 50%, #0f0f23 100%);
	border-radius: 6px;
	overflow: hidden;
	position: relative;
	box-shadow: 
		inset 0 1px 3px rgba(0,0,0,0.5),
		0 2px 4px rgba(0,0,0,0.3);
}

.rsvp-ticker-digit::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	height: 1px;
	background: rgba(0,0,0,0.4);
	z-index: 2;
}

.rsvp-ticker-digit::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 50%;
	background: linear-gradient(180deg, rgba(255,255,255,0.1) 0%, transparent 100%);
	z-index: 1;
	border-radius: 6px 6px 0 0;
}

.rsvp-ticker-digit-inner {
	display: flex;
	flex-direction: column;
	transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.rsvp-digit-num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 44px;
	font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Fira Code', monospace;
	font-size: 28px;
	font-weight: 700;
	color: #22d3ee;
	text-shadow: 0 0 10px rgba(34, 211, 238, 0.5);
}

/* Animation states */
.rsvp-ticker-digit.animated .rsvp-ticker-digit-inner {
	animation: tickerRoll 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.rsvp-ticker-digit[data-digit="0"] .rsvp-ticker-digit-inner { transform: translateY(0); }
.rsvp-ticker-digit[data-digit="1"] .rsvp-ticker-digit-inner { transform: translateY(-44px); }
.rsvp-ticker-digit[data-digit="2"] .rsvp-ticker-digit-inner { transform: translateY(-88px); }
.rsvp-ticker-digit[data-digit="3"] .rsvp-ticker-digit-inner { transform: translateY(-132px); }
.rsvp-ticker-digit[data-digit="4"] .rsvp-ticker-digit-inner { transform: translateY(-176px); }
.rsvp-ticker-digit[data-digit="5"] .rsvp-ticker-digit-inner { transform: translateY(-220px); }
.rsvp-ticker-digit[data-digit="6"] .rsvp-ticker-digit-inner { transform: translateY(-264px); }
.rsvp-ticker-digit[data-digit="7"] .rsvp-ticker-digit-inner { transform: translateY(-308px); }
.rsvp-ticker-digit[data-digit="8"] .rsvp-ticker-digit-inner { transform: translateY(-352px); }
.rsvp-ticker-digit[data-digit="9"] .rsvp-ticker-digit-inner { transform: translateY(-396px); }

/* Initial state before animation */
.rsvp-ticker-digit:not(.animated) .rsvp-ticker-digit-inner {
	transform: translateY(0) !important;
}

@keyframes tickerRoll {
	0% {
		transform: translateY(0);
	}
}

.rsvp-ticker-label {
	display: flex;
	align-items: center;
	gap: 6px;
	color: #e0e7ff;
	font-size: 14px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.rsvp-ticker-icon {
	font-size: 18px;
}

/* Glow pulse effect */
.rsvp-ticker-container {
	animation: tickerGlow 3s ease-in-out infinite;
}

@keyframes tickerGlow {
	0%, 100% {
		box-shadow: 0 4px 15px rgba(30, 27, 75, 0.3);
	}
	50% {
		box-shadow: 0 4px 25px rgba(99, 102, 241, 0.4);
	}
}

/* Smaller variant for compact displays */
.event-rsvp-ticker.compact .rsvp-ticker-container {
	padding: 8px 12px;
	gap: 10px;
}

.event-rsvp-ticker.compact .rsvp-ticker-digit {
	width: 24px;
	height: 32px;
}

.event-rsvp-ticker.compact .rsvp-digit-num {
	width: 24px;
	height: 32px;
	font-size: 20px;
}

.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="1"] .rsvp-ticker-digit-inner { transform: translateY(-32px); }
.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="2"] .rsvp-ticker-digit-inner { transform: translateY(-64px); }
.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="3"] .rsvp-ticker-digit-inner { transform: translateY(-96px); }
.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="4"] .rsvp-ticker-digit-inner { transform: translateY(-128px); }
.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="5"] .rsvp-ticker-digit-inner { transform: translateY(-160px); }
.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="6"] .rsvp-ticker-digit-inner { transform: translateY(-192px); }
.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="7"] .rsvp-ticker-digit-inner { transform: translateY(-224px); }
.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="8"] .rsvp-ticker-digit-inner { transform: translateY(-256px); }
.event-rsvp-ticker.compact .rsvp-ticker-digit[data-digit="9"] .rsvp-ticker-digit-inner { transform: translateY(-288px); }

.event-rsvp-ticker.compact .rsvp-ticker-label {
	font-size: 12px;
}

/* RSVP Button */
.event-rsvp-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 20px;
	background: linear-gradient(135deg, #9333ea 0%, #7c3aed 100%);
	color: #ffffff;
	border: none;
	border-radius: 25px;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	box-shadow: 0 2px 8px rgba(147, 51, 234, 0.3);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.event-rsvp-btn:hover {
	background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);
	box-shadow: 0 4px 12px rgba(147, 51, 234, 0.4);
	transform: translateY(-1px);
}

.event-rsvp-btn:active {
	transform: translateY(0);
}

.event-rsvp-btn i {
	font-size: 12px;
	transition: transform 0.2s ease;
}

.event-rsvp-btn:hover i {
	transform: translateX(3px);
}

/* ==========================================================================
   RSVP Modal Styles
   ========================================================================== */

.event-rsvp-modal {
	display: none;
	position: fixed;
	z-index: 999999 !important;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	background-color: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(4px);
}

.event-rsvp-modal-content {
	background-color: #ffffff;
	margin: 5% auto;
	padding: 0;
	border-radius: 16px;
	width: 90%;
	max-width: 500px;
	position: relative;
	z-index: 1000000 !important;
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
	animation: modalSlideIn 0.3s ease-out;
	overflow: hidden;
}

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

.event-rsvp-modal-header {
	padding: 24px 30px 20px;
	background: linear-gradient(135deg, #9333ea 0%, #7c3aed 100%);
	color: #ffffff;
	position: relative;
}

.event-rsvp-modal-header h2 {
	margin: 0;
	font-size: 24px;
	font-weight: 700;
}

.event-rsvp-modal-header p {
	margin: 8px 0 0 0;
	font-size: 14px;
	opacity: 0.9;
}

.event-rsvp-modal-close {
	position: absolute;
	right: 20px;
	top: 20px;
	color: rgba(255, 255, 255, 0.8);
	font-size: 28px;
	font-weight: bold;
	cursor: pointer;
	line-height: 1;
	transition: color 0.2s;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
}

.event-rsvp-modal-close:hover {
	color: #ffffff;
	background: rgba(255, 255, 255, 0.1);
}

.event-rsvp-modal-body {
	padding: 30px;
}

/* ==========================================================================
   RSVP Form Styles
   ========================================================================== */

.event-rsvp-form {
	margin: 0;
}

.event-rsvp-form-group {
	margin-bottom: 20px;
}

.event-rsvp-form-group label {
	display: block;
	margin-bottom: 6px;
	font-weight: 600;
	color: #374151;
	font-size: 14px;
}

.event-rsvp-form-group label .required {
	color: #ef4444;
	margin-left: 2px;
}

.event-rsvp-form-group input[type="text"],
.event-rsvp-form-group input[type="email"],
.event-rsvp-form-group input[type="tel"],
.event-rsvp-form-group input[type="number"],
.event-rsvp-form-group textarea,
.event-rsvp-form-group select {
	width: 100%;
	padding: 12px 14px;
	border: 2px solid #e5e7eb;
	border-radius: 10px;
	font-size: 15px;
	font-family: inherit;
	transition: border-color 0.2s, box-shadow 0.2s;
	background: #fff;
	box-sizing: border-box;
}

.event-rsvp-form-group input:focus,
.event-rsvp-form-group textarea:focus,
.event-rsvp-form-group select:focus {
	outline: none;
	border-color: #9333ea;
	box-shadow: 0 0 0 3px rgba(147, 51, 234, 0.1);
}

.event-rsvp-form-group textarea {
	resize: vertical;
	min-height: 80px;
}

.event-rsvp-form-group input[type="number"] {
	width: 100px;
}

.event-rsvp-form-group small {
	display: block;
	margin-top: 4px;
	color: #6b7280;
	font-size: 12px;
}

/* Guest count specific */
.event-rsvp-guest-count {
	display: flex;
	align-items: center;
	gap: 10px;
}

.event-rsvp-guest-count input {
	width: 80px !important;
	text-align: center;
}

.event-rsvp-guest-count span {
	color: #6b7280;
	font-size: 14px;
}

/* Submit button */
.event-rsvp-submit {
	width: 100%;
	padding: 14px 24px;
	background: linear-gradient(135deg, #9333ea 0%, #7c3aed 100%);
	color: #ffffff;
	border: none;
	border-radius: 10px;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	box-shadow: 0 4px 12px rgba(147, 51, 234, 0.3);
	margin-top: 10px;
}

.event-rsvp-submit:hover {
	background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);
	box-shadow: 0 6px 16px rgba(147, 51, 234, 0.4);
	transform: translateY(-1px);
}

.event-rsvp-submit:disabled {
	background: #9ca3af;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

/* Messages */
.event-rsvp-message {
	margin-top: 15px;
	padding: 12px 16px;
	border-radius: 10px;
	font-size: 14px;
	display: none;
}

.event-rsvp-message.success {
	background: #f0fdf4;
	color: #166534;
	border: 1px solid #bbf7d0;
	display: block;
}

.event-rsvp-message.error {
	background: #fef2f2;
	color: #991b1b;
	border: 1px solid #fecaca;
	display: block;
}

/* Loading state */
.event-rsvp-loading {
	display: none;
	text-align: center;
	padding: 20px;
}

.event-rsvp-loading.active {
	display: block;
}

.event-rsvp-loading-spinner {
	display: inline-block;
	width: 40px;
	height: 40px;
	border: 4px solid #e5e7eb;
	border-top-color: #9333ea;
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
}

@keyframes spin {
	to {
		transform: rotate(360deg);
	}
}

/* ==========================================================================
   RSVP List Shortcode Styles
   ========================================================================== */

.event-rsvp-list {
	margin: 20px 0;
}

.event-rsvp-list ul {
	list-style: none;
	padding: 0;
	margin: 0 0 15px 0;
}

.event-rsvp-list li {
	padding: 10px 15px;
	background: #f9fafb;
	border-left: 3px solid #9333ea;
	margin-bottom: 8px;
	border-radius: 0 8px 8px 0;
	font-size: 15px;
}

.event-rsvp-list li:hover {
	background: #f3f4f6;
}

.event-rsvp-list .guest-count {
	color: #6b7280;
	font-size: 13px;
}

.event-rsvp-list .rsvp-total {
	margin: 0;
	padding: 12px 15px;
	background: linear-gradient(135deg, #f3e8ff 0%, #e0e7ff 100%);
	border-radius: 8px;
	font-size: 15px;
}

/* ==========================================================================
   Responsive Styles
   ========================================================================== */

@media (max-width: 600px) {
	/* Stack RSVP content vertically on mobile */
	.evo_metarow_rsvp {
		padding: 15px 20px;
	}
	
	.evo_metarow_rsvp .event-rsvp-content {
		flex-direction: column;
		align-items: stretch;
		gap: 15px;
	}
	
	.event-rsvp-invite-text {
		justify-content: center;
		text-align: center;
	}
	
	.event-rsvp-ticker {
		width: 100%;
	}
	
	.rsvp-ticker-container {
		justify-content: center;
	}
	
	.event-rsvp-action {
		text-align: center;
	}
	
	.event-rsvp-btn {
		width: 100%;
		justify-content: center;
	}
	
	.event-rsvp-modal-content {
		margin: 2% auto;
		width: 95%;
		border-radius: 12px;
	}
	
	.event-rsvp-modal-header {
		padding: 20px;
	}
	
	.event-rsvp-modal-header h2 {
		font-size: 20px;
		padding-right: 30px;
	}
	
	.event-rsvp-modal-body {
		padding: 20px;
	}
	
	.evo_metarow_rsvp {
		flex-direction: column;
		padding: 12px 15px;
	}
	
	.evo_metarow_rsvp .evcal_evdata_icons {
		margin-right: 0;
		margin-bottom: 10px;
	}
	
	.event-rsvp-btn {
		width: 100%;
		justify-content: center;
	}
	
	/* Ticker responsive */
	.rsvp-ticker-container {
		flex-direction: column;
		gap: 8px;
		padding: 10px 14px;
	}
	
	.rsvp-ticker-digit {
		width: 26px;
		height: 36px;
	}
	
	.rsvp-digit-num {
		width: 26px;
		height: 36px;
		font-size: 22px;
	}
	
	.rsvp-ticker-digit[data-digit="1"] .rsvp-ticker-digit-inner { transform: translateY(-36px); }
	.rsvp-ticker-digit[data-digit="2"] .rsvp-ticker-digit-inner { transform: translateY(-72px); }
	.rsvp-ticker-digit[data-digit="3"] .rsvp-ticker-digit-inner { transform: translateY(-108px); }
	.rsvp-ticker-digit[data-digit="4"] .rsvp-ticker-digit-inner { transform: translateY(-144px); }
	.rsvp-ticker-digit[data-digit="5"] .rsvp-ticker-digit-inner { transform: translateY(-180px); }
	.rsvp-ticker-digit[data-digit="6"] .rsvp-ticker-digit-inner { transform: translateY(-216px); }
	.rsvp-ticker-digit[data-digit="7"] .rsvp-ticker-digit-inner { transform: translateY(-252px); }
	.rsvp-ticker-digit[data-digit="8"] .rsvp-ticker-digit-inner { transform: translateY(-288px); }
	.rsvp-ticker-digit[data-digit="9"] .rsvp-ticker-digit-inner { transform: translateY(-324px); }
	
	.rsvp-ticker-label {
		font-size: 12px;
	}
}

/* ==========================================================================
   Admin Styles (included for in-page admin modals)
   ========================================================================== */

.event-rsvp-admin-notice {
	padding: 12px 15px;
	margin: 15px 0;
	border-radius: 4px;
}

.event-rsvp-admin-notice.success {
	background: #d1fae5;
	border-left: 4px solid #10b981;
	color: #065f46;
}

.event-rsvp-admin-notice.error {
	background: #fee2e2;
	border-left: 4px solid #ef4444;
	color: #991b1b;
}
