/*
 * Digitaali Order Cancellation — peruutuslomakkeen perustyylit.
 *
 * Tavoite: neutraali, sivuston ulkoasua häiritsemätön peruslayout.
 * Kaikki värit ja mitat custom propertyinä — sivusto voi overrideä ne
 * teeman puolelta koskematta pluginiin. Suodatin
 * `dg_doc_enqueue_public_css` poistaa tämän tiedoston kokonaan käytöstä.
 */

.dg-doc-form-wrapper {
	--dg-doc-text: #1a1a1a;
	--dg-doc-muted: #555;
	--dg-doc-border: #cccccc;
	--dg-doc-border-strong: #1a1a1a;
	--dg-doc-bg-subtle: #f6f6f6;
	--dg-doc-bg-input: #ffffff;
	--dg-doc-radius: 4px;
	--dg-doc-gap: 1.25rem;
	--dg-doc-focus: #1a1a1a;

	/* Submit-napin värit erikseen, jotta sivusto voi virittää
	 * pelkän napin ilman että muut "vahvat" elementit muuttuvat. */
	--dg-doc-submit-bg: #ffffff;
	--dg-doc-submit-fg: #1a1a1a;
	--dg-doc-submit-border: #1a1a1a;
	--dg-doc-submit-hover-bg: #1a1a1a;
	--dg-doc-submit-hover-fg: #ffffff;

	/* Input-kenttien tyylit omina muuttujinaan — sivusto voi virittää
	 * vapaasti ilman pluginiin koskemista. */
	--dg-doc-input-bg: #ffffff;
	--dg-doc-input-fg: #1a1a1a;
	--dg-doc-input-border: #cccccc;
	--dg-doc-input-padding: 0.6rem 0.75rem;

	/* Komponentin pakollinen layout-leveys. !important on välttämätön,
	 * koska monet WP-teemat asettavat `.entry-content > *`-säännöllä
	 * koko sisällön leveyden (specificity 7) — pelkkä luokkavalitsija
	 * ei voita tätä cascadessa. Sivusto voi edelleen yliajaa tämän
	 * omalla !important-säännöllään tai overridattamalla muuttujan
	 * --dg-doc-form-max-width: jos otetaan käyttöön. */
	width: min(var(--dg-doc-form-max-width, 800px), 100%) !important;
	max-width: 100% !important;
	margin: 1.5rem auto;
	padding: 15px;
	font: inherit;
	color: var(--dg-doc-text);
	line-height: 1.5;
	box-sizing: border-box;
}

/* Tilausyhteenveto ---------------------------------------------------- */

.dg-doc-order-summary {
	background: var(--dg-doc-bg-subtle);
	border: 1px solid var(--dg-doc-border);
	border-radius: var(--dg-doc-radius);
	padding: 1rem 1.25rem;
	margin-bottom: var(--dg-doc-gap);
}
.dg-doc-order-summary h2 {
	margin: 0 0 0.5rem 0;
	font-size: 1.25rem;
	line-height: 1.3;
}
.dg-doc-order-summary p {
	margin: 0 0 0.5rem 0;
}
.dg-doc-items {
	margin: 0.5rem 0 0 1.25rem;
	padding: 0;
}
.dg-doc-items li {
	margin: 0.25rem 0;
}

/* Peruutusoikeuden deadline ------------------------------------------- */

/*
 * Visuaalinen erotin lakisääteisen 14 päivän peruutusajan voimassaolon ja
 * ylittyneen tilanteen välillä. Modifierit `.dg-doc-deadline--active` ja
 * `--expired` asetetaan PHP-puolella laskennan tuloksen mukaan
 * (Form::get_cancellation_deadline). Iäkkäämmälle käyttäjälle tilan visuaalinen
 * signaali on tärkeä — pelkkä teksti ei riitä.
 */
.dg-doc-deadline {
	padding: 0.75rem 1rem;
	margin: 0 0 var(--dg-doc-gap) 0;
	border-radius: var(--dg-doc-radius);
	border: 1px solid var(--dg-doc-border);
	border-left-width: 4px;
	font-size: 0.95rem;
	background: var(--dg-doc-bg-subtle);
}
.dg-doc-deadline--active {
	border-left-color: var(--dg-doc-border-strong);
}
.dg-doc-deadline--expired {
	border-left-color: var(--dg-doc-border-strong);
	border-color: var(--dg-doc-border-strong);
	font-weight: 600;
}

