﻿/*
Theme Name: Diverkion
Theme URI: https://diverkion.com
Author: Roger Torreda
Author URI: https://diverkion.com
Description: Tema premium para DIVERKION.com — tienda WooCommerce de juguetes naturales, sensoriales y libres de quimicos. Estetica calida y minimalista.
Version: 1.1.52
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: diverkion
Tags: woocommerce, e-commerce, custom-colors, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready, two-columns, right-sidebar
WC requires at least: 7.0
WC tested up to: 8.8
*/

/* ==========================================================================
   DIVERKION â€” Design Tokens
   Paleta cÃ¡lida natural: avena/crema, arcilla/terracota, salvia, madera.
   ========================================================================== */
:root {
  /* ---- DiseÃ±o pastel DiverKion ---- */
  --dk-white:        #FFFFFF;
  --dk-cream:        #FFFDFB; /* fondo principal (casi blanco) */
  --dk-oat:          #FBF6EF; /* secciones suaves */
  --dk-sand:         #F1E9DF; /* bordes cÃ¡lidos */
  --dk-charcoal:     #3B3A4A; /* texto principal (pizarra) */
  --dk-muted:        #8C8A99; /* texto secundario */
  --dk-line:         #ECEAF2; /* lÃ­neas / divisores */
  --dk-success:      #6BAE7E;
  --dk-sale:         #E0533A;

  /* Naranja de marca (logo DK) â€” acciÃ³n / compra */
  --dk-brand:        #F5A623;
  --dk-brand-dark:   #E78A0C;
  --dk-brand-soft:   #FDEFD6;

  /* Lila â€” color secundario (titulares, newsletter) */
  --dk-purple:       #9B80D6;
  --dk-purple-dark:  #7E5FC4;
  --dk-purple-soft:  #EDE6FA;

  /* Pasteles para tarjetas de categorÃ­a / banners */
  --dk-pastel-peach: #FBE3CE;
  --dk-pastel-yellow:#FBEFC2;
  --dk-pastel-mint:  #D9EFD6;
  --dk-pastel-lilac: #E9E1F8;
  --dk-pastel-blue:  #D9E9F8;
  --dk-pastel-pink:  #F9DCE8;
  --dk-pastel-blue-deep:#BBD3F0;

  /* Alias retro-compatibles (usados por componentes antiguos) */
  --dk-clay:         #E89B6B;
  --dk-sage:         #8FBF9A;
  --dk-sage-dark:    #5FA579;
  --dk-wood:         #E78A0C;
  --dk-yellow:       #F6C453;
  --dk-mint:         #EAF6EA;

  /* TipografÃ­a */
  --dk-font-display: "Fredoka", "Varela Round", "Trebuchet MS", sans-serif;
  --dk-font-body:    "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Radios y sombras (suaves, orgÃ¡nicos) */
  --dk-radius-sm: 10px;
  --dk-radius:    18px;
  --dk-radius-lg: 28px;
  --dk-radius-pill: 999px;
  --dk-shadow:    0 12px 34px -16px rgba(62, 58, 52, 0.28);
  --dk-shadow-sm: 0 6px 18px -10px rgba(62, 58, 52, 0.25);

  /* Layout */
  --dk-wrap: 1240px;
  --dk-gap: 28px;

  /* Transiciones */
  --dk-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ==========================================================================
   Reset suave
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--dk-font-body);
  font-size: 17px;
  line-height: 1.7;
  color: var(--dk-charcoal);
  background: var(--dk-cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }

a {
  color: var(--dk-wood);
  text-decoration: none;
  transition: color 0.25s var(--dk-ease);
}
a:hover { color: var(--dk-clay); }

h1, h2, h3, h4 {
  font-family: var(--dk-font-display);
  font-weight: 700;
  line-height: 1.15;
  color: var(--dk-charcoal);
  margin: 0 0 0.5em;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(2.2rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.8rem, 3.6vw, 2.7rem); }
h3 { font-size: 1.35rem; }

p { margin: 0 0 1.2em; }

.dk-wrap {
  width: 100%;
  max-width: var(--dk-wrap);
  margin-inline: auto;
  padding-inline: 24px;
}

.dk-eyebrow {
  display: inline-block;
  font-family: var(--dk-font-body);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dk-clay);
  margin-bottom: 0.8rem;
}

.dk-section { padding-block: clamp(56px, 8vw, 110px); }
.dk-section--oat { background: var(--dk-oat); }
.dk-section--sage { background: var(--dk-sage); color: var(--dk-cream); }
.dk-section--sage h2, .dk-section--sage h3 { color: var(--dk-cream); }

.dk-center { text-align: center; }
.dk-section__head { max-width: 660px; margin-inline: auto; margin-bottom: 3rem; }
.dk-section__head p { color: var(--dk-muted); font-size: 1.08rem; }
.dk-section--sage .dk-section__head p { color: rgba(251, 247, 240, 0.85); }

/* ==========================================================================
   Botones
   ========================================================================== */
.dk-btn,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  font-family: var(--dk-font-body);
  font-weight: 700;
  font-size: 0.98rem;
  line-height: 1;
  padding: 0.95em 1.9em;
  border: none;
  border-radius: var(--dk-radius-pill);
  background: var(--dk-brand);
  color: var(--dk-white) !important;
  cursor: pointer;
  box-shadow: 0 10px 22px -12px rgba(224, 127, 31, 0.8);
  transition: transform 0.25s var(--dk-ease), box-shadow 0.25s var(--dk-ease), background 0.25s var(--dk-ease);
  text-align: center;
}
.dk-btn:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background: var(--dk-brand-dark);
  color: var(--dk-white) !important;
  transform: translateY(-2px);
  box-shadow: 0 14px 28px -12px rgba(224, 127, 31, 0.9);
}

.dk-btn--ghost {
  background: transparent;
  color: var(--dk-charcoal) !important;
  border: 1.5px solid var(--dk-charcoal);
}
.dk-btn--ghost:hover {
  background: var(--dk-charcoal);
  color: var(--dk-cream) !important;
}
.dk-btn--sage { background: var(--dk-sage-dark); }
.dk-btn--light { background: var(--dk-cream); color: var(--dk-charcoal) !important; }
.dk-btn--light:hover { background: var(--dk-white); }

/* ==========================================================================
   Header
   ========================================================================== */
.dk-topbar {
  background: linear-gradient(90deg, var(--dk-brand) 0%, var(--dk-brand-dark) 100%);
  color: #fff;
  font-size: 0.83rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.dk-topbar .dk-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding-block: 8px;
  text-align: center;
}
.dk-topbar a { color: #fff; text-decoration: underline; }

/* Header global */
.dk-header { background: var(--dk-white); border-bottom: 1px solid var(--dk-line); }

/* â”€â”€ Fila 1: Logo + bÃºsqueda + carrito â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dk-header-branding { background: var(--dk-white); padding-block: 14px; }
.dk-header-branding__inner {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 24px;
}

/* Logo */
.dk-header__brand { flex: 0 0 auto; display: flex; align-items: center; }
.dk-logo {
  font-family: var(--dk-font-display);
  font-weight: 600;
  font-size: 1.7rem;
  letter-spacing: 0.02em;
  color: var(--dk-charcoal);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  text-decoration: none;
}
.dk-logo:hover { color: var(--dk-brand-dark); }
.dk-logo__mark {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  line-height: 1;
  color: var(--dk-brand);
}
.dk-logo__smile { display: block; width: 36px; margin-top: -4px; color: var(--dk-brand); }
.dk-logo__word { font-size: 1.4rem; color: var(--dk-charcoal); }
.dk-logo--img img,
.custom-logo-link img,
.dk-header__brand .custom-logo {
  max-height: 72px;
  width: auto !important;
  height: auto;
  object-fit: contain;
  display: block;
}

/* Buscador central */
.dk-header-search { flex: 1; }
.dk-header-search form {
  display: flex;
  align-items: center;
  background: var(--dk-oat);
  border: 1.5px solid var(--dk-line);
  border-radius: var(--dk-radius-pill);
  overflow: hidden;
  transition: border-color 0.2s;
}
.dk-header-search form:focus-within { border-color: var(--dk-brand); }
.dk-header-search input[type="search"] {
  flex: 1;
  border: none;
  background: transparent;
  padding: 11px 18px;
  font-family: var(--dk-font-body);
  font-size: 0.97rem;
  color: var(--dk-charcoal);
  outline: none;
}
.dk-header-search button {
  background: var(--dk-brand);
  border: none;
  padding: 0 18px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #fff;
  transition: background 0.2s;
}
.dk-header-search button:hover { background: var(--dk-brand-dark); }
.dk-header-search button svg { width: 20px; height: 20px; }

/* Iconos de acciÃ³n */
.dk-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
.dk-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 6px 10px;
  border-radius: var(--dk-radius-sm);
  color: var(--dk-charcoal);
  font-size: 0.72rem;
  font-weight: 600;
  text-decoration: none;
  position: relative;
  transition: background 0.2s, color 0.2s;
  white-space: nowrap;
}
.dk-action svg { width: 22px; height: 22px; }
.dk-action:hover { background: var(--dk-oat); color: var(--dk-brand-dark); }
.dk-action__badge {
  position: absolute;
  top: 2px; right: 4px;
  background: var(--dk-brand);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 800;
  min-width: 17px; height: 17px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  padding: 0 3px;
  line-height: 1;
}
.dk-cart-count { position: absolute; top: 2px; right: 4px; }

