/**
 * FoxDog Convert — front-end form styles.
 *
 * Three themes available via the shortcode `theme` attribute:
 *
 *   [foxdog_capture]               — light (default)
 *   [foxdog_capture theme="dark"]  — dark background, light inputs
 *   [foxdog_capture theme="minimal"] — transparent, no background or border
 *
 * All class names are prefixed .foxdog-convert- to avoid theme conflicts.
 * Override any rule in your theme CSS as needed.
 *
 * @package FoxDog_Convert
 * @since   1.0.0
 */

/* ==========================================================================
   CSS custom properties — override these in your theme to restyle globally.
   ========================================================================== */

:root {
	--foxdog-radius:       4px;
	--foxdog-font-size:    1em;
	--foxdog-gap:          0.5em;
	--foxdog-padding-v:    0.65em;
	--foxdog-padding-h:    1em;
	--foxdog-transition:   background 0.15s ease, border-color 0.15s ease, color 0.15s ease;

	/* Light theme tokens */
	--foxdog-light-bg:           #ffffff;
	--foxdog-light-border:       1px solid #d0d0d0;
	--foxdog-light-text:         #1a1a1a;
	--foxdog-light-input-bg:     #ffffff;
	--foxdog-light-input-border: #cccccc;
	--foxdog-light-input-focus:  #0073aa;
	--foxdog-light-btn-bg:       #0073aa;
	--foxdog-light-btn-text:     #ffffff;
	--foxdog-light-btn-hover:    #005d8c;

	/* Dark theme tokens */
	--foxdog-dark-bg:            #1e1e1e;
	--foxdog-dark-border:        1px solid #3a3a3a;
	--foxdog-dark-text:          #f0f0f0;
	--foxdog-dark-input-bg:      #2c2c2c;
	--foxdog-dark-input-border:  #4a4a4a;
	--foxdog-dark-input-focus:   #5ba4cf;
	--foxdog-dark-btn-bg:        #5ba4cf;
	--foxdog-dark-btn-text:      #ffffff;
	--foxdog-dark-btn-hover:     #4390ba;

	/* Success / error colours (shared across themes) */
	--foxdog-success-color: #2e7d32;
	--foxdog-error-color:   #c62828;
}

/* ==========================================================================
   Base layout — shared by all themes
   ========================================================================== */

.foxdog-convert-wrap {
	margin: 1.5em 0;
	border-radius: var(--foxdog-radius);
}

.foxdog-convert-wrap *,
.foxdog-convert-wrap *::before,
.foxdog-convert-wrap *::after {
	box-sizing: border-box;
}

.foxdog-convert-fields {
	display: flex;
	flex-wrap: wrap;
	gap: var(--foxdog-gap);
	align-items: center;
}

.foxdog-convert-email {
	flex: 1 1 220px;
	min-width: 0;
	padding: var(--foxdog-padding-v) var(--foxdog-padding-h);
	font-size: var(--foxdog-font-size);
	border-radius: var(--foxdog-radius);
	line-height: 1.4;
	transition: var(--foxdog-transition);
	font-family: inherit;
}

.foxdog-convert-email:focus {
	outline: none;
}

.foxdog-convert-btn {
	flex: 0 0 auto;
	padding: var(--foxdog-padding-v) var(--foxdog-padding-h);
	font-size: var(--foxdog-font-size);
	font-family: inherit;
	font-weight: 600;
	cursor: pointer;
	border-radius: var(--foxdog-radius);
	line-height: 1.4;
	white-space: nowrap;
	border: none;
	transition: var(--foxdog-transition);
}

.foxdog-convert-btn:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.foxdog-convert-msg {
	margin: 0.5em 0 0;
	font-size: 0.9em;
	width: 100%;
	min-height: 1.2em;
}

.foxdog-convert-msg--success { color: var(--foxdog-success-color); }
.foxdog-convert-msg--error   { color: var(--foxdog-error-color); }

/* Success state — wrapper turns green after subscribe (all themes) */
.foxdog-convert-wrap--success {
	background:    #e8f5e9 !important;
	border-color:  #a5d6a7 !important;
	transition:    background 0.4s ease, border-color 0.4s ease;
}