/* Lomake — kentät allekkain, label aina kentän yllä -------------------- */

.dg-doc-form {
	display: block;
}
.dg-doc-form p {
	margin: 0 0 var(--dg-doc-gap) 0;
}
.dg-doc-form label {
	display: block;
	font-weight: 600;
	margin-bottom: 0.35rem;
}
/*
 * Input + textarea: !important visuaalisesti kriittisille
 * omaisuuksille, koska teemat tyylittävät usein
 * `.entry-content input` / `.entry-content textarea` korkealla
 * spesifisyydellä (border:none, transparent backgrounds yms.) jotka
 * piilottaisivat kentät käyttäjältä. Sivustokohtainen virittäminen
 * tehdään muuttujien (--dg-doc-input-*) kautta — ne resolvataan
 * meidän !important-säännön sisällä joten taistelua ei tarvita.
 */
.dg-doc-form input[type="email"],
.dg-doc-form textarea {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	padding: var(--dg-doc-input-padding) !important;
	background: var(--dg-doc-input-bg) !important;
	color: var(--dg-doc-input-fg) !important;
	border: 1px solid var(--dg-doc-input-border) !important;
	border-radius: var(--dg-doc-radius);
	font: inherit;
	line-height: 1.4;
	box-sizing: border-box;
}
.dg-doc-form textarea {
	resize: vertical;
	min-height: 7rem !important;
}
.dg-doc-form input[type="email"]:focus,
.dg-doc-form textarea:focus {
	outline: 2px solid var(--dg-doc-focus) !important;
	outline-offset: 1px;
	border-color: var(--dg-doc-focus) !important;
}
.dg-doc-form small {
	display: block;
	margin-top: 0.35rem;
	color: var(--dg-doc-muted);
	font-size: 0.875rem;
}

/* Vahvistus-checkbox: label kentän vieressä, ei yllä ------------------- */

.dg-doc-confirm label {
	font-weight: 400;
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
}
.dg-doc-confirm input[type="checkbox"] {
	margin-top: 0.25rem;
	flex-shrink: 0;
}

/* Toiminnot ------------------------------------------------------------ */

.dg-doc-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1rem;
	margin-top: 0.5rem;
}
/*
 * Submit-nappi: valkoinen tausta, musta border, musta teksti.
 * !important on välttämätön visuaalisesti kriittisille omaisuuksille,
 * koska monet teemat tyylittävät `button[type="submit"]` tai
 * `.entry-content button` korkealla spesifisyydellä (mm. brändivärit).
 * Sivusto virittelee tarvittaessa custom propertyilla (yllä).
 */
.dg-doc-submit {
	background: var(--dg-doc-submit-bg) !important;
	color: var(--dg-doc-submit-fg) !important;
	border: 1px solid var(--dg-doc-submit-border) !important;
	padding: 0.7rem 1.5rem;
	border-radius: var(--dg-doc-radius);
	font: inherit;
	font-weight: 600;
	line-height: 1;
	cursor: pointer;
	text-shadow: none;
	box-shadow: none;
}
.dg-doc-submit:hover,
.dg-doc-submit:focus {
	background: var(--dg-doc-submit-hover-bg) !important;
	color: var(--dg-doc-submit-hover-fg) !important;
	border-color: var(--dg-doc-submit-border) !important;
	outline: 2px solid var(--dg-doc-focus);
	outline-offset: 2px;
}
.dg-doc-link-secondary {
	color: var(--dg-doc-text);
	text-decoration: underline;
}
.dg-doc-link-secondary:hover,
.dg-doc-link-secondary:focus {
	text-decoration: none;
}

/* Ilmoitukset (info / success / error) — neutraalit, vain reuna eroaa --- */

.dg-doc-notice {
	padding: 1rem 1.25rem;
	margin-bottom: var(--dg-doc-gap);
	background: var(--dg-doc-bg-subtle);
	color: var(--dg-doc-text);
	border: 1px solid var(--dg-doc-border);
	border-left-width: 4px;
	border-left-color: var(--dg-doc-border);
	border-radius: var(--dg-doc-radius);
	font-size: 0.95rem;
}
.dg-doc-notice--info {
	border-left-color: var(--dg-doc-muted);
}
.dg-doc-notice--success {
	border-left-color: var(--dg-doc-border-strong);
}
.dg-doc-notice--error {
	border-left-color: var(--dg-doc-border-strong);
	border-color: var(--dg-doc-border-strong);
}

