/**
 * Frontend Styles - Checkout & Thank You Page
 * Design System: Outfit + Scan & Pay Brand Colors
 * Reference: .agents/modules/design-system/README.md
 */

/* Import Outfit from Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap');

/* Scan & Pay Brand Colors */
:root {
	--scanpay-primary: #008080;
	--scanpay-dark-green: #008080;
	--scanpay-teal: #008080;
	--scanpay-gold: #D4AF37;
	--scanpay-silver: #C0C0C0;
	--scanpay-black: #000000;
	--scanpay-white: #FFFFFF;
	--scanpay-dark-gray: #333333;
	--scanpay-medium-gray: #666666;
	--scanpay-light-gray: #F5F5F5;
	--scanpay-success: #4CAF50;
	--scanpay-warning: #FF9800;
	--scanpay-error: #F44336;
	--scanpay-font: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ============================================================================
   Gateway Display (Checkout Page) — text-only, teal brand color
   ============================================================================ */

.scanpay-gateway-container {
	display: inline-flex !important;
	align-items: center;
	white-space: nowrap;
	vertical-align: middle;
}

/**
 * Gateway text label — "Scan & Pay" in brand teal.
 * No logo/icon: clean BNPL-style text lockup.
 */
.scanpay-gateway-text {
	display: inline-block;
	vertical-align: middle;
	font-size: inherit;
	line-height: 1;
	font-family: var(--scanpay-font);
	font-weight: 600;
	color: var(--scanpay-teal);
}

/**
 * WooCommerce payment method label override
 * Ensures proper spacing between radio button and gateway container
 */
.wc_payment_method label[for="payment_method_scanpay"] {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

/* ============================================================================
   Thank You Page QR Display
   ============================================================================ */

/* Ensure plugin styles don't interfere with theme navigation */
.scanpay-custom-payment-page {
	position: relative;
	z-index: 1;
}

.scanpay-thankyou {
	padding: 20px;
	background: var(--scanpay-light-gray);
	border: 1px solid var(--scanpay-silver);
	border-radius: 8px;
	margin: 20px 0;
	text-align: center;
	font-family: var(--scanpay-font);
}

.scanpay-thankyou h2 {
	margin-top: 0;
	color: var(--scanpay-dark-green);
	font-family: var(--scanpay-font);
	font-weight: 700;
}

.scanpay-qr-wrapper {
	margin: 20px 0;
}

.scanpay-qr-image {
	width: 250px !important;
	height: 250px !important;
	max-width: 100%;
	border: 2px solid #333;
	border-radius: 8px;
	padding: 10px;
	background: #fff;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
	display: block;
	margin: 0 auto;
}

.scanpay-session-id {
	color: #666;
	font-size: 13px;
	margin-top: 10px;
}

.scanpay-session-id code {
	background: #f5f5f5;
	padding: 2px 6px;
	border-radius: 3px;
	font-family: 'Courier New', monospace;
}

.scanpay-loading {
	font-style: italic;
	color: #999;
	padding: 20px;
	text-align: center;
}

.scanpay-scan-instruction {
	margin-top: 15px;
	padding: 12px 20px;
	background: #f0f7ff;
	border-left: 4px solid #2271b1;
	color: #1d2327;
	font-size: 14px;
	line-height: 1.6;
	text-align: center;
}

.scanpay-instruction-text {
	margin-bottom: 20px;
	font-size: 15px;
	color: #50575e;
}

/* Payment status block - POS style */
.scanpay-status-block {
	margin: 20px 0;
	padding: 16px 20px;
	background: #f0f7ff;
	border-left: 4px solid #2271b1;
	border-radius: 4px;
	text-align: left;
}

.scanpay-status-title {
	font-size: 16px;
	font-weight: 600;
	color: var(--scanpay-dark-gray);
	margin: 0 0 8px 0;
	font-family: var(--scanpay-font);
}

.scanpay-status-text {
	font-size: 14px;
	color: var(--scanpay-medium-gray);
	line-height: 1.6;
	margin: 0;
	font-family: var(--scanpay-font);
}

/* Success state */
.scanpay-status-block.success {
	background: #E8F5E9;
	border-left-color: var(--scanpay-success);
}

.scanpay-status-block.success .scanpay-status-title {
	color: #155724;
}

.scanpay-status-block.success .scanpay-status-text {
	color: #155724;
}

/* Failed state */
.scanpay-status-block.failed {
	background: #FFEBEE;
	border-left-color: var(--scanpay-error);
}

.scanpay-status-block.failed .scanpay-status-title {
	color: #721c24;
}

.scanpay-status-block.failed .scanpay-status-text {
	color: #721c24;
}

.scanpay-status-message {
	margin-top: 15px;
	padding: 10px;
	border-radius: 4px;
}

.scanpay-paid {
	padding: 20px;
	background: #d4edda;
	border: 1px solid #c3e6cb;
	border-radius: 4px;
	margin: 20px 0;
	text-align: center;
}

.scanpay-paid h2 {
	color: #155724;
	margin-top: 0;
}

.scanpay-paid p {
	color: #155724;
	margin-bottom: 0;
}

/* Responsive adjustments */
@media (max-width: 768px) {
	.scanpay-qr-image {
		max-width: 250px;
	}

	.scanpay-thankyou,
	.scanpay-paid {
		padding: 15px;
	}
}

/* Fallback payment link block */
.scanpay-fallback-link {
    margin-top: 20px;
    padding: 15px;
    background: #e8f4f8;
    border: 1px solid #b8d4e3;
    border-radius: 8px;
    text-align: center;
}

.scanpay-fallback-link p {
    margin: 0 0 10px 0;
    color: #2c5282;
    font-size: 14px;
}

.scanpay-fallback-link-url {
    display: inline-block;
    color: #2b6cb0;
    font-weight: 600;
    text-decoration: underline;
    font-size: 14px;
    transition: color 0.2s ease;
}

.scanpay-fallback-link-url:hover {
    color: #1a4971;
}

/* Hide fallback link until session_id is available */
.scanpay-fallback-link[data-ready="false"] {
    display: none;
}

/* Scan & PayID Header */
.scanpay-header {
	text-align: center;
	margin-bottom: 15px;
}

.scanpay-header > div {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 24px;
	font-weight: 700;
	color: var(--scanpay-dark-green);
	font-family: var(--scanpay-font);
}

.scanpay-header img {
	height: 28px;
	vertical-align: middle;
}

@media (max-width: 768px) {
	.scanpay-header > div {
		font-size: 20px;
	}

	.scanpay-header img {
		height: 24px;
	}
}