/* â”€â”€ Fila 2: Barra de navegaciÃ³n (sticky) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dk-header-nav {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--dk-charcoal);
  box-shadow: 0 2px 12px rgba(59,58,74,0.18);
}
.dk-header-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 50px;
}
.dk-nav { flex: 1; }
.dk-menu {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 2px;
  margin: 0;
  padding: 0;
}
.dk-menu a {
  display: inline-block;
  padding: 12px 16px;
  font-weight: 600;
  font-size: 0.94rem;
  color: rgba(255,255,255,0.88);
  border-radius: 0;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.dk-menu a:hover,
.dk-menu .current-menu-item > a {
  background: rgba(255,255,255,0.12);
  color: var(--dk-brand);
}
.dk-menu li.menu-item-has-children > a::after { content: " â–¾"; font-size: 0.7em; opacity: 0.7; }
.dk-menu ul {
  display: none;
  position: absolute;
  flex-direction: column;
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius-sm);
  box-shadow: var(--dk-shadow);
  padding: 6px;
  min-width: 210px;
  gap: 2px;
  z-index: 300;
  top: 100%;
  left: 0;
}
.dk-menu li { position: relative; }
.dk-menu li:hover > ul { display: flex; }
.dk-menu ul a { color: var(--dk-charcoal); width: 100%; padding: 8px 14px; font-size: 0.92rem; border-radius: var(--dk-radius-sm); }
.dk-menu ul a:hover { background: var(--dk-oat); color: var(--dk-brand-dark); }

.dk-icon-btn {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  color: var(--dk-white);
  background: transparent;
  border: none; cursor: pointer;
  transition: background 0.2s;
}
.dk-icon-btn:hover { background: rgba(255,255,255,0.12); }
.dk-icon-btn svg { width: 22px; height: 22px; }
.dk-burger { display: none; }

/* ==========================================================================
   Hero
   ========================================================================== */
.dk-hero {
  position: relative;
  background:
    radial-gradient(120% 90% at 85% 10%, rgba(201,139,107,0.16), transparent 55%),
    radial-gradient(100% 80% at 5% 90%, rgba(143,163,131,0.18), transparent 50%),
    var(--dk-cream);
  overflow: hidden;
}
.dk-hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 56px;
  align-items: center;
  padding-block: clamp(48px, 7vw, 96px);
}
.dk-hero__title { margin-bottom: 0.6rem; }
.dk-hero__lead {
  font-size: 1.18rem;
  color: var(--dk-muted);
  max-width: 46ch;
  margin-bottom: 2rem;
}
.dk-hero__cta { display: flex; flex-wrap: wrap; gap: 14px; }
.dk-hero__media {
  position: relative;
  border-radius: var(--dk-radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3.4;
  background: var(--dk-sand);
  box-shadow: var(--dk-shadow);
}
.dk-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.dk-hero__badge {
  position: absolute;
  bottom: 18px; left: 18px;
  background: var(--dk-white);
  border-radius: var(--dk-radius);
  padding: 12px 18px;
  box-shadow: var(--dk-shadow-sm);
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; font-size: 0.9rem;
}
.dk-hero__badge span.dk-emoji { font-size: 1.4rem; }

/* Tira de valores bajo el hero */
.dk-trust {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  border-top: 1px solid var(--dk-line);
  padding-block: 28px;
}
.dk-trust__item { display: flex; align-items: center; gap: 12px; font-weight: 600; font-size: 0.95rem; }
.dk-trust__icon {
  flex: 0 0 auto; width: 46px; height: 46px;
  display: grid; place-items: center;
  background: var(--dk-oat); border-radius: 14px;
  color: var(--dk-sage-dark);
}
.dk-trust__icon svg { width: 24px; height: 24px; }

/* ==========================================================================
   CategorÃ­as
   ========================================================================== */
.dk-cats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--dk-gap);
}
.dk-cat {
  position: relative;
  display: block;
  border-radius: var(--dk-radius);
  overflow: hidden;
  background: var(--dk-sand);
  aspect-ratio: 3 / 4;
  box-shadow: var(--dk-shadow-sm);
  transition: transform 0.35s var(--dk-ease);
}
.dk-cat:hover { transform: translateY(-6px); }
.dk-cat img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--dk-ease); }
.dk-cat:hover img { transform: scale(1.06); }
.dk-cat__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 35%, rgba(62,58,52,0.72) 100%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 22px;
}
.dk-cat__name { color: var(--dk-cream); font-family: var(--dk-font-display); font-size: 1.4rem; margin: 0; }
.dk-cat__count { color: rgba(251,247,240,0.8); font-size: 0.85rem; font-weight: 600; }

/* ==========================================================================
   SecciÃ³n "Crea tu cesta ideal"
   ========================================================================== */
.dk-basket {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.dk-basket__steps { list-style: none; margin: 1.6rem 0 2rem; padding: 0; display: grid; gap: 18px; }
.dk-basket__steps li { display: flex; gap: 16px; align-items: flex-start; }
.dk-basket__num {
  flex: 0 0 auto; width: 40px; height: 40px; border-radius: 50%;
  background: var(--dk-cream); color: var(--dk-wood);
  display: grid; place-items: center; font-family: var(--dk-font-display); font-weight: 600; font-size: 1.1rem;
}
.dk-section--sage .dk-basket__num { background: var(--dk-cream); }
.dk-basket__media {
  border-radius: var(--dk-radius-lg); overflow: hidden;
  aspect-ratio: 1/1; box-shadow: var(--dk-shadow); background: var(--dk-oat);
}
.dk-basket__media img { width: 100%; height: 100%; object-fit: cover; }

/* ==========================================================================
   Valores / Compromiso
   ========================================================================== */
.dk-values {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--dk-gap);
}
.dk-value {
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 32px 28px;
  text-align: center;
  transition: transform 0.3s var(--dk-ease), box-shadow 0.3s var(--dk-ease);
}
.dk-value:hover { transform: translateY(-4px); box-shadow: var(--dk-shadow); }
.dk-value__icon {
  width: 64px; height: 64px; margin: 0 auto 18px;
  display: grid; place-items: center;
  background: var(--dk-oat); border-radius: 20px; color: var(--dk-sage-dark);
}
.dk-value__icon svg { width: 32px; height: 32px; }
.dk-value h3 { margin-bottom: 0.4rem; }
.dk-value p { color: var(--dk-muted); font-size: 0.97rem; margin: 0; }

/* ==========================================================================
   Testimonios
   ========================================================================== */
.dk-quotes { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--dk-gap); }
.dk-quote {
  background: var(--dk-white); border-radius: var(--dk-radius);
  padding: 30px; border: 1px solid var(--dk-line);
}
.dk-quote__stars { color: var(--dk-clay); letter-spacing: 2px; margin-bottom: 0.6rem; }
.dk-quote p { font-style: italic; color: var(--dk-charcoal); }
.dk-quote__author { font-weight: 700; font-style: normal; color: var(--dk-muted); font-size: 0.9rem; }

/* ==========================================================================
   Newsletter
   ========================================================================== */
.dk-newsletter { text-align: center; }
.dk-newsletter__form {
  display: flex; gap: 10px; max-width: 480px; margin: 1.6rem auto 0;
}
.dk-newsletter__form input[type="email"] {
  flex: 1; padding: 0.95em 1.4em; border-radius: var(--dk-radius-pill);
  border: 1.5px solid var(--dk-line); background: var(--dk-white);
  font-family: var(--dk-font-body); font-size: 1rem;
}
.dk-newsletter__form input:focus { outline: none; border-color: var(--dk-clay); }

/* ==========================================================================
   Footer
   ========================================================================== */
.dk-footer {
  background: var(--dk-charcoal);
  color: rgba(251,247,240,0.78);
  padding-block: 64px 28px;
  font-size: 0.95rem;
}
.dk-footer a { color: rgba(251,247,240,0.78); }
.dk-footer a:hover { color: var(--dk-cream); }
.dk-footer__grid {
  display: grid;
  grid-template-columns: 1.6fr repeat(3, 1fr);
  gap: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(251,247,240,0.12);
}
.dk-footer h4 { color: var(--dk-cream); font-family: var(--dk-font-body); font-weight: 700; font-size: 0.85rem; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 1rem; }
.dk-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.dk-footer__brand .dk-logo { color: var(--dk-cream); margin-bottom: 1rem; }
.dk-footer__social { display: flex; gap: 12px; margin-top: 1rem; }
.dk-footer__social a {
  width: 40px; height: 40px; border-radius: 50%;
  display: grid; place-items: center;
  background: rgba(251,247,240,0.08);
}
.dk-footer__social a:hover { background: var(--dk-clay); color: var(--dk-white); }
.dk-footer__social svg { width: 18px; height: 18px; }
.dk-footer__bottom {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 10px; padding-top: 24px; font-size: 0.85rem;
  color: rgba(251,247,240,0.55);
}
.dk-payments { display: flex; gap: 8px; align-items: center; }
.dk-payments span {
  background: rgba(251,247,240,0.1); border-radius: 6px; padding: 4px 8px;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.05em;
}

/* ==========================================================================
   Contenido genÃ©rico (pÃ¡ginas / blog)
   ========================================================================== */
.dk-page { padding-block: clamp(40px, 6vw, 80px); }
.dk-page__layout { display: grid; grid-template-columns: 1fr; gap: 48px; }
.dk-page--sidebar .dk-page__layout { grid-template-columns: minmax(0,1fr) 300px; }
.dk-article { background: var(--dk-white); border: 1px solid var(--dk-line); border-radius: var(--dk-radius); padding: clamp(24px, 4vw, 48px); }
.dk-page-title { margin-bottom: 0.4rem; }
.dk-breadcrumbs { font-size: 0.85rem; color: var(--dk-muted); margin-bottom: 1.6rem; }
.dk-breadcrumbs a { color: var(--dk-muted); }

