/* =========================================================================
   Naranjeitor by TuDespedida.com — Frontend
   Estética: cítrica, cálida, juguetona pero cuidada.
   ========================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=Nunito:ital,wght@0,400;0,600;0,700;0,800;1,600&display=swap');

.tdn {
	--tdn-orange: #ff7a18;
	--tdn-orange-deep: #e8520c;
	--tdn-orange-dark: #c23d05;
	--tdn-peach: #fff3e6;
	--tdn-peach-2: #ffe6cc;
	--tdn-cream: #fffaf4;
	--tdn-leaf: #4caf50;
	--tdn-ink: #3a2410;
	--tdn-ink-soft: #8a6747;
	--tdn-wa: #25d366;
	--tdn-wa-deep: #128c7e;
	--tdn-radius: 22px;
	--tdn-shadow: 0 18px 50px -18px rgba(200, 80, 10, .45);
	--tdn-shadow-sm: 0 8px 24px -12px rgba(200, 80, 10, .4);

	font-family: 'Nunito', system-ui, sans-serif;
	color: var(--tdn-ink);
	width: 100%;
	max-width: var(--tdn-max, 960px);
	margin: 0 auto;
	padding: 8px 16px 60px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}

.tdn * { box-sizing: border-box; }

/* ---------- Tipografía ---------- */
.tdn h1, .tdn h2, .tdn h3 { font-family: 'Baloo 2', cursive; line-height: 1.1; margin: 0 0 .4em; }
.tdn-h1 { font-size: clamp(2.1rem, 6vw, 3.6rem); font-weight: 800; }
.tdn-h1 span { color: var(--tdn-orange); position: relative; white-space: nowrap; }
.tdn-h2 { font-size: clamp(1.6rem, 4vw, 2.4rem); font-weight: 800; color: var(--tdn-orange-deep); }
.tdn-h3 { font-size: clamp(1.2rem, 3vw, 1.5rem); font-weight: 700; color: var(--tdn-orange-deep); }
.tdn-lead { font-size: 1.12rem; color: var(--tdn-ink-soft); max-width: 46ch; }
.tdn-lead-sm { color: var(--tdn-ink-soft); margin-bottom: 1.2em; }
.tdn-microcopy { font-size: .85rem; color: var(--tdn-ink-soft); margin-top: 10px; }

