/* DSE Tools — shared styles. Brand palette pulled from /dse-update/config/brand_colors.json. */

:root {
	--dse-primary:    #2872FA;
	--dse-secondary:  #1559ED;
	--dse-accent:     #4D6BFE;
	--dse-ink:        #192A3D;
	--dse-muted:      #3A4F66;
	--dse-rule:       #E1E8ED;
	--dse-soft-bg:    #F2F5F7;
	--dse-bg:         #FFFFFF;
	--dse-radius:     10px;
	--dse-shadow:     0 1px 2px rgba(25,42,61,0.04), 0 4px 12px rgba(25,42,61,0.06);
	--dse-font:       inherit;
}

/* === Tool wrapper === */
.dse-tool {
	display: block;
	margin: 24px 0;
	padding: 20px;
	background: var(--dse-bg);
	border: 1px solid var(--dse-rule);
	border-radius: var(--dse-radius);
	box-shadow: var(--dse-shadow);
	color: var(--dse-ink);
	font-family: var(--dse-font);
}
.dse-tool h3 {
	margin: 0 0 14px;
	font-size: 1.15em;
	color: var(--dse-ink);
}
.dse-tool .dse-tool-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 12px 16px;
}
.dse-tool label {
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 0.92em;
	color: var(--dse-muted);
}
.dse-tool input[type="number"],
.dse-tool input[type="text"],
.dse-tool select,
.dse-tool textarea {
	padding: 8px 10px;
	border: 1px solid var(--dse-rule);
	border-radius: 6px;
	background: var(--dse-bg);
	color: var(--dse-ink);
	font-size: 0.95em;
	width: 100%;
	box-sizing: border-box;
}
.dse-tool textarea {
	min-height: 120px;
	resize: vertical;
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}
.dse-tool input[type="range"] {
	width: 100%;
}
.dse-tool button {
	padding: 9px 16px;
	background: var(--dse-primary);
	color: #fff;
	border: 0;
	border-radius: 6px;
	font-weight: 600;
	cursor: pointer;
	font-size: 0.95em;
}
.dse-tool button:hover { background: var(--dse-secondary); }
.dse-tool button.dse-tool-secondary {
	background: var(--dse-bg);
	color: var(--dse-primary);
	border: 1px solid var(--dse-primary);
}

/* === Result panels === */
.dse-tool-result {
	margin-top: 16px;
	padding: 14px;
	background: var(--dse-soft-bg);
	border-left: 3px solid var(--dse-primary);
	border-radius: 6px;
}
.dse-tool-result dl {
	margin: 0;
	display: grid;
	grid-template-columns: max-content 1fr;
	column-gap: 12px;
	row-gap: 4px;
}
.dse-tool-result dt {
	color: var(--dse-muted);
	font-size: 0.9em;
}
.dse-tool-result dd {
	margin: 0;
	color: var(--dse-ink);
	font-weight: 600;
}
.dse-tool-result .dse-strong { color: var(--dse-primary); font-size: 1.15em; }

/* === TOC === */
.dse-toc {
	margin: 22px 0;
	padding: 16px 20px;
	background: var(--dse-soft-bg);
	border: 1px solid var(--dse-rule);
	border-radius: var(--dse-radius);
	color: var(--dse-ink);
}
.dse-toc-title {
	margin: 0 0 8px;
	font-weight: 700;
	font-size: 0.95em;
	color: var(--dse-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.dse-toc ol, .dse-toc ul {
	margin: 0; padding-left: 18px; list-style: decimal;
}
.dse-toc li {
	margin: 4px 0;
	color: var(--dse-ink);
}
.dse-toc a {
	color: var(--dse-ink);
	text-decoration: none;
	border-bottom: 1px dashed transparent;
}
.dse-toc a:hover { border-bottom-color: var(--dse-primary); color: var(--dse-primary); }
.dse-toc .dse-toc-h3 { padding-left: 14px; font-size: 0.95em; color: var(--dse-muted); }

/* === Sources === */
.dse-sources {
	margin: 24px 0;
	padding: 18px 20px;
	background: var(--dse-bg);
	border: 1px solid var(--dse-rule);
	border-radius: var(--dse-radius);
}
.dse-sources ol {
	margin: 0; padding-left: 22px;
	font-size: 0.94em; color: var(--dse-ink);
}
.dse-sources li { margin: 6px 0; }
.dse-sources a {
	color: var(--dse-primary);
	text-decoration: none;
	word-break: break-word;
}
.dse-sources a:hover { color: var(--dse-secondary); text-decoration: underline; }
.dse-sources .dse-source-meta {
	color: var(--dse-muted);
	font-size: 0.92em;
}

/* === Legacy banner (used by site-wide CSS, not by plugin shortcodes) === */
.dse-legacy-banner {
	margin: 0 0 18px;
	padding: 12px 16px;
	background: #FFF8E1;
	border-left: 4px solid #F4B400;
	border-radius: 6px;
	color: var(--dse-ink);
	font-size: 0.96em;
}
.dse-legacy-banner.dse-legacy-deprecated {
	background: #FDECEA;
	border-left-color: #D32F2F;
}
.dse-legacy-banner.dse-legacy-vigente {
	background: #E8F0FE;
	border-left-color: var(--dse-primary);
}
.dse-updated-stamp {
	font-size: 0.86em;
	color: var(--dse-muted);
	margin: 4px 0 16px;
}

@media (max-width: 600px) {
	.dse-tool { padding: 14px; }
	.dse-tool .dse-tool-grid { grid-template-columns: 1fr; }
}