/* Toimitus- ja sopimusehdot -linkki ------------------------------------ */

.dg-doc-form-wrapper .dg-doc-terms-link {
	margin-top: 1rem;
	font-size: 0.9rem;
	color: var(--dg-doc-muted);
}

/* WC-yhteensopivuus: kun lomake renderöityy .woocommerce-wrapperissä,
 * teema (Storefront yms.) saattaa lisätä omat list-tyylinsä
 * .woocommerce-message/-error/-info -elementeille. Säilytetään
 * .dg-doc-notice* -reunaviivat WC-tyylittelyn päällä. */
.dg-doc-form-wrapper ul.dg-doc-notice {
	margin: 0 0 var(--dg-doc-gap);
	list-style: none;
}
.dg-doc-form-wrapper ul.dg-doc-notice > li {
	list-style: none;
	margin: 0;
}

/* Tunnistautumislomake (Auth_Form) ------------------------------------- */

/*
 * Auth-formin omat lisäykset .dg-doc-form-wrapper -peruslayoutin päälle.
 * Tekstikentät (input[type="text"]) tarvitsevat samat tyylit kuin
 * email-kenttä Form-luokassa — sääntö laajennettu kattamaan numeerinen
 * tilausnumero-kenttä.
 */
.dg-doc-form input[type="text"] {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	padding: var(--dg-doc-input-padding) !important;
	background: var(--dg-doc-input-bg) !important;
	color: var(--dg-doc-input-fg) !important;
	border: 1px solid var(--dg-doc-input-border) !important;
	border-radius: var(--dg-doc-radius);
	font: inherit;
	line-height: 1.4;
	box-sizing: border-box;
}
.dg-doc-form input[type="text"]:focus {
	outline: 2px solid var(--dg-doc-focus) !important;
	outline-offset: 1px;
	border-color: var(--dg-doc-focus) !important;
}

.dg-doc-auth-intro {
	margin-bottom: var(--dg-doc-gap);
}
.dg-doc-auth-intro h2 {
	margin: 0 0 0.5rem 0;
	font-size: 1.4rem;
	line-height: 1.3;
}
.dg-doc-auth-intro p {
	margin: 0;
	color: var(--dg-doc-muted);
}

.dg-doc-auth-support {
	margin-top: 2rem;
	padding-top: 1rem;
	border-top: 1px solid var(--dg-doc-border);
	font-size: 0.95rem;
}
.dg-doc-auth-support h3 {
	margin: 0 0 0.5rem 0;
	font-size: 1.05rem;
}
.dg-doc-auth-support p {
	margin: 0 0 0.5rem 0;
}
.dg-doc-auth-support ul {
	margin: 0;
	padding-left: 1.25rem;
}
.dg-doc-auth-support li {
	margin: 0.25rem 0;
}

/* Footer-linkki -------------------------------------------------------- */

/*
 * WCAG 2.1 AA + EAA (voimaan 28.6.2025) -vaatimukset:
 * - Riittävä klikkialue mobiilissa (min. 44×44 px → padding + inline-block)
 * - Riittävä kontrasti (ei opacity-himmennystä, perii teeman tekstivärin)
 * - Luettavissa oleva fonttikoko (vähintään 1rem, ei pienennetty)
 * Teema voi yliajaa CSS-muuttujilla tai filterillä `dg_doc_footer_link_html`.
 */
