/**
 * WWU Withdrawal Button — frontend styles.
 *
 * Every visual element is themeable two ways:
 *   1. CSS custom properties (--wwu-wb-*) — one-line overrides (colors, radius,
 *      spacing). Override them from the admin "Custom CSS" box, e.g.
 *        :root { --wwu-wb-accent: #f49619; --wwu-wb-radius: 8px; }
 *   2. Plain classes (.wwu-wb-*) — full control for anything else.
 *
 * The full token + class reference is listed in the plugin Settings page.
 *
 * Legibility note: the withdrawal button must stay legible and prominent
 * (Art. 11a "easily legible"); do not hide or low-contrast it via custom CSS.
 */

:root {
	/* Accent (buttons) */
	--wwu-wb-accent:        #1a1f3a;
	--wwu-wb-accent-text:   #ffffff;
	--wwu-wb-accent-focus:  #1a1f3a;
	/* Shape */
	--wwu-wb-radius:        5px;
	--wwu-wb-field-radius:  4px;
	/* Buttons */
	--wwu-wb-button-padding:   0.7em 1.4em;
	--wwu-wb-button-font-size: 1rem;
	--wwu-wb-button-font-weight: 600;
	--wwu-wb-button-border:    2px solid currentColor;
	/* Form */
	--wwu-wb-form-max-width:   540px;
	--wwu-wb-field-border:     #c3c4c7;
	--wwu-wb-field-padding:    0.6em 0.7em;
	--wwu-wb-label-weight:     600;
	/* Notes / states */
	--wwu-wb-note-color:       #666666;
	--wwu-wb-success-bg:       #edfaef;
	--wwu-wb-success-border:   #46b450;
	--wwu-wb-success-text:     #1a4d24;
	--wwu-wb-error-bg:         #fcf0f1;
	--wwu-wb-error-border:     #d63638;
	--wwu-wb-error-text:       #8a1f21;
	--wwu-wb-notice-bg:        #f6f7f7;
	--wwu-wb-notice-accent:    #1a1f3a;
	--wwu-wb-spacing:          1em;
}

.wwu-wb-button-wrap {
	margin: var(--wwu-wb-spacing) 0;
}

.wwu-wb-button {
	display: inline-block;
	padding: var(--wwu-wb-button-padding);
	font-size: var(--wwu-wb-button-font-size);
	line-height: 1.2;
	font-weight: var(--wwu-wb-button-font-weight);
	text-decoration: none;
	border-radius: var(--wwu-wb-radius);
	cursor: pointer;
	border: var(--wwu-wb-button-border);
	background: var(--wwu-wb-accent);
	color: var(--wwu-wb-accent-text);
	transition: opacity 0.2s ease-in-out;
}

.wwu-wb-button:hover,
.wwu-wb-button:focus {
	opacity: 0.9;
	color: var(--wwu-wb-accent-text);
}

.wwu-wb-button:focus-visible {
	outline: 3px solid var(--wwu-wb-accent-focus);
	outline-offset: 2px;
}

.wwu-wb-window-note {
	display: inline-block;
	margin-left: 0.75em;
	font-size: 0.85rem;
	color: var(--wwu-wb-note-color);
}

/* Small button variant (used in the orders chooser table). */
.wwu-wb-button--sm {
	padding: 0.45em 1em;
	font-size: 0.9rem;
	white-space: nowrap;
}

/* Orders chooser (My Account tab + public form page). */
.wwu-wb-account-intro {
	margin: 1em 0;
}

.wwu-wb-orders {
	width: 100%;
	border-collapse: collapse;
	margin: 1em 0;
}

.wwu-wb-orders th,
.wwu-wb-orders td {
	text-align: left;
	padding: 0.7em 1em;
	border-bottom: 1px solid var(--wwu-wb-field-border);
	vertical-align: middle;
}

.wwu-wb-orders thead th {
	font-weight: 600;
	border-bottom-width: 2px;
}

.wwu-wb-orders__action {
	white-space: nowrap;
}

/* Compact, inline status pill — no block margins inside a table cell. */
.wwu-wb-status-pill {
	display: inline-block;
	padding: 0.3em 0.7em;
	font-size: 0.85rem;
	line-height: 1.2;
	border-radius: 999px;
	background: var(--wwu-wb-notice-bg);
	border: 1px solid var(--wwu-wb-field-border);
	color: var(--wwu-wb-note-color);
	white-space: nowrap;
}