.foxdog-convert-wrap--success .foxdog-convert-msg--success {
	color: #2e7d32;
}

/* Full-width centred success state that replaces the form */
.foxdog-convert-msg--standalone {
	display: block;
	width: 100%;
	margin: 0;
	text-align: center;
	font-size: 1.05em;
	font-weight: 600;
	padding: 0.5em 0;
}

/* ==========================================================================
   Theme: light (default)
   Use on white or pale-grey backgrounds.
   ========================================================================== */

.foxdog-convert-wrap--light {
	background:    var(--foxdog-light-bg);
	border:        var(--foxdog-light-border);
	color:         var(--foxdog-light-text);
	padding:       1.25em 1.5em;
}

.foxdog-convert-wrap--light .foxdog-convert-email {
	background:    var(--foxdog-light-input-bg);
	border:        1px solid var(--foxdog-light-input-border);
	color:         var(--foxdog-light-text);
}

.foxdog-convert-wrap--light .foxdog-convert-email::placeholder {
	color: #999;
}

.foxdog-convert-wrap--light .foxdog-convert-email:focus {
	border-color:  var(--foxdog-light-input-focus);
	box-shadow:    0 0 0 2px rgba(0, 115, 170, 0.2);
}

.foxdog-convert-wrap--light .foxdog-convert-btn {
	background:    var(--foxdog-light-btn-bg);
	color:         var(--foxdog-light-btn-text);
}

.foxdog-convert-wrap--light .foxdog-convert-btn:hover:not(:disabled) {
	background:    var(--foxdog-light-btn-hover);
}

/* ==========================================================================
   Theme: dark
   Use on dark/charcoal backgrounds — footers, hero sections, dark sidebars.
   ========================================================================== */

.foxdog-convert-wrap--dark {
	background:    var(--foxdog-dark-bg);
	border:        var(--foxdog-dark-border);
	color:         var(--foxdog-dark-text);
	padding:       1.25em 1.5em;
	border-radius: var(--foxdog-radius);
}

.foxdog-convert-wrap--dark .foxdog-convert-email {
	background:    var(--foxdog-dark-input-bg);
	border:        1px solid var(--foxdog-dark-input-border);
	color:         var(--foxdog-dark-text);
}

.foxdog-convert-wrap--dark .foxdog-convert-email::placeholder {
	color: #888;
}

.foxdog-convert-wrap--dark .foxdog-convert-email:focus {
	border-color:  var(--foxdog-dark-input-focus);
	box-shadow:    0 0 0 2px rgba(91, 164, 207, 0.25);
}

.foxdog-convert-wrap--dark .foxdog-convert-btn {
	background:    var(--foxdog-dark-btn-bg);
	color:         var(--foxdog-dark-btn-text);
}

.foxdog-convert-wrap--dark .foxdog-convert-btn:hover:not(:disabled) {
	background:    var(--foxdog-dark-btn-hover);
}

.foxdog-convert-wrap--dark .foxdog-convert-msg--success {
	color: #81c784; /* Lighter green readable on dark bg */
}

.foxdog-convert-wrap--dark .foxdog-convert-msg--error {
	color: #ef9a9a; /* Lighter red readable on dark bg */
}

/* ==========================================================================
   Theme: minimal
   No background, border, or padding. Blends into any container.
   Use when the surrounding design already provides the visual framing.
   ========================================================================== */

.foxdog-convert-wrap--minimal {
	background:    transparent;
	border:        none;
	padding:       0;
}

.foxdog-convert-wrap--minimal .foxdog-convert-email {
	background:    transparent;
	border:        1px solid currentColor;
	color:         inherit;
}

.foxdog-convert-wrap--minimal .foxdog-convert-email::placeholder {
	color: currentColor;
	opacity: 0.55;
}

.foxdog-convert-wrap--minimal .foxdog-convert-email:focus {
	border-color:  currentColor;
	box-shadow:    0 0 0 2px rgba(128, 128, 128, 0.2);
}

.foxdog-convert-wrap--minimal .foxdog-convert-btn {
	background:    currentColor;
	color:         #fff; /* Will be overridden by theme if needed */
	border:        1px solid currentColor;
}