.dg-doc-footer-link {
	text-align: center;
	padding: 0.5rem 0;
	font-size: 1rem;
}
.dg-doc-footer-link__link {
	color: inherit;
	text-decoration: underline;
	display: inline-block;
	padding: 0.75rem 1rem;
	min-height: 44px;
	line-height: 1.5;
}
.dg-doc-footer-link__link:hover,
.dg-doc-footer-link__link:focus {
	text-decoration: none;
}
.dg-doc-footer-link__link:focus {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

/* Mobiili -------------------------------------------------------------- */

@media (max-width: 480px) {
	.dg-doc-actions {
		flex-direction: column;
		align-items: stretch;
	}
	.dg-doc-submit {
		width: 100%;
	}
	.dg-doc-link-secondary {
		text-align: center;
	}
}

/* ===================================================================== */
/*  Lakisääteinen peruuttamisohje + malliperuuttamislomake (v0.3.0)       */
/* ===================================================================== */

/*
 * Visuaalinen erottelu interaktiivisesta peruutustoiminnosta: oma
 * reunaviiva + hillitty tausta + selvä väli. Accordion (<details>) pitää
 * sisällön oletuksena suljettuna → interaktiivinen lomake dominoi näkymää.
 * Kaikki selektorit juurielementin (.dg-doc-legal) alla — ei sivuvaikutuksia
 * sivuston muuhun ulkoasuun.
 */
.dg-doc-legal {
	--dg-doc-legal-border: #cccccc;
	--dg-doc-legal-border-strong: #1a1a1a;
	--dg-doc-legal-bg: #fafafa;
	--dg-doc-legal-text: #1a1a1a;
	--dg-doc-legal-muted: #555;
	--dg-doc-legal-radius: 4px;

	width: min(var(--dg-doc-form-max-width, 800px), 100%);
	max-width: 100%;
	margin: 2.5rem auto 1.5rem;
	color: var(--dg-doc-legal-text);
	line-height: 1.5;
	box-sizing: border-box;
}

.dg-doc-legal__accordion {
	border: 1px solid var(--dg-doc-legal-border);
	border-left-width: 4px;
	border-left-color: var(--dg-doc-legal-border-strong);
	border-radius: var(--dg-doc-legal-radius);
	background: var(--dg-doc-legal-bg);
}

.dg-doc-legal__summary {
	cursor: pointer;
	padding: 1rem 1.25rem;
	font-weight: 600;
	font-size: 1.05rem;
	list-style-position: inside;
}
.dg-doc-legal__summary:focus {
	outline: 2px solid var(--dg-doc-legal-border-strong);
	outline-offset: 2px;
}

.dg-doc-legal__body {
	padding: 0 1.25rem 1.25rem;
}

.dg-doc-legal__intro {
	margin: 0 0 1.25rem;
	color: var(--dg-doc-legal-muted);
	font-size: 0.95rem;
}

.dg-doc-legal__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
}
.dg-doc-legal__copy-status {
	font-size: 0.9rem;
	color: var(--dg-doc-legal-muted);
}

.dg-doc-legal__printable {
	background: #ffffff;
	border: 1px solid var(--dg-doc-legal-border);
	border-radius: var(--dg-doc-legal-radius);
	padding: 1.25rem 1.5rem;
}

.dg-doc-legal .dg-doc-legal__h {
	margin: 1.25rem 0 0.5rem;
	line-height: 1.3;
}
.dg-doc-legal__instructions > .dg-doc-legal__h:first-child {
	margin-top: 0;
}
.dg-doc-legal__printable p {
	margin: 0 0 0.75rem;
}

.dg-doc-legal__model {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--dg-doc-legal-border);
}
.dg-doc-legal__model-note {
	color: var(--dg-doc-legal-muted);
	font-size: 0.9rem;
}

.dg-doc-legal__fields {
	margin: 1rem 0;
}
.dg-doc-legal__fields dt {
	font-weight: 600;
	margin-top: 1rem;
}
.dg-doc-legal__fields dd {
	margin: 0.25rem 0 0;
	/* Säilytä Vastaanottaja-kentän rivinvaihdot (nimi/osoite/email). */
	white-space: pre-line;
}

/* Tulostus: näytä vain tulostettava lomakeosio, piilota muu sivu. ------- */

/*
 * Scopattu .dg-doc-printing -luokkaan, jonka Tulosta-nappi lisää bodyyn
 * ennen window.print():iä ja poistaa sen jälkeen (afterprint). Näin
 * selaimen oma Ctrl+P -tulostus EI laukaise piilotusta eikä sääntö
 * konfliktoi muiden plugarien print-tyylien kanssa.
 */
@media print {
	body.dg-doc-printing * {
		visibility: hidden;
	}
	body.dg-doc-printing .dg-doc-legal__printable,
	body.dg-doc-printing .dg-doc-legal__printable * {
		visibility: visible;
	}
	body.dg-doc-printing .dg-doc-legal__printable {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		border: none;
		padding: 0;
	}
}