/* Stack the table into rows on small screens (no theme dependency). */
@media (max-width: 600px) {
	.wwu-wb-orders thead {
		display: none;
	}
	.wwu-wb-orders,
	.wwu-wb-orders tbody,
	.wwu-wb-orders tr,
	.wwu-wb-orders td {
		display: block;
		width: 100%;
	}
	.wwu-wb-orders td {
		border-bottom: none;
		padding: 0.2em 0;
	}
	.wwu-wb-orders tr {
		border-bottom: 1px solid var(--wwu-wb-field-border);
		padding: 0.8em 0;
	}
	.wwu-wb-orders__num {
		font-weight: 600;
	}
}

.wwu-wb-form-wrap {
	max-width: var(--wwu-wb-form-max-width);
	margin: 1.5em 0;
}

.wwu-wb-form-title {
	margin-top: 0;
}

.wwu-wb-field {
	display: flex;
	flex-direction: column;
	margin-bottom: var(--wwu-wb-spacing);
}

.wwu-wb-field label {
	font-weight: var(--wwu-wb-label-weight);
	margin-bottom: 0.25em;
}

.wwu-wb-field input,
.wwu-wb-field textarea {
	padding: var(--wwu-wb-field-padding);
	font-size: 1rem;
	border: 1px solid var(--wwu-wb-field-border);
	border-radius: var(--wwu-wb-field-radius);
	width: 100%;
	box-sizing: border-box;
}

.wwu-wb-step2-intro {
	font-weight: 600;
}

.wwu-wb-result {
	margin-top: var(--wwu-wb-spacing);
	padding: 0.8em 1em;
	border-radius: var(--wwu-wb-field-radius);
}

.wwu-wb-result.is-success {
	background: var(--wwu-wb-success-bg);
	border: 1px solid var(--wwu-wb-success-border);
	color: var(--wwu-wb-success-text);
}

.wwu-wb-result.is-error {
	background: var(--wwu-wb-error-bg);
	border: 1px solid var(--wwu-wb-error-border);
	color: var(--wwu-wb-error-text);
}

.wwu-wb-status-notice {
	margin: var(--wwu-wb-spacing) 0;
	padding: 0.6em 1em;
	background: var(--wwu-wb-notice-bg);
	border-left: 4px solid var(--wwu-wb-notice-accent);
}

.wwu-wb-notice {
	margin: var(--wwu-wb-spacing) 0;
	color: var(--wwu-wb-note-color);
}

.wwu-wb-noscript {
	color: var(--wwu-wb-error-text);
}

.wwu-wb-model-form {
	margin: 1.5em 0;
}

.wwu-wb-model-form__fields {
	list-style: none;
	padding: 0;
}

.wwu-wb-model-form__fields li {
	padding: 0.35em 0;
	border-bottom: 1px dashed var(--wwu-wb-field-border);
}

.wwu-wb-info {
	margin: var(--wwu-wb-spacing) 0;
}

/* Consumer "how it works" guidance block. */
.wwu-wb-guidance {
	margin: 0 0 1.2em;
	padding: 0.9em 1.1em;
	background: var(--wwu-wb-notice-bg);
	border-left: 4px solid var(--wwu-wb-notice-accent);
	border-radius: var(--wwu-wb-field-radius);
}

.wwu-wb-guidance__intro {
	margin: 0;
}

.wwu-wb-guidance__details {
	margin-top: 0.6em;
}

.wwu-wb-guidance__details summary {
	cursor: pointer;
	font-weight: 600;
}

.wwu-wb-guidance__list {
	margin: 0.8em 0 0.4em;
	padding-left: 1.3em;
}

.wwu-wb-guidance__list li {
	margin-bottom: 0.5em;
}

.wwu-wb-guidance__help {
	margin: 0.4em 0 0;
	font-size: 0.9rem;
	color: var(--wwu-wb-note-color);
}

/* Trap #19 twin rule: keep [hidden] effective even if a theme sets display. */
.wwu-wb-form-wrap [hidden] {
	display: none !important;
}

/*
 * Art. 59 exemption transparency note — shown when the button is absent
 * because the order is exempt from the right of withdrawal.
 */
.wwu-wb-exempt-note {
	margin: 1em 0;
	padding: 0.75em 1em;
	background-color: #f9f0e0;
	border-left: 4px solid #c78a00;
	border-radius: 0 4px 4px 0;
	color: var(--wwu-wb-text-color, #333);
	font-size: 0.9rem;
	line-height: 1.5;
}

.wwu-wb-exempt-note p {
	margin: 0;
}
