/*
Theme Name: DB Newsletter RD
Theme URI: https://example.com/
Author: DB
Author URI: https://example.com/
Description: Tema ligero, moderno y orientado a móvil (inspirado en Orbital). Diseñado para sitios de noticias, Gutenberg y embeds responsivos.
Version: 6.0.5
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: db-newsletter-rd
Tags: news, blog, one-column, custom-logo, responsive-layout, editor-style
*/

:root{
  --db-text:#333333;
  --db-bg:#ffffff;
  --db-muted:#6b7280;
  --db-border:#e5e7eb;
  --db-max: 1180px;
  --db-pad: 16px;
  --db-radius: 14px;
}

html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--db-bg);
  color:var(--db-text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  font-size:20px;
  line-height:1.65;
  word-wrap:break-word;
  overflow-wrap:anywhere;
}
a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:none; }
img{ max-width:100%; height:auto; }
*{ box-sizing:border-box; }

.db-container{
  max-width: var(--db-max);
  margin: 0 auto;
  padding: 0 var(--db-pad);
  min-width:0;
  overflow-x:clip;
}

.db-header{
  position:relative; 
  z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--db-border);
}
.db-header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 12px 0;
}
.db-brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width: 0;
}
.db-brand a{
  font-weight:800;
  text-decoration:none;
  color:inherit;
  letter-spacing:-.02em;
  white-space:nowrap;
}
.db-logo img{ max-height:40px; width:auto; display:block; }
.db-nav{
  display:flex;
  align-items:center;
  gap:12px;
}
.db-menu{
  display:flex;
  align-items:center;
  gap:14px;
  list-style:none;
  margin:0;
  padding:0;
  font-size:16px;
}
.db-menu a{
  display:inline-flex;
  text-decoration:none;
  color:inherit;
  padding:10px 10px;
  border-radius:12px;
}
.db-menu a:hover{ background:#f3f4f6; text-decoration:none; }

/* Submenús (desktop): dropdown en lista para evitar que se rompa el header */
.db-menu > li{ position:relative; }
.db-menu .sub-menu{
  list-style:none;
  margin:0;
  padding:10px;
  position:absolute;
  top:100%;
  left:0;
  min-width:220px;
  background:#fff;
  border:1px solid var(--db-border);
  border-radius:14px;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  display:none;
  z-index:60;
}
.db-menu .sub-menu li{ margin:0; }
.db-menu .sub-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  white-space:normal;
}
.db-menu li:hover > .sub-menu,
.db-menu li:focus-within > .sub-menu{
  display:block;
}