.foxdog-convert-wrap--minimal .foxdog-convert-btn:hover:not(:disabled) {
	opacity: 0.85;
}

/* ==========================================================================
   Responsive — stack vertically on narrow screens (all themes)
   ========================================================================== */

@media ( max-width: 480px ) {
	.foxdog-convert-fields {
		flex-direction: column;
		align-items:    stretch;
	}

	.foxdog-convert-btn {
		width: 100%;
		text-align: center;
	}
}

/* ==========================================================================
   Post-subscribe recommendations modal
   ========================================================================== */

.foxdog-modal-overlay {
	position:         fixed;
	inset:            0;
	background:       rgba( 0, 0, 0, 0.55 );
	display:          flex;
	align-items:      center;
	justify-content:  center;
	z-index:          99999;
	padding:          1rem;
	box-sizing:       border-box;
	opacity:          0;
	transition:       opacity 0.25s ease;
}

.foxdog-modal-overlay--visible {
	opacity: 1;
}

.foxdog-modal {
	background:    #ffffff;
	border-radius: 8px;
	box-shadow:    0 8px 40px rgba( 0, 0, 0, 0.25 );
	padding:       2rem 2rem 1.5rem;
	max-width:     640px;
	width:         100%;
	max-height:    90vh;
	overflow-y:    auto;
	box-sizing:    border-box;
	transform:     translateY( 12px );
	transition:    transform 0.25s ease;
}

.foxdog-modal-overlay--visible .foxdog-modal {
	transform: translateY( 0 );
}

.foxdog-modal__title {
	margin:      0 0 0.25em;
	font-size:   1.4em;
	font-weight: 700;
	color:       #1a1a1a;
}

.foxdog-modal__intro {
	margin:    0 0 1.25em;
	color:     #555;
	font-size: 0.95em;
}

/* Cards grid */

.foxdog-modal-cards {
	display:        grid;
	grid-template-columns: repeat( auto-fill, minmax( 240px, 1fr ) );
	gap:            1rem;
	margin-bottom:  1.5rem;
}

.foxdog-modal-card {
	border:        1px solid #e0e0e0;
	border-radius: 6px;
	padding:       1rem;
	display:       flex;
	flex-direction: column;
	gap:           0.75rem;
}

.foxdog-modal-card__body {
	display:        flex;
	flex-direction: column;
	gap:            0.2em;
	flex:           1;
}

.foxdog-modal-card__name {
	font-size:   1em;
	font-weight: 700;
	color:       #1a1a1a;
	line-height: 1.3;
}

.foxdog-modal-card__tagline {
	font-size:   0.85em;
	color:       #0073aa;
	font-weight: 500;
}

.foxdog-modal-card__desc {
	margin:    0;
	font-size: 0.85em;
	color:     #555;
	line-height: 1.4;
}

/* Card subscribe button */

.foxdog-modal-card__btn {
	display:       block;
	width:         100%;
	padding:       0.55em 1em;
	font-size:     0.9em;
	font-weight:   600;
	font-family:   inherit;
	cursor:        pointer;
	border:        none;
	border-radius: 4px;
	background:    #0073aa;
	color:         #ffffff;
	transition:    background 0.15s ease, opacity 0.15s ease;
	text-align:    center;
}

.foxdog-modal-card__btn:hover:not(:disabled) {
	background: #005d8c;
}

.foxdog-modal-card__btn:disabled {
	cursor:  default;
	opacity: 0.65;
}

.foxdog-modal-card__btn--done {
	background: #2e7d32;
}

/* Maybe Later button */

.foxdog-modal-later {
	display:     block;
	width:       100%;
	padding:     0.6em 1em;
	font-size:   0.9em;
	font-family: inherit;
	cursor:      pointer;
	border:      none;
	background:  transparent;
	color:       #777;
	text-align:  center;
	transition:  color 0.15s ease;
}

.foxdog-modal-later:hover {
	color: #333;
}

/* Narrow screens — single column */

@media ( max-width: 480px ) {
	.foxdog-modal {
		padding: 1.5rem 1.25rem 1.25rem;
	}

	.foxdog-modal-cards {
		grid-template-columns: 1fr;
	}
}