.widget { background: var(--dk-white); border: 1px solid var(--dk-line); border-radius: var(--dk-radius); padding: 24px; margin-bottom: 24px; }
.widget-title { font-size: 1.1rem; margin-bottom: 1rem; }
.widget ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 980px) {
  .dk-hero__grid, .dk-basket { grid-template-columns: 1fr; }
  .dk-trust { grid-template-columns: 1fr 1fr; }
  .dk-footer__grid { grid-template-columns: 1fr 1fr; }
  .dk-page--sidebar .dk-page__layout { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  body { font-size: 16px; }
  .dk-burger { display: inline-flex; }
  /* El menú móvil (display:none / .is-open) se define más abajo en el bloque 720px
     como panel desplegable bajo la barra. No duplicar aquí para evitar conflictos. */
  .dk-nav ul { flex-direction: column; align-items: stretch; gap: 4px; }
  .dk-nav ul ul { position: static; box-shadow: none; border: none; padding-left: 16px; }
  .dk-nav li:hover > ul { display: flex; }
  .dk-trust { grid-template-columns: 1fr; }
  .dk-footer__grid { grid-template-columns: 1fr; }
  .dk-newsletter__form { flex-direction: column; }
}

/* Accesibilidad */
.screen-reader-text {
  position: absolute !important; width: 1px; height: 1px;
  overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap;
}
:focus-visible { outline: 3px solid var(--dk-clay); outline-offset: 2px; border-radius: 4px; }
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: 16px; top: 16px; background: var(--dk-charcoal); color: #fff; padding: 10px 16px; border-radius: 8px; z-index: 999; }

/* ==========================================================================
   COMERCIO â€” componentes orientados a venta
   ========================================================================== */

/* Badge de oferta circular en el hero */
.dk-hero__offer {
  position: absolute;
  top: 22px; right: 22px;
  width: 104px; height: 104px;
  border-radius: 50%;
  background: var(--dk-brand);
  color: #fff;
  display: grid; place-content: center; text-align: center;
  box-shadow: 0 12px 26px -10px rgba(224,127,31,.75);
  transform: rotate(-8deg);
  border: 3px solid #fff;
}
.dk-hero__offer strong { font-family: var(--dk-font-display); font-size: 1.9rem; line-height: 1; display: block; }
.dk-hero__offer span { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }

/* Mini-perks bajo los botones del hero */
.dk-hero__perks { list-style: none; display: flex; flex-wrap: wrap; gap: 18px; margin: 1.4rem 0 0; padding: 0; }
.dk-hero__perks li { display: flex; align-items: center; gap: 7px; font-size: .9rem; font-weight: 600; color: var(--dk-charcoal); }
.dk-hero__perks svg { width: 18px; height: 18px; color: var(--dk-sage-dark); }

/* Tira de ventajas con color (USP) */
.dk-usp {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.dk-usp__card {
  display: flex; align-items: center; gap: 14px;
  background: var(--dk-white); border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius); padding: 18px 20px;
}
.dk-usp__card svg { width: 26px; height: 26px; }
.dk-usp__ic { flex: 0 0 auto; width: 48px; height: 48px; border-radius: 14px; display: grid; place-items: center; }
.dk-usp__ic--brand { background: var(--dk-brand-soft); color: var(--dk-brand-dark); }
.dk-usp__ic--sage  { background: var(--dk-mint); color: var(--dk-sage-dark); }
.dk-usp__ic--clay  { background: #F4E2D7; color: var(--dk-clay); }
.dk-usp__ic--yellow{ background: #FCEFC7; color: #C9962B; }
.dk-usp__t { font-weight: 800; font-size: .98rem; display: block; }
.dk-usp__s { font-size: .82rem; color: var(--dk-muted); }

/* Cabecera de secciÃ³n con enlace "ver todo" */
.dk-shead {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 16px; margin-bottom: 2rem; flex-wrap: wrap;
}
.dk-shead h2 { margin: 0; }
.dk-shead .dk-eyebrow { margin-bottom: .3rem; }
.dk-shead__link { font-weight: 800; color: var(--dk-brand-dark); white-space: nowrap; }
.dk-shead__link:hover { color: var(--dk-brand); }

/* Chips de categorÃ­as (navegaciÃ³n rÃ¡pida de compra) */
.dk-chips { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 2.4rem; }
.dk-chips a {
  background: var(--dk-white); border: 1.5px solid var(--dk-line);
  color: var(--dk-charcoal); font-weight: 700; font-size: .92rem;
  padding: .55em 1.15em; border-radius: var(--dk-radius-pill);
  transition: all .2s var(--dk-ease);
}
.dk-chips a:hover { background: var(--dk-brand); border-color: var(--dk-brand); color: #fff; }

/* Banner promocional con color */
.dk-promo {
  border-radius: var(--dk-radius-lg);
  padding: clamp(32px, 5vw, 64px);
  display: grid; grid-template-columns: 1.2fr .8fr; align-items: center; gap: 32px;
  position: relative; overflow: hidden;
}
.dk-promo--brand { background: linear-gradient(120deg, #FBB04A 0%, #EF8C20 100%); color: #fff; }
.dk-promo--sage  { background: linear-gradient(120deg, #9DB191 0%, #6F8466 100%); color: #fff; }
.dk-promo h2 { color: #fff; }
.dk-promo p { color: rgba(255,255,255,.92); font-size: 1.1rem; max-width: 46ch; }
.dk-promo .dk-eyebrow { color: rgba(255,255,255,.9); }
.dk-promo__media { text-align: center; }
.dk-promo__media img { max-height: 230px; margin-inline: auto; filter: drop-shadow(0 18px 24px rgba(0,0,0,.18)); }
.dk-promo__big { font-family: var(--dk-font-display); font-size: clamp(3rem, 8vw, 5.5rem); line-height: .9; }

/* Secciones con tinte de color (rompen la neutralidad) */
.dk-section--brandsoft { background: var(--dk-brand-soft); }
.dk-section--mint { background: var(--dk-mint); }

/* Badge "mÃ¡s vendido" sobre tarjetas (lo usa tambiÃ©n content-product) */
.dk-tag-best {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  background: var(--dk-charcoal); color: #fff;
  font-size: .68rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase;
  padding: .35em .8em; border-radius: var(--dk-radius-pill);
}

/* GarantÃ­as mini bajo secciones de producto */
.dk-guarantee { display:flex; flex-wrap:wrap; justify-content:center; gap:28px; margin-top:2.5rem; color:var(--dk-muted); font-size:.9rem; font-weight:600; }
.dk-guarantee span { display:flex; align-items:center; gap:7px; }
.dk-guarantee svg { width:18px; height:18px; color:var(--dk-sage-dark); }

@media (max-width: 900px) {
  .dk-usp { grid-template-columns: 1fr 1fr; }
  .dk-promo { grid-template-columns: 1fr; text-align: center; }
  .dk-promo p { margin-inline: auto; }
  .dk-promo__media { display: none; }
}
@media (max-width: 560px) {
  .dk-usp { grid-template-columns: 1fr; }
  .dk-hero__offer { width: 86px; height: 86px; top: 14px; right: 14px; }
  .dk-hero__offer strong { font-size: 1.5rem; }
}

/* ==========================================================================
   ESTILO "JUGUETERÃA" â€” hero fotogrÃ¡fico, cupÃ³n, tiles de color, colecciones
   ========================================================================== */

/* --- Hero fotogrÃ¡fico a pantalla completa --- */
.dk-herobig {
  position: relative;
  min-height: clamp(440px, 64vh, 660px);
  display: flex; align-items: center;
  color: #fff; overflow: hidden;
  background-color: var(--dk-wood);
  background-size: cover; background-position: center;
}
.dk-herobig::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(40,32,24,.55) 0%, rgba(40,32,24,.28) 45%, rgba(40,32,24,.12) 100%);
}
.dk-herobig--center::before { background: rgba(40,32,24,.42); }
.dk-herobig .dk-wrap { position: relative; z-index: 2; width: 100%; }
.dk-herobig__inner { max-width: 620px; }
.dk-herobig--center .dk-herobig__inner { max-width: 760px; margin-inline: auto; text-align: center; }
.dk-herobig h1 {
  color: #fff; font-size: clamp(2.4rem, 6vw, 4.2rem);
  margin-bottom: .5rem; text-shadow: 0 2px 18px rgba(0,0,0,.3);
}
.dk-herobig p {
  color: rgba(255,255,255,.95); font-size: clamp(1.05rem, 2vw, 1.3rem);
  max-width: 50ch; margin-bottom: 1.8rem; text-shadow: 0 1px 10px rgba(0,0,0,.3);
}
.dk-herobig--center p { margin-inline: auto; }
.dk-herobig .dk-eyebrow { color: var(--dk-yellow); }
.dk-herobig__cta { display: flex; flex-wrap: wrap; gap: 14px; }
.dk-herobig--center .dk-herobig__cta { justify-content: center; }

/* --- Tira de cupÃ³n --- */
.dk-coupon { background: var(--dk-brand-soft); }
.dk-coupon .dk-wrap {
  display: flex; align-items: center; justify-content: center;
  gap: 18px; padding-block: 16px; flex-wrap: wrap; text-align: center;
}
.dk-coupon__txt { font-weight: 800; color: var(--dk-charcoal); }
.dk-coupon__box {
  display: inline-flex; align-items: center;
  border: 1.5px dashed var(--dk-brand); border-radius: var(--dk-radius-pill);
  background: #fff; overflow: hidden;
}
.dk-coupon__code {
  padding: .55em 1.2em; font-family: var(--dk-font-body);
  font-weight: 800; letter-spacing: .12em; color: var(--dk-brand-dark);
}
.dk-coupon__copy {
  border: none; background: var(--dk-brand); color: #fff;
  padding: .7em 1.3em; font-weight: 800; font-size: .85rem; cursor: pointer;
  transition: background .2s var(--dk-ease);
}
.dk-coupon__copy:hover { background: var(--dk-brand-dark); }
.dk-coupon__copy.is-copied { background: var(--dk-sage-dark); }

/* --- Tiles de categorÃ­a coloridos ("compra por edad") --- */
.dk-tiles { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; }
.dk-tile {
  display: block; border-radius: var(--dk-radius);
  overflow: hidden; box-shadow: var(--dk-shadow-sm);
  transition: transform .3s var(--dk-ease), box-shadow .3s var(--dk-ease);
}
.dk-tile:hover { transform: translateY(-6px); box-shadow: var(--dk-shadow); }
.dk-tile__top {
  background: var(--tile, var(--dk-brand));
  aspect-ratio: 1 / 1;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 16px; position: relative; gap: 6px;
}
.dk-tile__label {
  font-family: var(--dk-font-display); color: #fff; font-weight: 600;
  font-size: clamp(1.3rem, 2.6vw, 2.1rem); line-height: 1;
  text-shadow: 0 2px 10px rgba(0,0,0,.18); text-align: center;
}
.dk-tile__img { max-height: 50%; max-width: 78%; object-fit: contain; filter: drop-shadow(0 8px 12px rgba(0,0,0,.18)); }
.dk-tile__foot { background: #fff; padding: 14px 16px; }
.dk-tile__name { font-weight: 800; color: var(--dk-charcoal); display: block; }
.dk-tile__count { color: var(--dk-muted); font-size: .82rem; }

/* --- Bloques de colecciÃ³n (foto + panel inferior) --- */
.dk-collections { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.dk-coll {
  position: relative; border-radius: var(--dk-radius-lg); overflow: hidden;
  min-height: 420px; display: flex; align-items: flex-end;
  box-shadow: var(--dk-shadow-sm);
}
.dk-coll__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--dk-ease); }
.dk-coll:hover .dk-coll__img { transform: scale(1.05); }
.dk-coll__panel {
  position: relative; z-index: 2; width: 100%;
  margin: 16px; padding: 22px 24px;
  background: rgba(251,247,240,.96); border-radius: var(--dk-radius);
  backdrop-filter: blur(4px);
}
.dk-coll__panel h3 { margin: 0 0 .2rem; font-size: 1.5rem; }
.dk-coll__panel p { margin: 0 0 1rem; color: var(--dk-muted); font-size: .92rem; }
.dk-coll__panel .dk-btn { padding: .7em 1.5em; font-size: .9rem; }

@media (max-width: 900px) {
  .dk-tiles { grid-template-columns: repeat(3, 1fr); }
  .dk-collections { grid-template-columns: 1fr; }
  .dk-coll { min-height: 320px; }
}
@media (max-width: 560px) {
  .dk-tiles { grid-template-columns: 1fr 1fr; }
  .dk-coupon .dk-wrap { gap: 10px; }
}

/* ==========================================================================
   â–‘â–‘ DISEÃ‘O PASTEL DIVERKION (v2) â–‘â–‘
   Blanco + naranja + lila, tarjetas de colores suaves, redondeado y alegre.
   ========================================================================== */
body { background: var(--dk-cream); }

.dk-btn--purple { background: var(--dk-purple); box-shadow: 0 10px 22px -12px rgba(126,95,196,.8); }
.dk-btn--purple:hover { background: var(--dk-purple-dark); box-shadow: 0 14px 28px -12px rgba(126,95,196,.9); }
.dk-btn--outline {
  background: #fff; color: var(--dk-charcoal) !important;
  border: 1.5px solid var(--dk-line); box-shadow: none;
}
.dk-btn--outline:hover { background: var(--dk-oat); border-color: var(--dk-brand); color: var(--dk-brand-dark) !important; transform: translateY(-2px); }
.dk-btn--sm { padding: .65em 1.3em; font-size: .9rem; }

/* ---------- Cabecera v2 ---------- */
.dk-header { background: #fff; border-bottom: 1px solid var(--dk-line); }
.dk-header__inner { gap: 18px; min-height: 88px; }
.dk-logo { font-family: var(--dk-font-display); color: var(--dk-brand); font-weight: 600; gap: .35rem; }
.dk-logo__mark {
  font-weight: 700; color: var(--dk-brand); letter-spacing: .01em;
  display: inline-flex; flex-direction: column; align-items: center; line-height: .82;
}
.dk-logo__smile { width: 1.5em; height: .4em; margin-top: 1px; }
.dk-logo__word { color: var(--dk-brand); font-weight: 600; }
.dk-logo--img img { max-height: 56px; width: auto; }

/* Nav link colors set in .dk-menu a (dark nav: white text, brand on hover) */

/* Buscador en cabecera */
.dk-headsearch { flex: 1; max-width: 340px; margin-left: auto; }
.dk-headsearch form { display: flex; align-items: center; background: var(--dk-oat); border: 1.5px solid var(--dk-line); border-radius: var(--dk-radius-pill); overflow: hidden; }
.dk-headsearch input[type="search"] {
  flex: 1; border: none; background: transparent; padding: .7em 1.1em;
  font-family: var(--dk-font-body); font-size: .92rem; color: var(--dk-charcoal);
}
.dk-headsearch input:focus { outline: none; }
.dk-headsearch button { border: none; background: var(--dk-brand); color: #fff; width: 42px; height: 42px; margin: 3px; border-radius: 50%; display: grid; place-items: center; cursor: pointer; flex: 0 0 auto; }
.dk-headsearch button:hover { background: var(--dk-brand-dark); }
.dk-headsearch button svg { width: 18px; height: 18px; }

.dk-actions { display: flex; align-items: center; gap: 6px; }
.dk-action { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 6px 10px; border-radius: 14px; color: var(--dk-charcoal); position: relative; font-size: .68rem; font-weight: 700; }
.dk-action:hover { background: var(--dk-brand-soft); color: var(--dk-brand-dark); }
.dk-action svg { width: 22px; height: 22px; }
.dk-action__badge { position: absolute; top: 0; right: 4px; background: var(--dk-brand); color: #fff; font-size: .62rem; min-width: 17px; height: 17px; border-radius: 50%; display: grid; place-items: center; font-weight: 800; }
.dk-action--fav .dk-action__badge { background: var(--dk-purple); }

/* ---------- Hero v2 ---------- */
.dk-hero2 { position: relative; overflow: hidden; background:
  radial-gradient(60% 70% at 88% 12%, var(--dk-pastel-yellow) 0%, transparent 60%),
  radial-gradient(50% 60% at 4% 90%, var(--dk-pastel-peach) 0%, transparent 60%),
  #fff; }
.dk-hero2__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 40px; align-items: center; padding-block: clamp(36px, 5vw, 70px) clamp(70px, 8vw, 120px); }
.dk-hero2__star { color: var(--dk-brand); margin-bottom: .6rem; display: inline-block; }
.dk-hero2 h1 { font-size: clamp(2.4rem, 5.2vw, 4rem); line-height: 1.05; margin-bottom: .8rem; }
.dk-hero2 h1 .alt { color: var(--dk-purple); }
.dk-hero2__lead { font-size: 1.2rem; color: var(--dk-muted); max-width: 40ch; margin-bottom: 1.8rem; }
.dk-hero2__cta { display: flex; flex-wrap: wrap; gap: 14px; }
.dk-hero2__media { position: relative; }
.dk-hero2__photo { border-radius: 30px; aspect-ratio: 4/3.3; object-fit: cover; width: 100%; background: var(--dk-pastel-blue); box-shadow: var(--dk-shadow); }
.dk-hero2__bubble {
  position: absolute; top: 18px; right: -8px; background: var(--dk-pastel-pink);
  color: var(--dk-purple-dark); border-radius: 22px 22px 22px 6px; padding: 14px 18px;
  font-weight: 800; max-width: 190px; box-shadow: var(--dk-shadow-sm); font-size: .95rem; line-height: 1.2;
}
.dk-hero2__bubble small { display: block; font-weight: 600; color: var(--dk-charcoal); font-size: .78rem; margin-top: 2px; }
/* burbujas decorativas */
.dk-blob { position: absolute; border-radius: 50%; filter: blur(2px); opacity: .8; z-index: 0; pointer-events: none; }

/* Tarjeta de confianza superpuesta */
.dk-trustcard {
  position: relative; z-index: 3; margin-top: -54px; margin-bottom: 10px;
  background: #fff; border: 1px solid var(--dk-line); border-radius: 22px;
  box-shadow: var(--dk-shadow); padding: 22px clamp(20px, 4vw, 40px);
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
}
.dk-trustcard__item { display: flex; align-items: center; gap: 12px; }
.dk-trustcard__ic { flex: 0 0 auto; width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; }
.dk-trustcard__ic svg { width: 24px; height: 24px; }
.dk-trustcard__t { font-weight: 800; font-size: .95rem; display: block; line-height: 1.2; }
.dk-trustcard__s { font-size: .8rem; color: var(--dk-muted); }

/* Utilidades de color pastel para iconos */
.dk-ic-peach { background: var(--dk-pastel-peach); color: var(--dk-brand-dark); }
.dk-ic-mint  { background: var(--dk-pastel-mint); color: var(--dk-sage-dark); }
.dk-ic-lilac { background: var(--dk-pastel-lilac); color: var(--dk-purple-dark); }
.dk-ic-blue  { background: var(--dk-pastel-blue); color: #4f86c6; }
.dk-ic-pink  { background: var(--dk-pastel-pink); color: #d46a93; }
.dk-ic-yellow{ background: var(--dk-pastel-yellow); color: #c9962b; }

/* ---------- Tarjetas de categorÃ­a pastel ---------- */
.dk-ptiles { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.dk-ptile { text-align: center; transition: transform .3s var(--dk-ease); }
.dk-ptile:hover { transform: translateY(-6px); }
.dk-ptile__box {
  background: var(--ptile, var(--dk-pastel-peach)); border-radius: 22px;
  aspect-ratio: 1/1; display: grid; place-items: center; padding: 18px; margin-bottom: 12px;
  box-shadow: 0 10px 22px -16px rgba(59,58,74,.5);
}
.dk-ptile__box img { max-height: 78%; max-width: 82%; object-fit: contain; filter: drop-shadow(0 6px 8px rgba(0,0,0,.12)); }
.dk-ptile__name { font-family: var(--dk-font-display); font-weight: 600; font-size: 1.05rem; color: var(--dk-charcoal); }

/* ---------- SecciÃ³n destacada: productos + banners ---------- */
.dk-feature { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.dk-feature__promo { grid-column: span 2; }
.dk-h-icon { display: flex; align-items: center; gap: 10px; margin-bottom: 1.6rem; }
.dk-h-icon h2 { margin: 0; }
.dk-h-icon svg { width: 26px; height: 26px; color: var(--dk-purple); }

/* Tarjeta de producto v2 */
.dk-pcard { background: #fff; border: 1px solid var(--dk-line); border-radius: 20px; padding: 14px; position: relative; display: flex; flex-direction: column; transition: transform .25s var(--dk-ease), box-shadow .25s var(--dk-ease); }
.dk-pcard:hover { transform: translateY(-6px); box-shadow: var(--dk-shadow); }
.dk-pcard__media { border-radius: 14px; background: var(--dk-pastel-peach); aspect-ratio: 1/1; display: grid; place-items: center; overflow: hidden; margin-bottom: 12px; }
.dk-pcard__media img { width: 100%; height: 100%; object-fit: cover; }
.dk-pcard__tag { position: absolute; top: 16px; left: 16px; z-index: 2; font-size: .68rem; font-weight: 800; padding: .35em .8em; border-radius: var(--dk-radius-pill); color: #fff; }
.dk-tag-new { background: var(--dk-sage-dark); }
.dk-tag-top { background: var(--dk-brand); }
.dk-tag-off { background: var(--dk-sale); }
.dk-pcard__fav { position: absolute; top: 14px; right: 14px; z-index: 2; width: 34px; height: 34px; border-radius: 50%; background: rgba(255,255,255,.92); border: 1px solid var(--dk-line); display: grid; place-items: center; color: var(--dk-muted); cursor: pointer; }
.dk-pcard__fav:hover { color: var(--dk-purple); }
.dk-pcard__fav svg { width: 17px; height: 17px; }
.dk-pcard__name { font-family: var(--dk-font-display); font-weight: 600; font-size: 1.08rem; margin: 0 2px 4px; }
.dk-pcard__price { font-weight: 800; color: var(--dk-charcoal); font-size: 1.1rem; margin-bottom: 6px; }
.dk-pcard__price del { color: var(--dk-muted); font-weight: 500; opacity: .7; margin-left: 6px; font-size: .9rem; }
.dk-pcard__rating { display: flex; align-items: center; gap: 6px; font-size: .8rem; color: var(--dk-muted); margin-top: auto; }
.dk-pcard__stars { color: var(--dk-brand); letter-spacing: 1px; }

/* Banners promocionales pastel */
.dk-pbanner { border-radius: 24px; padding: 28px; position: relative; overflow: hidden; display: flex; flex-direction: column; min-height: 220px; }
.dk-pbanner h3 { font-size: 1.6rem; line-height: 1.05; margin-bottom: .4rem; }
.dk-pbanner p { font-size: .92rem; margin-bottom: 1.1rem; max-width: 24ch; }
.dk-pbanner .dk-btn { align-self: flex-start; }
.dk-pbanner__art { position: absolute; right: 14px; bottom: 14px; font-size: 4.4rem; opacity: .9; }
.dk-pbanner--blue { background: var(--dk-pastel-blue); }
.dk-pbanner--blue h3 { color: var(--dk-purple-dark); }
.dk-pbanner--cream { background: var(--dk-pastel-yellow); }
.dk-pbanner--cream h3 { color: var(--dk-brand-dark); }

/* ---------- Testimonios v2 ---------- */
.dk-testi { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.dk-testi__card { background: #fff; border: 1px solid var(--dk-line); border-radius: 20px; padding: 24px; }
.dk-testi__head { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.dk-testi__avatar { width: 50px; height: 50px; border-radius: 50%; object-fit: cover; background: var(--dk-pastel-lilac); }
.dk-testi__name { font-weight: 800; font-size: .95rem; }
.dk-testi__stars { color: var(--dk-brand); font-size: .82rem; letter-spacing: 1px; }
.dk-testi__card p { font-size: .95rem; color: var(--dk-charcoal); margin: 0; }

/* ---------- Newsletter lila ---------- */
.dk-nl { background: var(--dk-purple-soft); border-radius: 28px; padding: clamp(28px, 5vw, 52px); display: grid; grid-template-columns: 1.1fr 1fr; gap: 30px; align-items: center; position: relative; overflow: hidden; }
.dk-nl h2 { color: var(--dk-purple-dark); margin-bottom: .4rem; }
.dk-nl p { color: var(--dk-charcoal); margin: 0; opacity: .85; }
.dk-nl form { display: flex; gap: 10px; }
.dk-nl input[type="email"] { flex: 1; border: 1.5px solid #fff; background: #fff; border-radius: var(--dk-radius-pill); padding: .9em 1.3em; font-family: var(--dk-font-body); }
.dk-nl input:focus { outline: none; border-color: var(--dk-purple); }

/* ---------- Barra de garantÃ­as (sobre el footer) ---------- */
.dk-trustbar { background: var(--dk-purple-soft); }
.dk-trustbar .dk-wrap { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; padding-block: 26px; }
.dk-trustbar__item { display: flex; align-items: center; gap: 12px; }
.dk-trustbar__ic { flex: 0 0 auto; width: 42px; height: 42px; border-radius: 12px; background: #fff; display: grid; place-items: center; color: var(--dk-purple-dark); }
.dk-trustbar__ic svg { width: 22px; height: 22px; }
.dk-trustbar__t { font-weight: 800; font-size: .92rem; display: block; }
.dk-trustbar__s { font-size: .8rem; color: var(--dk-muted); }

/* ---------- Footer v2 ---------- */
.dk-footer { background: #fff; color: var(--dk-muted); border-top: 1px solid var(--dk-line); }
.dk-footer a { color: var(--dk-muted); }
.dk-footer a:hover { color: var(--dk-brand-dark); }
.dk-footer h4 { color: var(--dk-charcoal); }
.dk-footer__grid { border-bottom: 1px solid var(--dk-line); grid-template-columns: 1.6fr repeat(4, 1fr); }
.dk-footer__brand .dk-logo { color: var(--dk-brand); }
/* Logo-imagen en el pie (custom logo o logo.png): mismo trato que el de texto */
.dk-footer__brand .custom-logo-link,
.dk-footer__brand .dk-logo--img { display: inline-block; margin-bottom: 1rem; }
.dk-footer__brand .custom-logo-link img,
.dk-footer__brand .dk-logo--img img { max-height: 52px; width: auto; }
.dk-footer__social a { background: var(--dk-oat); color: var(--dk-charcoal); }
.dk-footer__social a:hover { background: var(--dk-brand); color: #fff; }
.dk-footer__bottom { color: var(--dk-muted); }
.dk-footer__tagline { background: var(--dk-pastel-yellow); border-radius: 20px; padding: 22px 26px; display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 30px; }
.dk-footer__tagline strong { font-family: var(--dk-font-display); font-weight: 600; color: var(--dk-charcoal); font-size: 1.2rem; }
.dk-footer__tagline .art { font-size: 2.4rem; }

/* ==========================================================================
   Responsive â€” Header dos filas
   ========================================================================== */
@media (max-width: 980px) {
  .dk-header-branding__inner {
    grid-template-columns: auto 1fr auto auto;
    gap: 14px;
  }
  .dk-menu a { padding: 12px 10px; font-size: 0.87rem; }
  .dk-trustbar .dk-wrap { grid-template-columns: 1fr 1fr; }
  .dk-footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 720px) {
  /* Header: ocultar texto de acciones, mostrar solo iconos */
  .dk-action span { display: none; }
  .dk-action { padding: 6px 8px; }
  /* BÃºsqueda: reducir */
  .dk-header-search input[type="search"] { font-size: 0.88rem; padding: 9px 12px; }
  /* Nav: burger */
  .dk-header-nav__inner { justify-content: space-between; }
  .dk-burger { display: inline-flex !important; }
  /* Anclar el panel relativo a la barra sticky */
  .dk-header-nav { position: sticky; }
  .dk-nav { display: none; }
  .dk-nav.is-open {
    display: block;
    position: absolute;
    top: 100%;            /* justo debajo de la barra, sea cual sea su alto */
    left: 0; right: 0; bottom: auto;   /* bottom:auto anula cualquier inset heredado */
    background: var(--dk-charcoal);
    z-index: 300;
    padding: 8px 0 16px;
    margin: 0;
    box-shadow: 0 14px 26px -14px rgba(0,0,0,.45);
    max-height: calc(100vh - 50px);
    overflow-y: auto;
  }
  .dk-nav.is-open .dk-menu { flex-direction: column; align-items: flex-start; gap: 0; width: 100%; }
  .dk-nav.is-open .dk-menu a { width: 100%; padding: 13px 20px; }
  /* Submenús dentro del panel: en bloque, sin posicionar */
  .dk-nav.is-open .dk-menu ul { position: static; display: block; box-shadow: none; border: none; background: transparent; padding-left: 16px; }
  .dk-trustbar .dk-wrap { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  .dk-header-branding__inner { grid-template-columns: auto auto auto; gap: 10px; }
  .dk-header-search { display: none; }
  .dk-footer__grid { grid-template-columns: 1fr; }
  .dk-footer__tagline { flex-direction: column; text-align: center; }
  .dk-hero2__grid { grid-template-columns: 1fr; }
  .dk-feature, .dk-feature__promo { grid-template-columns: 1fr; grid-column: auto; }
}

/* ==========================================================================
   PORTADA â€” Hero banner de imagen completa
   ========================================================================== */
.dk-hero-banner {
  position: relative;
  min-height: 480px;
  background: var(--dk-pastel-peach) center/cover no-repeat;
  display: flex;
  align-items: center;
}
.dk-hero-banner__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(59,58,74,0.55) 0%, rgba(59,58,74,0.15) 70%, transparent 100%);
}
.dk-hero-banner__inner {
  position: relative;
  z-index: 1;
  padding-block: 80px;
}
.dk-hero-banner__content { max-width: 580px; color: #fff; }
.dk-hero-banner__content h1 {
  color: #fff;
  font-size: clamp(2.2rem,5vw,3.8rem);
  margin-bottom: 0.6em;
  text-shadow: 0 2px 16px rgba(0,0,0,0.22);
}
.dk-hero-banner__content p {
  font-size: 1.12rem;
  opacity: 0.93;
  margin-bottom: 1.8em;
  text-shadow: 0 1px 8px rgba(0,0,0,0.18);
}
.dk-hero-banner__content .dk-btn { font-size: 1.05rem; padding: 1em 2.2em; }

/* ==========================================================================
   PORTADA â€” Banner promocional Packs
   ========================================================================== */
.dk-promo-banner {
  position: relative;
  min-height: 320px;
  background: linear-gradient(135deg, var(--dk-purple-soft) 0%, var(--dk-pastel-blue) 100%) center/cover no-repeat;
  display: flex;
  align-items: center;
}
.dk-promo-banner__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(59,58,74,0.48) 0%, rgba(59,58,74,0.10) 70%, transparent 100%);
}
.dk-promo-banner__inner { position: relative; z-index: 1; padding-block: 60px; }
.dk-promo-banner__content { max-width: 560px; color: #fff; }
.dk-promo-banner__content h2 {
  color: #fff;
  font-size: clamp(1.8rem,3.8vw,3rem);
  margin-bottom: 0.5em;
  text-shadow: 0 2px 12px rgba(0,0,0,0.2);
}
.dk-promo-banner__content p {
  opacity: 0.92;
  margin-bottom: 1.6em;
  font-size: 1.05rem;
  text-shadow: 0 1px 8px rgba(0,0,0,0.15);
}
.dk-promo-banner .dk-btn--outline,
.dk-hero-banner .dk-btn--outline {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,0.85);
  box-shadow: none;
}
.dk-promo-banner .dk-btn--outline:hover,
.dk-hero-banner .dk-btn--outline:hover {
  background: rgba(255,255,255,0.18) !important;
  border-color: #fff;
  transform: translateY(-2px);
}

/* ==========================================================================
   PORTADA â€” Secciones de productos (MÃ¡s vendidos / Ãšltimos)
   ========================================================================== */
.dk-products-section { padding-block: 56px; }
.dk-products-section + .dk-products-section { background: var(--dk-oat); }

.dk-products-section .dk-section__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: none;
  margin-bottom: 2rem;
}
.dk-products-section .dk-section__head h2 { font-size: clamp(1.5rem,3vw,2.2rem); margin: 0; }

.dk-products-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

/* Tarjeta de producto */
.dk-pcard {
  position: relative;
  background: var(--dk-white);
  border-radius: var(--dk-radius);
  box-shadow: var(--dk-shadow-sm);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s var(--dk-ease), box-shadow 0.3s var(--dk-ease);
}
.dk-pcard:hover { transform: translateY(-4px); box-shadow: 0 18px 40px -18px rgba(62,58,52,0.3); }

.dk-pcard__tag {
  position: absolute;
  top: 12px; left: 12px;
  z-index: 2;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--dk-radius-pill);
}
.dk-tag-top { background: var(--dk-brand-soft); color: var(--dk-brand-dark); }
.dk-tag-new { background: var(--dk-pastel-mint); color: #3a8a5a; }
.dk-tag-off { background: #FDE8E4; color: var(--dk-sale); }

.dk-pcard__media-link { display: block; text-decoration: none; }
.dk-pcard__media {
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--dk-oat);
  display: flex;
  align-items: center;
  justify-content: center;
}
.dk-pcard__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.4s var(--dk-ease);
}
.dk-pcard:hover .dk-pcard__media img { transform: scale(1.04); }

.dk-pcard__body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.dk-pcard__name {
  font-family: var(--dk-font-display);
  font-weight: 600;
  font-size: 1rem;
  color: var(--dk-charcoal);
  text-decoration: none;
  line-height: 1.3;
}
.dk-pcard__name:hover { color: var(--dk-brand-dark); }
.dk-pcard__price { font-weight: 800; font-size: 1.05rem; color: var(--dk-charcoal); }
.dk-pcard__price del { color: var(--dk-muted); font-weight: 400; margin-left: 4px; font-size: 0.88rem; }
.dk-pcard__rating { display: flex; align-items: center; gap: 4px; font-size: 0.82rem; color: var(--dk-muted); }
.dk-pcard__stars { color: var(--dk-brand); letter-spacing: -1px; }
.dk-pcard__add {
  margin-top: auto !important;
  padding: 0.65em 1.3em !important;
  font-size: 0.88rem !important;
  width: 100%;
  text-align: center;
}

/* ==========================================================================
   Selector de idioma
   ========================================================================== */
.dk-lang-switcher {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-right: 8px;
}
.dk-lang-link {
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  padding: 5px 9px;
  border-radius: var(--dk-radius-pill);
  color: var(--dk-muted);
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
  line-height: 1;
}
.dk-lang-link:hover { background: var(--dk-oat); color: var(--dk-charcoal); }
.dk-lang--active { background: var(--dk-brand-soft); color: var(--dk-brand-dark) !important; }
@media (max-width: 600px) { .dk-lang-switcher { margin-right: 4px; } }

/* Ocultar el widget flotante de TranslatePress (usamos el del header) */
.trp-floating-ls-container,
.trp-float-ls-container,
#trp-float-ls,
.trp-floated-ls-container,
[id^="trp-float"],
[class*="trp-float-ls"] { display: none !important; }

/* ==========================================================================
   Página "Sobre nosotros / Nuestra historia"
   ========================================================================== */
.dk-about-hero__title {
  font-family: var(--dk-font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  margin: .3rem 0 1rem;
}
.dk-about-hero__lead {
  max-width: 60ch;
  margin-inline: auto;
  color: var(--dk-muted);
  font-size: 1.1rem;
  line-height: 1.6;
}
.dk-about-story { max-width: 760px; margin-inline: auto; }
.dk-about-story h2 {
  font-family: var(--dk-font-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  margin: .3rem 0 1rem;
}
.dk-about-story p { color: var(--dk-charcoal); line-height: 1.75; margin-bottom: 1rem; }
.dk-about-values {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.dk-about-value {
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 28px 22px;
  text-align: center;
}
.dk-about-value__ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--dk-brand-soft);
  color: var(--dk-brand-dark);
  margin-bottom: 14px;
}
.dk-about-value h3 { font-size: 1.05rem; margin-bottom: .5rem; }
.dk-about-value p { color: var(--dk-muted); font-size: .92rem; line-height: 1.55; margin: 0; }
.dk-about-cta { text-align: center; }
.dk-about-cta h2 {
  font-family: var(--dk-font-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  margin-bottom: .8rem;
}
.dk-about-cta p { max-width: 56ch; margin: 0 auto 1.4rem; color: var(--dk-muted); line-height: 1.6; }
.dk-about-content { max-width: 760px; margin-inline: auto; }
@media (max-width: 900px) { .dk-about-values { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .dk-about-values { grid-template-columns: 1fr; } }

/* ==========================================================================
   Páginas de información (FAQ, envíos, devoluciones, pagos)
   ========================================================================== */
.dk-page-hero { text-align: center; }
.dk-page-hero__title {
  font-family: var(--dk-font-display);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  margin: .3rem 0 .8rem;
}
.dk-page-hero__lead {
  max-width: 60ch;
  margin-inline: auto;
  color: var(--dk-muted);
  font-size: 1.05rem;
  line-height: 1.6;
}
.dk-info-body { max-width: 760px; margin-inline: auto; }
.dk-info-block { margin-bottom: 2rem; }
.dk-info-block:last-child { margin-bottom: 0; }
.dk-info-block h2 {
  font-family: var(--dk-font-display);
  font-size: 1.3rem;
  margin-bottom: .6rem;
}
.dk-info-block p,
.dk-info-block li { color: var(--dk-charcoal); line-height: 1.75; }

/* FAQ — acordeón nativo <details> (sin JS) */
.dk-faq { max-width: 760px; margin-inline: auto; display: flex; flex-direction: column; gap: 12px; }
.dk-faq__item {
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  background: var(--dk-white);
  overflow: hidden;
}
.dk-faq__item summary {
  cursor: pointer;
  padding: 18px 22px;
  font-weight: 700;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  color: var(--dk-charcoal);
}
.dk-faq__item summary::-webkit-details-marker { display: none; }
.dk-faq__item summary::after {
  content: "+";
  font-size: 1.4rem;
  line-height: 1;
  color: var(--dk-brand-dark);
  flex: 0 0 auto;
}
.dk-faq__item[open] summary::after { content: "\2212"; } /* − */
.dk-faq__item .dk-faq__a { padding: 0 22px 18px; color: var(--dk-muted); line-height: 1.75; }

/* Métodos de pago */
.dk-pay-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  max-width: 760px;
  margin-inline: auto;
}
.dk-pay-card {
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  background: var(--dk-white);
  padding: 22px;
}
.dk-pay-card h3 { font-size: 1.05rem; margin-bottom: .4rem; }
.dk-pay-card p { color: var(--dk-muted); font-size: .92rem; line-height: 1.55; margin: 0; }
.dk-pay-note { max-width: 760px; margin: 1.6rem auto 0; color: var(--dk-muted); font-size: .92rem; }
@media (max-width: 600px) { .dk-pay-grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   Página de Contacto
   ========================================================================== */
.dk-contact {
  display: grid;
  grid-template-columns: 1fr 1.25fr;
  gap: 48px;
  align-items: start;
  max-width: 1000px;
  margin-inline: auto;
}
.dk-contact__intro h2 { font-family: var(--dk-font-display); font-size: 1.5rem; margin-bottom: .6rem; }
.dk-contact__intro p { color: var(--dk-muted); line-height: 1.7; margin-bottom: 1.2rem; }
.dk-contact__email {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: var(--dk-brand-dark);
  word-break: break-all;
}
.dk-contact__email:hover { color: var(--dk-brand); }
.dk-contact__form {
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 28px;
}
.dk-field { margin-bottom: 1.1rem; }
.dk-field label { display: block; font-weight: 700; font-size: .9rem; margin-bottom: .45rem; color: var(--dk-charcoal); }
.dk-field .req { color: var(--dk-sale); }
.dk-field input,
.dk-field textarea {
  width: 100%;
  border: 1.5px solid var(--dk-line);
  border-radius: var(--dk-radius-pill);
  padding: .8em 1.1em;
  font-family: var(--dk-font-body);
  font-size: 1rem;
  background: var(--dk-white);
  box-sizing: border-box;
}
.dk-field textarea { border-radius: var(--dk-radius); min-height: 140px; resize: vertical; }
.dk-field input:focus,
.dk-field textarea:focus { outline: none; border-color: var(--dk-brand); }
.dk-contact__form .dk-btn { width: 100%; justify-content: center; }
/* Honeypot oculto */
.dk-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
/* Avisos del formulario */
.dk-formmsg { border-radius: var(--dk-radius-sm); padding: 14px 18px; margin-bottom: 1.2rem; font-size: .95rem; line-height: 1.5; }
.dk-formmsg--ok { background: #F0FAF4; color: #2f7a52; border: 1px solid #bfe6d0; }
.dk-formmsg--err { background: #FEF2F0; color: #b5453a; border: 1px solid #f3cfc9; }
.dk-formmsg ul { margin: .4rem 0 0; padding-left: 1.1rem; }
@media (max-width: 820px) { .dk-contact { grid-template-columns: 1fr; gap: 28px; } }

/* ==========================================================================
   Formularios genéricos en páginas (registro, contacto, etc.)
   ========================================================================== */
/* Campos de texto */
.dk-article form:not(.woocommerce-form) input[type="text"],
.dk-article form:not(.woocommerce-form) input[type="email"],
.dk-article form:not(.woocommerce-form) input[type="password"],
.dk-article form:not(.woocommerce-form) input[type="url"],
.dk-article form:not(.woocommerce-form) input[type="number"],
.dk-article form:not(.woocommerce-form) textarea,
.dk-article form:not(.woocommerce-form) select {
  width: 100%;
  padding: .75em 1em;
  border: 1.5px solid var(--dk-line);
  border-radius: var(--dk-radius-sm);
  font-family: var(--dk-font-body);
  font-size: .95rem;
  color: var(--dk-charcoal);
  background: var(--dk-white);
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
}
.dk-article form:not(.woocommerce-form) input[type="text"]:focus,
.dk-article form:not(.woocommerce-form) input[type="email"]:focus,
.dk-article form:not(.woocommerce-form) input[type="password"]:focus,
.dk-article form:not(.woocommerce-form) textarea:focus {
  outline: none;
  border-color: var(--dk-brand);
  box-shadow: 0 0 0 3px var(--dk-brand-soft);
}
.dk-article form:not(.woocommerce-form) label {
  display: block;
  font-size: .88rem;
  font-weight: 600;
  color: var(--dk-charcoal);
  margin-bottom: .4em;
}
/* Botón de envío — formularios genéricos y CF7 */
.dk-article form input[type="submit"],
.dk-article form button[type="submit"],
.wpcf7-form .wpcf7-submit,
.wpcf7 input[type="submit"] {
  background: var(--dk-brand) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--dk-radius-pill) !important;
  padding: .9em 2.4em !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  font-family: var(--dk-font-body) !important;
  cursor: pointer !important;
  transition: background .2s, transform .2s !important;
  letter-spacing: .02em;
  display: inline-block;
  text-decoration: none;
}
.dk-article form input[type="submit"]:hover,
.dk-article form button[type="submit"]:hover,
.wpcf7-form .wpcf7-submit:hover,
.wpcf7 input[type="submit"]:hover {
  background: var(--dk-brand-dark) !important;
  transform: translateY(-1px);
}

/* ==========================================================================
   Responsive — portada
   ========================================================================== */
@media (max-width: 900px) {
  .dk-products-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .dk-products-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .dk-hero-banner { min-height: 340px; }
  .dk-promo-banner { min-height: 240px; }
  .dk-hero-banner__content h1 { font-size: 1.9rem; }
}

/* ==========================================================================
   ARTÃCULO â€” TipografÃ­a del contenido (entry-content)
   ========================================================================== */
.dk-article .entry-content,
.dk-content .entry-content {
  max-width: 72ch;
}
.dk-article .entry-content h1,
.dk-article .entry-content h2,
.dk-article .entry-content h3,
.dk-article .entry-content h4,
.dk-article .entry-content h5,
.dk-article .entry-content h6 {
  margin-top: 1.8em;
  margin-bottom: 0.5em;
  line-height: 1.25;
}
.dk-article .entry-content h2 { font-size: clamp(1.4rem, 2.8vw, 1.9rem); }
.dk-article .entry-content h3 { font-size: 1.25rem; }
.dk-article .entry-content p { margin-bottom: 1.3em; line-height: 1.75; }
.dk-article .entry-content ul,
.dk-article .entry-content ol {
  padding-left: 1.5em;
  margin-bottom: 1.3em;
  display: grid;
  gap: 6px;
}
.dk-article .entry-content li { line-height: 1.65; }
.dk-article .entry-content a { color: var(--dk-brand-dark); font-weight: 600; text-decoration: underline; text-underline-offset: 3px; }
.dk-article .entry-content a:hover { color: var(--dk-brand); }
.dk-article .entry-content img {
  border-radius: var(--dk-radius-sm);
  margin-block: 1.5em;
  max-width: 100%;
}
.dk-article .entry-content figure { margin: 1.5em 0; }
.dk-article .entry-content figcaption { font-size: .85rem; color: var(--dk-muted); text-align: center; margin-top: .4em; }
.dk-article .entry-content blockquote {
  border-left: 4px solid var(--dk-brand);
  background: var(--dk-brand-soft);
  border-radius: 0 var(--dk-radius-sm) var(--dk-radius-sm) 0;
  padding: 1em 1.4em;
  margin: 1.5em 0;
  font-style: italic;
  color: var(--dk-charcoal);
}
.dk-article .entry-content blockquote p { margin: 0; }
.dk-article .entry-content code {
  background: var(--dk-oat);
  border-radius: 5px;
  padding: .2em .45em;
  font-size: .9em;
  color: var(--dk-brand-dark);
  font-family: "Courier New", Courier, monospace;
}
.dk-article .entry-content pre {
  background: var(--dk-charcoal);
  color: var(--dk-cream);
  border-radius: var(--dk-radius-sm);
  padding: 1.2em 1.4em;
  overflow-x: auto;
  margin: 1.5em 0;
}
.dk-article .entry-content pre code { background: none; color: inherit; padding: 0; }
.dk-article .entry-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5em 0;
  font-size: .95rem;
}
.dk-article .entry-content th { background: var(--dk-oat); font-weight: 700; }
.dk-article .entry-content th,
.dk-article .entry-content td {
  border: 1px solid var(--dk-line);
  padding: .65em .9em;
  text-align: left;
}
.dk-article .entry-content tr:nth-child(even) td { background: #fafafa; }
.dk-article .entry-content hr {
  border: none;
  border-top: 1px solid var(--dk-line);
  margin: 2em 0;
}

/* Meta del artÃ­culo */
.dk-post-meta,
.dk-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  color: var(--dk-muted);
  font-size: .88rem;
  font-weight: 600;
  margin-bottom: 1.4rem;
}
.dk-post-meta a { color: var(--dk-muted); }
.dk-post-meta a:hover { color: var(--dk-brand-dark); }

/* Imagen destacada del artÃ­culo */
.dk-article__thumb img { width: 100%; height: auto; aspect-ratio: 16/7; object-fit: cover; }

/* Etiquetas del artÃ­culo */
.dk-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 1.4rem;
}
.dk-tags a {
  background: var(--dk-oat);
  border: 1px solid var(--dk-line);
  color: var(--dk-charcoal);
  font-size: .82rem;
  font-weight: 700;
  padding: .4em .9em;
  border-radius: var(--dk-radius-pill);
  text-decoration: none;
  transition: background .2s, border-color .2s;
}
.dk-tags a:hover { background: var(--dk-brand-soft); border-color: var(--dk-brand); color: var(--dk-brand-dark); }

/* NavegaciÃ³n anterior/siguiente */
.post-navigation,
.nav-links {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 2.4rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--dk-line);
}
.post-navigation .nav-previous,
.post-navigation .nav-next,
.nav-links .nav-previous,
.nav-links .nav-next {
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: box-shadow .2s;
}
.post-navigation .nav-previous:hover,
.post-navigation .nav-next:hover,
.nav-links .nav-previous:hover,
.nav-links .nav-next:hover { box-shadow: var(--dk-shadow-sm); }
.post-navigation .nav-next { text-align: right; }
.post-navigation a,
.nav-links a {
  font-weight: 700;
  color: var(--dk-charcoal);
  font-size: .95rem;
  text-decoration: none;
}
.post-navigation a:hover,
.nav-links a:hover { color: var(--dk-brand-dark); }

/* DescripciÃ³n de categorÃ­a/archivo */
.dk-archive-desc {
  color: var(--dk-muted);
  max-width: 60ch;
  font-size: 1rem;
  margin-top: .6rem;
}

/* ==========================================================================
   COMENTARIOS
   ========================================================================== */
.dk-comments { margin-top: 2.8rem; padding-top: 2rem; border-top: 1px solid var(--dk-line); }
.dk-comments h2 { margin-bottom: 1.6rem; font-size: 1.6rem; }

.comment-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 20px; }
.comment-list .children { list-style: none; padding-left: 48px; display: grid; gap: 16px; margin-top: 16px; }
.comment-body {
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 22px;
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 16px;
  align-items: start;
}
.comment-body .avatar { border-radius: 50%; width: 48px; height: 48px; }
.comment-author .fn { font-weight: 700; color: var(--dk-charcoal); }
.comment-meta { font-size: .82rem; color: var(--dk-muted); margin-bottom: .5rem; }
.comment-content p { margin: 0 0 .8em; font-size: .95rem; }
.comment-reply-link {
  font-size: .82rem; font-weight: 700; color: var(--dk-brand-dark);
}
.comment-reply-link:hover { color: var(--dk-brand); }

/* Formulario de comentario */
.comment-respond { margin-top: 2rem; }
.comment-respond h3 { font-size: 1.35rem; margin-bottom: 1.2rem; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  border: 1.5px solid var(--dk-line);
  border-radius: var(--dk-radius-sm);
  padding: .8em 1em;
  font-family: var(--dk-font-body);
  font-size: .97rem;
  background: var(--dk-white);
  transition: border-color .2s;
}
.comment-form input:focus,
.comment-form textarea:focus { outline: none; border-color: var(--dk-brand); }
.comment-form textarea { min-height: 120px; }
.comment-form-cookies-consent { display: flex; align-items: center; gap: 8px; font-size: .88rem; }
.comment-form .submit {
  background: var(--dk-brand);
  color: #fff;
  border: none;
  border-radius: var(--dk-radius-pill);
  padding: .9em 2em;
  font-family: var(--dk-font-body);
  font-weight: 700;
  cursor: pointer;
  transition: background .2s, transform .2s;
}
.comment-form .submit:hover { background: var(--dk-brand-dark); transform: translateY(-2px); }
.form-submit { margin-top: .5rem; }

/* ==========================================================================
   PÃGINAS ESTÃTICAS
   ========================================================================== */
.page .dk-article { max-width: 860px; }
.dk-page-head {
  margin-bottom: 2rem;
  padding-bottom: 1.2rem;
  border-bottom: 1px solid var(--dk-line);
}

/* ==========================================================================
   BÃšSQUEDA
   ========================================================================== */
.search .dk-page-title span { color: var(--dk-brand-dark); }
.dk-card--row .dk-card__media img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--dk-radius-sm) 0 0 var(--dk-radius-sm); }

/* ==========================================================================
   404
   ========================================================================== */
.error404 .dk-page { text-align: center; }
.error404 .dk-page h1 { font-size: clamp(4rem, 16vw, 9rem); line-height: 1; color: var(--dk-brand); margin-bottom: 0; }
.error404 .dk-eyebrow { font-size: 1rem; }

/* ==========================================================================
   Responsive â€” contenido
   ========================================================================== */
@media (max-width: 720px) {
  .post-navigation,
  .nav-links { grid-template-columns: 1fr; }
  .post-navigation .nav-next { text-align: left; }
  .comment-list .children { padding-left: 24px; }
}

/* ==========================================================================
   PÃGINA CESTA DE LOS TESOROS
   ========================================================================== */

/* â”€â”€ Hero â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dk-cesta-hero {
  padding-block: 40px 0;
  background: transparent;
}

/* Banner imagen packs (/etiqueta-producto/packs/) */
.dk-packs-banner { margin-bottom: 32px; }
.dk-packs-banner__img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 20px;
  box-shadow: 0 12px 40px -10px rgba(0,0,0,0.18);
}

.dk-cesta-hero__banner-link { display: block; text-decoration: none; }
.dk-cesta-hero__banner {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 20px;
  box-shadow: 0 12px 40px -10px rgba(0,0,0,0.18);
}
.dk-cesta-hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  padding: 32px 0 8px;
}

/* â”€â”€ Pasos "cÃ³mo funciona" â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dk-cesta-steps {
  display: grid;
  grid-template-columns: 1fr 36px 1fr 36px 1fr;
  gap: 0 8px;
  align-items: start;
  margin-bottom: 2.4rem;
}

.dk-cesta-step {
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius);
  padding: 28px 24px;
  text-align: center;
}
.dk-cesta-step--arrow {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 50px;
  color: var(--dk-muted);
  font-size: 1.4rem;
}
.dk-cesta-step--arrow::before { content: "\2192"; }

.dk-cesta-step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--dk-brand-soft);
  color: var(--dk-brand-dark);
  font-family: var(--dk-font-display);
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 auto 18px;
}
.dk-cesta-step h3 {
  font-size: 1.1rem;
  margin-bottom: .5rem;
  line-height: 1.3;
}
.dk-cesta-step p {
  color: var(--dk-muted);
  font-size: .92rem;
  margin: 0;
  line-height: 1.6;
}

/* â”€â”€ Banner de descuento â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dk-cesta-discount {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--dk-pastel-yellow);
  border-radius: var(--dk-radius);
  padding: 18px 28px;
  margin-top: 2rem;
}
.dk-cesta-discount svg { flex: 0 0 auto; color: var(--dk-brand-dark); }
.dk-cesta-discount p { margin: 0; font-size: .97rem; color: var(--dk-charcoal); }
.dk-cesta-discount strong { color: var(--dk-brand-dark); }

/* â”€â”€ Grid de cestas prefabricadas (5 items) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dk-products-grid--5 {
  grid-template-columns: repeat(5, 1fr);
}

/* â”€â”€ Encabezado del form â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dk-cesta-form-head { margin-bottom: 2.4rem; }
.dk-cesta-form-head p { color: var(--dk-muted); max-width: 60ch; margin-inline: auto; }

/* â”€â”€ Wrapper del formulario â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.dk-cesta-form-wrap {
  background: var(--dk-white);
  border: 1px solid var(--dk-line);
  border-radius: var(--dk-radius-lg);
  padding: clamp(24px, 4vw, 56px);
  max-width: 1000px;
  margin-inline: auto;
}

/* Headings dentro del formulario */
.dk-cesta-form-wrap h3,
.dk-cesta-form-wrap h4 {
  font-size: 1.1rem;
  margin-top: 2rem;
  margin-bottom: .8rem;
  padding-bottom: .5rem;
  border-bottom: 2px solid var(--dk-line);
  color: var(--dk-charcoal);
}
.dk-cesta-form-wrap h3:first-child,
.dk-cesta-form-wrap h4:first-child { margin-top: 0; }

/* Inputs de texto, email, tel, select */
.dk-cesta-form-wrap input[type="text"],
.dk-cesta-form-wrap input[type="email"],
.dk-cesta-form-wrap input[type="tel"],
.dk-cesta-form-wrap select,
.dk-cesta-form-wrap textarea {
  width: 100%;
  border: 1.5px solid var(--dk-line);
  border-radius: var(--dk-radius-sm);
  padding: .85em 1.1em;
  font-family: var(--dk-font-body);
  font-size: .97rem;
  background: var(--dk-cream);
  color: var(--dk-charcoal);
  transition: border-color .2s;
}
.dk-cesta-form-wrap input[type="text"]:focus,
.dk-cesta-form-wrap input[type="email"]:focus,
.dk-cesta-form-wrap input[type="tel"]:focus,
.dk-cesta-form-wrap select:focus,
.dk-cesta-form-wrap textarea:focus {
  outline: none;
  border-color: var(--dk-brand);
}
.dk-cesta-form-wrap textarea { min-height: 100px; resize: vertical; }

/* Checkboxes â€” grid automÃ¡tico */
.dk-cesta-form-wrap .wpcf7-checkbox .wpcf7-list-item,
.dk-cesta-form-wrap .wpcf7-radio .wpcf7-list-item {
  display: inline-flex;
  align-items: center;
  margin: 0 !important;
}
.dk-cesta-form-wrap .wpcf7-checkbox,
.dk-cesta-form-wrap .wpcf7-radio {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px 12px;
  margin-block: .6rem;
}
.dk-cesta-form-wrap input[type="checkbox"],
.dk-cesta-form-wrap input[type="radio"] {
  accent-color: var(--dk-brand);
  width: 16px; height: 16px;
  margin-right: 6px;
  flex: 0 0 auto;
}
.dk-cesta-form-wrap label { font-size: .93rem; cursor: pointer; }
.dk-cesta-form-wrap p.wpcf7-form-control-wrap { margin: 0; }

/* BotÃ³n de envÃ­o */
.dk-cesta-form-wrap .wpcf7-submit,
.dk-cesta-form-wrap input[type="submit"],
.dk-cesta-form-wrap button[type="submit"] {
  background: var(--dk-brand);
  color: #fff !important;
  border: none;
  border-radius: var(--dk-radius-pill);
  padding: 1em 2.6em;
  font-family: var(--dk-font-body);
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  transition: background .2s, transform .2s;
  box-shadow: 0 10px 22px -12px rgba(224,127,31,.8);
  display: inline-block;
  margin-top: 1rem;
}
.dk-cesta-form-wrap .wpcf7-submit:hover,
.dk-cesta-form-wrap input[type="submit"]:hover { background: var(--dk-brand-dark); transform: translateY(-2px); }

/* Mensaje OK / error de CF7 */
.dk-cesta-form-wrap .wpcf7-response-output {
  margin-top: 1rem;
  padding: .9em 1.2em;
  border-radius: var(--dk-radius-sm);
  font-weight: 600;
  font-size: .93rem;
  border: none !important;
}
.dk-cesta-form-wrap .wpcf7-mail-sent-ok { background: var(--dk-pastel-mint); color: #2d7a4a; }
.dk-cesta-form-wrap .wpcf7-validation-errors,
.dk-cesta-form-wrap .wpcf7-mail-sent-ng { background: #FEE8E4; color: var(--dk-sale); }

/* â”€â”€ Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 1100px) {
  .dk-products-grid--5 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .dk-cesta-steps { grid-template-columns: 1fr; gap: 12px; }
  .dk-cesta-step--arrow { transform: rotate(90deg); margin-top: 0; min-height: 36px; }
  .dk-cesta-hero h1 { font-size: 2.2rem; }
  .dk-products-grid--5 { grid-template-columns: repeat(2, 1fr); }
  .dk-cesta-discount { flex-direction: column; text-align: center; }
}
@media (max-width: 480px) {
  .dk-products-grid--5 { grid-template-columns: 1fr 1fr; }
  .dk-cesta-form-wrap .wpcf7-checkbox,
  .dk-cesta-form-wrap .wpcf7-radio { grid-template-columns: 1fr 1fr; }
}