.db-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.db-iconbtn{
  width:42px;
  height:42px;
  border:1px solid var(--db-border);
  border-radius:12px;
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.db-iconbtn:hover{ background:#f9fafb; }
.db-hamburger{ display:none; }

/* IMPORTANTE: el menú móvil existe en el HTML para accesibilidad,
   pero en escritorio debe estar SIEMPRE oculto para evitar “doble menú”. */
.db-mobile-menu{ display:none; }

@media (max-width: 980px){
  .db-menu{ display:none; }
  .db-hamburger{ display:inline-flex; }
  .db-mobile-menu{
    display:none;
    border-top:1px solid var(--db-border);
    padding:10px 0 16px;
  }
  .db-mobile-menu.is-open{ display:block; }
  .db-mobile-menu ul{
    list-style:none; margin:0; padding:0;
    display:flex; flex-direction:column; gap:6px;
    font-size:18px;
  }
  .db-mobile-menu a{ padding:12px 10px; border-radius:12px; display:block; }
  .db-mobile-menu a:hover{ background:#f3f4f6; text-decoration:none; }
}

/* Layout */
.db-main{ padding: 18px 0 34px; }
.db-title{
  font-size:28px;
  line-height:1.2;
  margin: 12px 0 10px;
  letter-spacing:-.02em;
}
.db-meta{ color:var(--db-muted); font-size:15px; margin-top:6px; }

.db-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
  min-width:0;
  max-width:100%;
}
.db-grid > *{
  min-width:0;
  max-width:100%;
}
@media (min-width: 720px){
  .db-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (min-width: 1024px){
  .db-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}

.db-card{
  border:1px solid var(--db-border);
  border-radius: var(--db-radius);
  overflow:hidden;
  background:#fff;
}
.db-card > a{ display:block; color:inherit; text-decoration:none; }
.db-card > a:hover{ text-decoration:none; }
.db-card:hover{ border-color:#d1d5db; }
.db-thumb{
  aspect-ratio: 16/9;
  background:#f3f4f6;
  overflow:hidden;
}
.db-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.db-card-body{ padding: 12px 12px 14px; }
.db-card-title{
  font-size:18px;
  line-height:1.25;
  margin:0;
  font-weight:800;
}
.db-card-title a:hover{ text-decoration:none; }
.db-pagination{
  display:flex;
  gap:10px;
  justify-content:center;
  margin-top: 18px;
  font-size:16px;
}
.db-pagination a, .db-pagination span{
  border:1px solid var(--db-border);
  border-radius:12px;
  padding:10px 12px;
}
.db-pagination .current{ background:#111827; color:#fff; border-color:#111827; }

/* Single */
.db-article{
  max-width: 820px;
  margin: 0 auto;
}
.db-article .db-title{ font-size:28px; }
.db-entry-category{
  display:inline-flex;
  align-items:center;
  margin: 0 0 10px;
  padding: 6px 11px;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-size:13px;
  font-weight:800;
  line-height:1.2;
  text-transform:uppercase;
}
.db-entry-category:hover,
.db-entry-category:focus{
  color:#fff;
}
.db-entry-thumb{
  border-radius: var(--db-radius);
  margin: 14px 0 18px;
}
.db-content p{ margin: 0 0 16px; }
.db-content h2{ font-size:24px; margin: 26px 0 10px; }
.db-content h3{ font-size:22px; margin: 22px 0 8px; }
.db-content ul, .db-content ol{ padding-left: 22px; }
.db-content blockquote{
  margin: 18px 0;
  padding: 14px 16px;
  border-left: 4px solid #111827;
  background:#f9fafb;
  border-radius: 12px;
}
.db-content img,
.db-content .wp-block-image img{
  border-radius: var(--db-radius);
}
.db-content figure img{
  display:block;
}
.db-related{
  max-width: var(--db-max);
  margin: 30px auto 0;
}
.db-related-title{
  margin: 0 0 14px;
  font-size:24px;
  line-height:1.2;
  font-weight:800;
  letter-spacing:0;
}
.db-related-grid{
  margin-top:0;
}

/* Gutenberg blocks: full width support */
.alignwide{ width:100%; max-width: var(--db-max); margin-left:auto; margin-right:auto; }
.alignfull{ width:100vw; max-width:100vw; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
.wp-block-image, .wp-block-video{ margin: 0 0 18px; }

/* Embeds responsivos: Instagram, Facebook, YouTube, Rumble, Dailymotion, X, etc. */
.wp-block-embed,
.wp-block-embed__wrapper{
  width:100%;
  max-width:100%;
}
.wp-block-embed__wrapper iframe,
.wp-block-embed__wrapper embed,
.wp-block-embed__wrapper object{
  max-width:100% !important;
}
.wp-block-embed.is-type-video .wp-block-embed__wrapper,
.wp-block-embed.is-provider-youtube .wp-block-embed__wrapper,
.wp-block-embed.is-provider-dailymotion .wp-block-embed__wrapper,
.wp-block-embed.is-provider-vimeo .wp-block-embed__wrapper{
  position:relative;
  width:100%;
  padding-top:56.25%;
}
.wp-block-embed.is-type-video iframe,
.wp-block-embed.is-provider-youtube iframe,
.wp-block-embed.is-provider-dailymotion iframe,
.wp-block-embed.is-provider-vimeo iframe{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  border:0;
}

/* Iframes sueltos (si pegas HTML): no rompen */
.db-content iframe{
  max-width:100%;
}

/* AdSense y anuncios inyectados: evita que unidades responsivas o iframes
   externos ensanchen el listado en movil. */
.db-container ins.adsbygoogle,
.db-container .adsbygoogle,
.db-container .code-block,
.db-container .google-auto-placed,
.db-container .google-auto-placed > *,
.db-container [id^="aswift_"],
.db-container [id^="google_ads_iframe_"],
.db-container iframe[id^="aswift_"],
.db-container iframe[id^="google_ads_iframe_"]{
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
}
.db-container ins.adsbygoogle,
.db-container .adsbygoogle,
.db-container .code-block{
  display:block !important;
  width:100% !important;
  margin-left:auto !important;
  margin-right:auto !important;
  overflow:hidden !important;
}
.db-grid > ins.adsbygoogle,
.db-grid > .adsbygoogle,
.db-grid > .code-block,
.db-grid > .google-auto-placed,
.db-grid > [id^="aswift_"],
.db-grid > [id^="google_ads_iframe_"]{
  justify-self:stretch;
  width:100% !important;
  overflow:hidden;
}
.db-content .google-auto-placed,
.db-content .code-block,
.db-content ins.adsbygoogle,
.db-content .adsbygoogle{
  clear:both;
  max-width:100% !important;
  overflow:hidden !important;
}
.db-container .code-block iframe{
  max-width:100% !important;
  min-width:0 !important;
}

/* Footer */
.db-footer{
  border-top:1px solid var(--db-border);
  padding: 22px 0;
  color:var(--db-muted);
  font-size:15px;
}

/* Search modal */
.db-modal{
  position:fixed;
  inset:0;
  background:rgba(17,24,39,.52);
  display:none;
  align-items:center;
  justify-content:center;
  padding: 24px 16px;
  z-index:200;
  backdrop-filter: blur(8px);
}
.db-modal.is-open{ display:flex; }
.db-modal-panel{
  width: min(680px, 100%);
  background:#fff;
  border-radius: 20px;
  border:1px solid var(--db-border);
  padding: 18px;
  box-shadow: 0 24px 80px rgba(0,0,0,.28);
}
.db-modal-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin: 0 0 12px;
}
.db-modal-title{
  font-size:18px;
  font-weight:800;
  line-height:1.2;
}
.db-modal-close{
  width:38px;
  height:38px;
  border:1px solid var(--db-border);
  border-radius:12px;
  background:#f9fafb;
  color:#111827;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
  line-height:1;
  cursor:pointer;
}
.db-modal-close:hover,
.db-modal-close:focus{
  background:#eef2f7;
}
.db-search{
  width:100%;
}
.db-search-row{
  display:flex;
  gap:10px;
  align-items:stretch;
  width:100%;
}
.db-search-row input[type="search"]{
  flex: 1 1 auto;
  min-width:0;
  width:auto;
  height:54px;
  border:1px solid var(--db-border);
  border-radius:14px;
  padding: 0 16px;
  font-size:18px;
  line-height:1;
  outline:none;
  background:#f9fafb;
}
.db-search-row input[type="search"]:focus{
  border-color:#111827;
  background:#fff;
  box-shadow:0 0 0 4px rgba(17,24,39,.08);
}
.db-search-row button{
  flex: 0 0 auto;
  min-width:110px;
  height:54px;
  border:1px solid var(--db-border);
  background:#111827;
  color:#fff;
  border-radius:14px;
  padding: 0 18px;
  font-size:16px;
  font-weight:800;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  white-space:nowrap;
  cursor:pointer;
}
.db-search-row button:hover,
.db-search-row button:focus{
  background:#000;
}
.db-search-hint{ margin: 10px 0 0; font-size:14px; color:var(--db-muted); }

@media (max-width: 520px){
  .db-modal{
    align-items:flex-start;
    padding-top:64px;
  }
  .db-modal-panel{
    padding:14px;
    border-radius:18px;
  }
  .db-search-row{
    flex-direction:column;
  }
  .db-search-row button{
    width:100%;
  }
}

/* Accessibility */
.screen-reader-text{
  position:absolute !important;
  height:1px; width:1px;
  overflow:hidden;
  clip:rect(1px,1px,1px,1px);
  white-space:nowrap;
}

/* Refuerzo anti-doble-menú: si por cualquier razón el menú móvil se renderiza, que no se vea en escritorio */
.db-mobile-menu[hidden]{ display:none !important; }
@media (min-width: 981px){
  .db-mobile-menu{ display:none !important; }
  .db-mobile-menu ul{ list-style:none; margin:0; padding:0; }
}

.db-brand a:hover{ text-decoration:none; }


/* v4: asegurar que el header NO sea fijo/pegajoso */
.db-header{ position:static !important; top:auto !important; }


/* v5: Submenú en PC como dropdown en listado (corrige menú roto) */
@media (min-width: 981px){
  /* Solo el primer nivel es horizontal */
  .db-menu{ display:flex; align-items:center; gap:14px; }
  .db-menu > li{ position:relative; }

  /* Submenú: fuera del flujo, en columna, oculto por defecto */
  .db-menu > li > ul.sub-menu{
    position:absolute;
    top:100%;
    left:0;
    min-width:220px;
    margin:8px 0 0;
    padding:10px;
    list-style:none;
    background:#fff;
    border:1px solid var(--db-border);
    border-radius:14px;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    display:none;
    z-index:90;
  }
  .db-menu > li > ul.sub-menu > li{ margin:0; }
  .db-menu > li > ul.sub-menu a{
    display:block;
    padding:10px 12px;
    border-radius:12px;
    white-space:normal;
  }

  /* Mostrar al pasar el mouse o con teclado */
  .db-menu > li:hover > ul.sub-menu,
  .db-menu > li:focus-within > ul.sub-menu{
    display:block;
  }
}

/* v5: asegurar que cualquier UL anidado no se vea como parte del menú horizontal */
.db-menu ul{ display:block; }


/* v4: asegurar que cualquier UL anidado no se vea como parte del menú horizontal */
.db-menu ul{ display:block; }

/* v5: eliminar subrayado al pasar el mouse en TODO el sitio */
a:hover,
a:focus,
a:active{
  text-decoration: none !important;
}


/* v5: asegurar que el header NO siga el scroll (sin sticky/fixed) */
.db-header{ position:static !important; top:auto !important; }

/* Cookie notice */
.cookies-revoke,
.cookies-window{
  position:fixed;
  z-index:10000000;
  box-sizing:border-box;
  display:flex;
  flex-wrap:nowrap;
  font-size:16px;
  line-height:1.5;
  opacity:1;
  overflow:hidden;
  transition:opacity 1s ease;
}
.cookies-window.cookies-static{
  position:static;
}
.cookies-window.cookies-invisible{
  opacity:0;
}
.cookies-window.cookies-banner{
  width:100%;
  max-width:100vw;
  padding:1em 1.8em;
  flex-direction:row;
  align-items:center;
}
.cookies-window.cookies-floating{
  width:100%;
  max-width:24em;
  padding:2em;
  flex-direction:column;
}
.cookies-banner.cookies-bottom{
  right:0;
  bottom:0;
  left:0;
}
.cookies-banner.cookies-top{
  top:0;
  right:0;
  left:0;
}
.cookies-message{
  flex:1;
  min-width:0;
  margin-right:1em;
  overflow-wrap:anywhere;
}
.cookies-link{
  display:inline-block;
  padding:.2em;
  cursor:pointer;
  opacity:.85;
  text-decoration:underline;
}
.cookies-link:hover{
  opacity:1;
  text-decoration:underline !important;
}
.cookies-compliance{
  display:flex;
  align-items:center;
  align-content:space-between;
  flex:0 0 auto;
}
.cookies-btn{
  display:block;
  min-width:140px;
  padding:.55em 1em;
  border:2px solid transparent;
  border-radius:5px;
  cursor:pointer;
  font-size:.9em;
  font-weight:800;
  text-align:center;
  white-space:nowrap;
}
.cookies-banner .cookies-btn:last-child{
  min-width:140px;
}
.cookies-compliance > .cookies-btn{
  flex:1;
}
.cookies-btn + .cookies-btn{
  margin-left:.5em;
}
.cookies-revoke{
  display:none;
}

@media print{
  .cookies-window{
    display:none;
  }
}

@media screen and (max-width:900px){
  .cookies-btn{
    white-space:normal;
  }
}

@media screen and (max-width:736px){
  .cookies-window{
    font-size:14px;
    line-height:1.45;
  }
  .cookies-window.dbnrd-cookie-card,
  .cookies-window.cookies-floating,
  .cookies-window.cookies-banner{
    left:50% !important;
    right:auto !important;
    width:calc(100vw - 28px) !important;
    max-width:430px !important;
    max-height:55vh !important;
    transform:translateX(-50%) !important;
    flex-direction:column;
    align-items:center !important;
    gap:10px;
    padding:14px 14px calc(14px + env(safe-area-inset-bottom, 0px)) !important;
    overflow-x:hidden;
    overflow-y:auto;
    text-align:center;
    background:rgba(237,239,245,.75) !important;
    color:#404656 !important;
    border-radius:18px !important;
    box-shadow:0 -12px 32px rgba(0,0,0,.18) !important;
    backdrop-filter:blur(12px) !important;
    -webkit-backdrop-filter:blur(12px) !important;
  }
  .cookies-window.dbnrd-cookie-card.cookies-bottom,
  .cookies-window.cookies-floating.cookies-bottom,
  .cookies-window.cookies-bottom{
    bottom:calc(12px + env(safe-area-inset-bottom, 0px)) !important;
    top:auto !important;
  }
  .cookies-window.dbnrd-cookie-card.cookies-top,
  .cookies-window.cookies-floating.cookies-top,
  .cookies-window.cookies-top{
    top:12px !important;
    bottom:auto !important;
    box-shadow:0 12px 32px rgba(0,0,0,.18) !important;
  }
  .cookies-message{
    display:block;
    flex:0 1 auto;
    width:100%;
    max-width:100%;
    margin-right:0;
    margin-bottom:0;
    font-size:14px;
    line-height:1.45;
    text-align:center;
  }
  .cookies-link{
    padding:0;
    color:inherit !important;
  }
  .cookies-compliance{
    width:100%;
    flex:0 0 auto;
    flex-wrap:wrap;
    gap:8px;
    justify-content:center;
  }
  .cookies-compliance > .cookies-btn,
  .cookies-btn{
    width:100%;
    min-width:0;
    margin:0 !important;
    padding:10px 12px;
    border-radius:10px;
    font-size:14px;
    line-height:1.2;
    white-space:normal;
  }
}