/* ---------- Botones ---------- */
.tdn-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	font-family: 'Baloo 2', cursive; font-weight: 700; font-size: 1rem;
	padding: 13px 26px; border-radius: 999px; border: 0; cursor: pointer;
	text-decoration: none; transition: transform .15s ease, box-shadow .2s ease, filter .2s ease;
	line-height: 1;
}
.tdn-btn:hover { transform: translateY(-2px); }
.tdn-btn:active { transform: translateY(0); }
.tdn-btn-lg { padding: 17px 38px; font-size: 1.15rem; }
.tdn-btn-primary { background: linear-gradient(135deg, #ff9a3d, var(--tdn-orange-deep)); color: #fff; box-shadow: var(--tdn-shadow-sm); }
.tdn-btn-primary:hover { box-shadow: var(--tdn-shadow); }
.tdn-btn-ghost { background: #fff; color: var(--tdn-orange-deep); border: 2px solid var(--tdn-peach-2); }
.tdn-btn-dark { background: var(--tdn-ink); color: #fff; }
.tdn-btn-wa { background: var(--tdn-wa); color: #fff; }
.tdn-btn-wa::before { content: ""; }
.tdn-btn[disabled] { opacity: .55; cursor: not-allowed; transform: none; }

/* ---------- Tarjetas ---------- */
.tdn-card {
	background: var(--tdn-cream);
	border: 1px solid var(--tdn-peach-2);
	border-radius: var(--tdn-radius);
	padding: 28px;
	box-shadow: var(--tdn-shadow-sm);
	margin: 18px 0;
}
.tdn-center { text-align: center; }
.tdn-logo { max-width: 220px; height: auto; margin-bottom: 18px; }
.tdn-logo-sm { max-height: 56px; width: auto; margin-bottom: 14px; }

/* =========================================================================
   INICIO
   ========================================================================= */
.tdn-start { --tdn-max: 1180px; padding-top: 24px; }
.tdn-hero {
	display: grid; grid-template-columns: 1.05fr .95fr; gap: 44px; align-items: center;
	background: radial-gradient(120% 120% at 0% 0%, var(--tdn-peach) 0%, var(--tdn-cream) 60%);
	border: 1px solid var(--tdn-peach-2); border-radius: 30px; padding: 56px 60px;
	box-shadow: var(--tdn-shadow-sm); position: relative; overflow: hidden;
}
.tdn-hero::after {
	content: "🍊"; position: absolute; right: -30px; bottom: -40px; font-size: 220px; opacity: .08; transform: rotate(-15deg);
}
.tdn-hero-img img { width: 100%; height: auto; border-radius: 18px; }
.tdn-hero-text { position: relative; z-index: 1; }
.tdn-hero-text .tdn-lead { max-width: 52ch; }

.tdn-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 26px; }
.tdn-step { background: #fff; border: 1px solid var(--tdn-peach-2); border-radius: 18px; padding: 22px; box-shadow: var(--tdn-shadow-sm); }
.tdn-step h3 { font-size: 1.15rem; }
.tdn-step p { margin: 0; color: var(--tdn-ink-soft); font-size: .95rem; }
.tdn-step-num {
	display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px;
	border-radius: 50%; background: var(--tdn-orange); color: #fff; font-family: 'Baloo 2'; font-weight: 800; margin-bottom: 12px;
}

.tdn-verdicts { margin-top: 36px; text-align: center; }
.tdn-verdict-grid { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: 14px; }
.tdn-vchip { padding: 9px 16px; border-radius: 999px; font-weight: 700; font-size: .9rem; color: #fff; }
.tdn-v-arrepentimiento { background: #d7392b; }
.tdn-v-cuarentena      { background: #e07a1f; }
.tdn-v-entrenamiento   { background: #f0a500; color: var(--tdn-ink); }
.tdn-v-medianaranja    { background: #7cb342; }
.tdn-v-completa        { background: #2e9e5b; }

/* =========================================================================
   FORMULARIOS
   ========================================================================= */
.tdn-form label { display: block; font-weight: 700; margin-bottom: 14px; font-size: .95rem; }
.tdn-form input, .tdn-form select, .tdn-text {
	width: 100%; margin-top: 6px; padding: 12px 14px; border: 2px solid var(--tdn-peach-2);
	border-radius: 12px; font-family: inherit; font-size: 1rem; font-weight: 600; background: #fff; color: var(--tdn-ink);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.tdn-form input:focus, .tdn-form select:focus, .tdn-text:focus {
	outline: none; border-color: var(--tdn-orange); box-shadow: 0 0 0 4px rgba(255, 122, 24, .15);
}
.tdn-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.tdn-fieldset { border: 1px dashed var(--tdn-peach-2); border-radius: 16px; padding: 18px 18px 6px; margin: 0 0 18px; }
.tdn-fieldset legend { font-family: 'Baloo 2'; font-weight: 700; color: var(--tdn-orange-deep); padding: 0 8px; font-size: 1.05rem; }
.tdn-opt { font-weight: 600; color: var(--tdn-ink-soft); font-size: .85rem; }
.tdn-check { display: flex; align-items: center; gap: 10px; font-weight: 600; }
.tdn-check input { width: auto; margin: 0; }
.tdn-privacy { font-size: .9rem; color: var(--tdn-ink-soft); margin: 14px 0; }
.tdn-friends { display: grid; gap: 10px; margin: 4px 0 14px; }
.tdn-friend-row { display: grid; grid-template-columns: 1.2fr 1.4fr 1fr; gap: 8px; }
.tdn-friend-row input { margin-top: 0; }
.tdn-error { color: #d7392b; font-weight: 700; margin-top: 12px; }

.tdn-links-list { display: grid; gap: 12px; margin: 18px 0; }
.tdn-link-item { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 8px; background: #fff; border: 1px solid var(--tdn-peach-2); border-radius: 14px; padding: 14px; }
.tdn-link-item strong { font-family: 'Baloo 2'; display: block; margin-bottom: 4px; }
.tdn-link-info { flex: 1 1 220px; min-width: 0; }
.tdn-link-url { width: 100%; margin: 0; font-size: .82rem; background: var(--tdn-cream); border: 1px solid var(--tdn-peach-2); border-radius: 8px; padding: 8px 10px; }
.tdn-copy { white-space: nowrap; }
.tdn-btn-sm { padding: 8px 14px; font-size: .85rem; }

/* =========================================================================
   QUIZ
   ========================================================================= */
.tdn-quiz-head { text-align: center; margin-bottom: 10px; }
.tdn-progress { height: 10px; background: var(--tdn-peach-2); border-radius: 999px; overflow: hidden; margin-top: 10px; }
.tdn-progress-bar { height: 100%; width: 0; background: linear-gradient(90deg, #ffb15c, var(--tdn-orange-deep)); transition: width .3s ease; border-radius: 999px; }

.tdn-question {
	background: var(--tdn-cream); border: 1px solid var(--tdn-peach-2); border-radius: var(--tdn-radius);
	padding: 24px; margin: 16px 0; box-shadow: var(--tdn-shadow-sm);
	display: none;
}
.tdn-question.is-active { display: block; animation: tdn-fade .3s ease; }
@keyframes tdn-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.tdn-q-num { font-size: .8rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--tdn-orange); margin: 0 0 6px; }
.tdn-q-text { font-size: 1.4rem; }
.tdn-q-sub { font-weight: 800; color: var(--tdn-ink-soft); margin: 16px 0 8px; font-size: .9rem; }

.tdn-options { display: grid; gap: 10px; }
.tdn-opt {
	display: flex; align-items: center; gap: 12px; text-align: left; width: 100%;
	background: #fff; border: 2px solid var(--tdn-peach-2); border-radius: 14px; padding: 14px 16px;
	font-family: inherit; font-size: 1.02rem; font-weight: 600; color: var(--tdn-ink); cursor: pointer;
	transition: all .15s ease;
}
.tdn-opt:hover { border-color: var(--tdn-orange); transform: translateX(3px); }
.tdn-opt-key {
	flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%; background: var(--tdn-peach);
	display: inline-flex; align-items: center; justify-content: center; font-family: 'Baloo 2'; font-weight: 800; color: var(--tdn-orange-deep);
}
.tdn-opt.is-selected { border-color: var(--tdn-orange-deep); background: var(--tdn-peach); box-shadow: var(--tdn-shadow-sm); }
.tdn-opt.is-selected .tdn-opt-key { background: var(--tdn-orange-deep); color: #fff; }

.tdn-quiz-nav { display: flex; justify-content: space-between; margin-top: 18px; }
#tdn-quiz-submit { display: none; width: 100%; margin-top: 6px; }

/* =========================================================================
   ESPERA
   ========================================================================= */
.tdn-orange-spin, .tdn-orange-sad { font-size: 64px; margin: 10px 0; }
.tdn-orange-spin { animation: tdn-spin 3s linear infinite; display: inline-block; }
@keyframes tdn-spin { to { transform: rotate(360deg); } }
.tdn-wait-count { font-family: 'Baloo 2'; font-weight: 700; font-size: 1.1rem; color: var(--tdn-orange-deep); margin: 8px 0 16px; }
.tdn-part-list { list-style: none; padding: 0; margin: 0 0 20px; text-align: left; max-width: 420px; margin-inline: auto; }
.tdn-part { display: flex; justify-content: space-between; align-items: center; padding: 11px 14px; border-radius: 12px; margin-bottom: 8px; font-weight: 600; }
.tdn-part.is-done { background: #eef8ee; }
.tdn-part.is-pending { background: #fff4e8; }
.tdn-part-name em { color: var(--tdn-ink-soft); font-weight: 600; }
.tdn-waiting .tdn-btn { margin: 6px; }

/* =========================================================================
   RESULTADO
   ========================================================================= */
.tdn-result-hero {
	text-align: center; padding: 38px 24px; border-radius: 30px; position: relative; overflow: hidden;
	background: radial-gradient(120% 120% at 50% 0%, var(--tdn-peach) 0%, var(--tdn-cream) 70%);
	border: 1px solid var(--tdn-peach-2); box-shadow: var(--tdn-shadow);
}
.tdn-result-pair { font-family: 'Baloo 2'; font-weight: 700; font-size: 1.2rem; color: var(--tdn-ink-soft); margin: 4px 0 8px; }

.tdn-score-ring { position: relative; width: 200px; height: 200px; margin: 6px auto 14px; }
.tdn-ring { width: 100%; height: 100%; transform: rotate(-90deg); }
.tdn-ring-bg { fill: none; stroke: var(--tdn-peach-2); stroke-width: 10; }
.tdn-ring-fg { fill: none; stroke: var(--tdn-orange-deep); stroke-width: 10; stroke-linecap: round;
	stroke-dasharray: 326.7; stroke-dashoffset: 326.7; transition: stroke-dashoffset 1.4s cubic-bezier(.2,.8,.2,1); }
.tdn-score-num { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center;
	font-family: 'Baloo 2'; font-weight: 800; font-size: 3.4rem; color: var(--tdn-orange-deep); line-height: 1; }
.tdn-score-num small { font-size: 1.1rem; color: var(--tdn-ink-soft); }

.tdn-verdict-title { font-size: clamp(1.8rem, 5vw, 2.8rem); color: var(--tdn-orange-deep); }
.tdn-verdict-frase { font-style: italic; color: var(--tdn-ink-soft); max-width: 40ch; margin: 0 auto 14px; }
.tdn-seal { display: inline-block; padding: 8px 18px; border-radius: 999px; background: var(--tdn-ink); color: #fff; font-family: 'Baloo 2'; font-weight: 700; }

/* Tema por veredicto */
.tdn-result-arrepentimiento .tdn-ring-fg { stroke: #d7392b; }
.tdn-result-arrepentimiento .tdn-score-num,
.tdn-result-arrepentimiento .tdn-verdict-title { color: #d7392b; }
.tdn-result-cuarentena .tdn-ring-fg { stroke: #e07a1f; }
.tdn-result-entrenamiento .tdn-ring-fg { stroke: #f0a500; }
.tdn-result-medianaranja .tdn-ring-fg { stroke: #7cb342; }
.tdn-result-medianaranja .tdn-score-num, .tdn-result-medianaranja .tdn-verdict-title { color: #5a9216; }
.tdn-result-completa .tdn-ring-fg { stroke: #2e9e5b; }
.tdn-result-completa .tdn-score-num, .tdn-result-completa .tdn-verdict-title { color: #1f8049; }

/* Desglose */
.tdn-breakdown { display: grid; gap: 14px; }
.tdn-bd-top { display: flex; justify-content: space-between; font-weight: 700; margin-bottom: 6px; }
.tdn-bd-pts { color: var(--tdn-orange-deep); font-family: 'Baloo 2'; }
.tdn-bd-bar { height: 12px; background: var(--tdn-peach-2); border-radius: 999px; overflow: hidden; }
.tdn-bd-fill { height: 100%; background: linear-gradient(90deg, #ffb15c, var(--tdn-orange-deep)); border-radius: 999px; width: 0; transition: width 1s ease .3s; }

/* Notas */
.tdn-note { margin: 0 0 10px; padding: 12px 16px; background: var(--tdn-peach); border-left: 4px solid var(--tdn-orange); border-radius: 10px; font-style: italic; }

/* Recomendación */
.tdn-reco { background: linear-gradient(135deg, #fff, var(--tdn-peach)); }
.tdn-reco-kicker { display: inline-block; background: var(--tdn-orange); color: #fff; font-family: 'Baloo 2'; font-weight: 700; padding: 5px 14px; border-radius: 999px; font-size: .85rem; margin-bottom: 14px; }
.tdn-reco-body { display: grid; grid-template-columns: 200px 1fr; gap: 20px; align-items: center; }
.tdn-reco-img img { width: 100%; height: 100%; object-fit: cover; border-radius: 16px; max-height: 180px; }
.tdn-reco-text p { color: var(--tdn-ink-soft); }
.tdn-reco-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }

.tdn-result-cta { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin: 24px 0; }
.tdn-disclaimer { font-size: .78rem; color: var(--tdn-ink-soft); text-align: center; max-width: 60ch; margin: 10px auto 0; }

/* =========================================================================
   DIPLOMA
   ========================================================================= */
.tdn-diploma-wrap { max-width: 800px; margin: 0 auto; padding: 16px; font-family: 'Nunito', sans-serif; }
.tdn-diploma {
	aspect-ratio: 1.414 / 1; background: var(--tdn-cream, #fffaf4); background-size: cover; background-position: center;
	border: 10px solid #ff7a18; border-radius: 14px; box-shadow: 0 18px 50px -18px rgba(200,80,10,.5);
	position: relative; overflow: hidden;
}
.tdn-diploma::before { content: ""; position: absolute; inset: 14px; border: 2px dashed rgba(200,80,10,.4); border-radius: 8px; pointer-events: none; }
.tdn-diploma-inner { position: relative; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 6% 8%; }
.tdn-diploma-logo { max-height: 64px; margin-bottom: 8px; }
.tdn-diploma-kicker { letter-spacing: .3em; text-transform: uppercase; font-size: .8rem; color: #c23d05; font-weight: 800; margin: 0; }
.tdn-diploma-title { font-family: 'Baloo 2', cursive; font-weight: 800; font-size: clamp(2rem, 6vw, 3.4rem); color: #e8520c; margin: 2px 0; letter-spacing: .04em; }
.tdn-diploma-sub { font-style: italic; color: #8a6747; margin: 0 0 14px; }
.tdn-diploma-pair { font-family: 'Baloo 2', cursive; font-weight: 700; font-size: clamp(1.4rem, 4vw, 2rem); color: #3a2410; margin: 6px 0; }
.tdn-diploma-seal { display: flex; flex-direction: column; align-items: center; gap: 2px; margin: 8px 0; }
.tdn-diploma-score { font-family: 'Baloo 2'; font-weight: 800; font-size: clamp(2.4rem, 7vw, 4rem); color: #e8520c; }
.tdn-diploma-score small { font-size: .4em; color: #8a6747; }
.tdn-diploma-verdict { background: #3a2410; color: #fff; font-family: 'Baloo 2'; font-weight: 700; padding: 5px 16px; border-radius: 999px; }
.tdn-diploma-frase { font-style: italic; color: #5a3a1d; max-width: 42ch; margin: 8px auto; }
.tdn-diploma-nota { font-size: .85rem; color: #8a6747; }
.tdn-diploma-foot { display: flex; align-items: flex-end; justify-content: space-between; width: 100%; margin-top: auto; }
.tdn-diploma-sign { display: flex; flex-direction: column; align-items: center; font-size: .8rem; color: #8a6747; }
.tdn-diploma-line { width: 160px; border-top: 2px solid #c23d05; margin-bottom: 4px; }
.tdn-diploma-qr { width: 78px; height: 78px; background: #fff; padding: 4px; border-radius: 8px; }
.tdn-diploma-actions { display: flex; gap: 12px; justify-content: center; margin-top: 20px; flex-wrap: wrap; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 860px) {
	.tdn-hero { grid-template-columns: 1fr; text-align: center; padding: 32px 24px; gap: 24px; }
	.tdn-hero-text { display: flex; flex-direction: column; align-items: center; }
	.tdn-hero-text .tdn-lead { max-width: 46ch; }
	.tdn-hero-img { order: -1; max-width: 300px; margin: 0 auto; }
}
@media (max-width: 720px) {
	.tdn-steps { grid-template-columns: 1fr; }
	.tdn-row { grid-template-columns: 1fr; }
	.tdn-friend-row { grid-template-columns: 1fr; }
	.tdn-reco-body { grid-template-columns: 1fr; }
	.tdn-reco-img img { max-height: 200px; }
}

/* ---------- Impresión (diploma como PDF) ---------- */
@media print {
	body * { visibility: hidden; }
	.tdn-diploma-wrap, .tdn-diploma-wrap * { visibility: visible; }
	.tdn-diploma-wrap { position: absolute; inset: 0; margin: 0; padding: 0; max-width: none; }
	.tdn-noprint { display: none !important; }
	.tdn-diploma { border-radius: 0; box-shadow: none; width: 100%; height: 100vh; aspect-ratio: auto; }
	@page { size: A4 landscape; margin: 0; }
}

/* =========================================================================
   v1.1 — LOGO SIN CAJA BLANCA + ANIMACIONES + ESTÉTICA MÁS LLAMATIVA
   ========================================================================= */

/* El truco "multiply" hace desaparecer el fondo blanco del logo sobre
   fondos claros, conservando los colores del dibujo. */
.tdn-logo, .tdn-logo-sm, .tdn-logo-blend { mix-blend-mode: multiply; }

/* ---- Entrada de tarjetas ---- */
@keyframes tdn-pop-in { 0% { opacity: 0; transform: translateY(18px) scale(.97); } 100% { opacity: 1; transform: none; } }
.tdn-pop { animation: tdn-pop-in .55s cubic-bezier(.2,.9,.2,1) both; }
.tdn-card { animation: tdn-pop-in .5s ease both; }

/* ---- Botón principal con pulso de energía ---- */
@keyframes tdn-glow {
	0%, 100% { box-shadow: 0 10px 26px -10px rgba(232,82,12,.65); }
	50%      { box-shadow: 0 16px 40px -8px rgba(232,82,12,.95), 0 0 0 6px rgba(255,154,61,.18); }
}
.tdn-btn-glow { animation: tdn-glow 2.2s ease-in-out infinite; }
.tdn-btn-glow:hover { animation-play-state: paused; }
.tdn-btn-lg { letter-spacing: .2px; }

/* ---- Opciones del test: rebote + check al elegir ---- */
.tdn-opt { position: relative; padding-right: 44px; }
.tdn-opt.is-selected { animation: tdn-bounce .35s ease; }
@keyframes tdn-bounce { 0% { transform: scale(1); } 40% { transform: scale(1.04); } 70% { transform: scale(.99); } 100% { transform: scale(1); } }
.tdn-opt.is-selected::after {
	content: "✓"; position: absolute; right: 16px; top: 50%; transform: translateY(-50%);
	font-weight: 900; color: #fff; background: var(--tdn-orange-deep);
	width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .8rem;
	animation: tdn-pop-in .25s ease both;
}
.tdn-opt-multi.is-selected::after { content: "✓"; }

/* ---- Barra de progreso con brillo en movimiento ---- */
.tdn-progress { height: 14px; }
.tdn-progress-bar { position: relative; overflow: hidden; }
.tdn-progress-bar::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
	transform: translateX(-100%); animation: tdn-shimmer 1.6s infinite;
}
@keyframes tdn-shimmer { 100% { transform: translateX(100%); } }

/* ---- Naranja flotante del hero ---- */
.tdn-hero::after { animation: tdn-float 6s ease-in-out infinite; }
@keyframes tdn-float { 0%, 100% { transform: rotate(-15deg) translateY(0); } 50% { transform: rotate(-9deg) translateY(-16px); } }

/* ---- Acento de color vivo en hero y resultado ---- */
.tdn-hero { background:
	radial-gradient(130% 130% at 0% 0%, #ffe0c0 0%, var(--tdn-cream) 55%),
	linear-gradient(135deg, rgba(255,154,61,.10), rgba(124,179,66,.06)); }
.tdn-h1 span::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: 6px; height: .35em;
	background: linear-gradient(90deg, #ffd28a, #ff9a3d); opacity: .45; border-radius: 6px; z-index: -1;
}

/* ---- Chips de veredicto con vidilla ---- */
.tdn-vchip { transition: transform .15s ease, box-shadow .2s ease; box-shadow: 0 6px 16px -8px rgba(0,0,0,.35); }
.tdn-vchip:hover { transform: translateY(-4px) rotate(-1.5deg) scale(1.04); }

/* ---- Pasos: hover divertido ---- */
.tdn-step { transition: transform .18s ease, box-shadow .25s ease; }
.tdn-step:hover { transform: translateY(-5px); box-shadow: var(--tdn-shadow); }

/* ---- Resultado: celebración ---- */
.tdn-result-hero { animation: tdn-pop-in .6s ease both; }
.tdn-seal { animation: tdn-pop-in .7s .25s ease both; }
.tdn-verdict-title { animation: tdn-pop-in .6s .15s ease both; }
.tdn-score-ring { animation: tdn-ring-bounce .9s .1s cubic-bezier(.2,.9,.2,1) both; }
@keyframes tdn-ring-bounce { 0% { transform: scale(.7); opacity: 0; } 60% { transform: scale(1.06); } 100% { transform: scale(1); opacity: 1; } }

/* ---- Emoji celebración en tarjeta de enlaces ---- */
.tdn-confetti-emoji { font-size: 46px; display: block; margin-bottom: 6px; animation: tdn-pop-in .5s ease both, tdn-float 4s ease-in-out infinite; }

/* ---- Naranja girando (espera) un poco más viva ---- */
.tdn-orange-spin { font-size: 56px; animation: tdn-spin 3s linear infinite; }
@keyframes tdn-spin { 100% { transform: rotate(360deg); } }

/* ---- Lluvia de confeti (se crea desde JS) ---- */
.tdn-confetti { position: fixed; inset: 0; pointer-events: none; overflow: hidden; z-index: 9999; }
.tdn-confetti i {
	position: absolute; top: -16px; width: 10px; height: 14px; border-radius: 2px; opacity: .95;
	animation: tdn-fall linear forwards;
}
@keyframes tdn-fall { to { transform: translateY(110vh) rotate(720deg); } }

/* ---- Respeto a quien prefiere menos movimiento ---- */
@media (prefers-reduced-motion: reduce) {
	.tdn-pop, .tdn-card, .tdn-btn-glow, .tdn-result-hero, .tdn-seal, .tdn-verdict-title,
	.tdn-score-ring, .tdn-confetti-emoji, .tdn-orange-spin, .tdn-hero::after { animation: none !important; }
	.tdn-progress-bar::after { display: none; }
}
