/*
Theme Name: pre entrenos
Author: Pres
Description: Preentrenos
Version: 1

Text Domain: wp-bootstrap-starter

*/
/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Normalize
# Typography
# Elements
# Forms
# Navigation
	## Links
	## Menus
# Accessibility
# Alignments
# Clearings
# Widgets
# Content
	## Posts and pages
	## Comments
# Infinite scroll
# Media
	## Captions
	## Galleries
# Woocommerce
# Footer
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/
body {
  margin: 0;
  -webkit-font-smoothing: auto;
  font-family: 'Lato', sans-serif;
  color: var(--color-dark);
  background: #fdfdfd !important;
  font-size: 20px;
  font-weight: 300;
  letter-spacing: 0.2px;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Playfair Display', serif;
  color: var(--color-dark);
  font-weight: 600;
  line-height: 1.25;
  margin-bottom: 0.75rem;
  letter-spacing: 0.3px;
}

h1 { font-size: 3em;    font-weight: 700; }
h2 { font-size: 2.6rem;  font-weight: 600; }
h3 { font-size: 1.9rem;  font-weight: 600; }
h4 { font-size: 1.6rem;  font-weight: 500; }
h5 { font-size: 1.3rem;  font-weight: 500; }
h6 { font-size: 1.1rem;  font-weight: 500; }

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden],
template {
  display: none;
}

a {
  background-color: transparent;
}

a:active,
a:hover {
  outline: 0;
}

dfn {
  font-style: italic;
}

mark {
  background: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

figure {
  margin: 1em 2.5rem;
}

hr {
  box-sizing: content-box;
  height: 0;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

.table-bordered td, .table-bordered th {
    border: 1px solid #ffcad4;
}

.table-sm td, .table-sm th {
    padding: 0.3rem 0.8rem;
}

.table td, .table th {
    vertical-align: unset;
    border-top: 1px solid #ffcad4;
}
.table-bordered {
    border: 1px solid #ffcad4;
}

table th {
    background-color: transparent;
    color: inherit;
}

td,
th {
  padding: 0;
}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/

.display-4 {
	font-weight: 300;
    line-height: 1.2;
    color: #fdb3c1;
    text-shadow: 0px 2px 0px #333;
}

/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/

img {
  height: auto;
  /* Make sure images are scaled correctly. */
  max-width: 100%;
  /* Adhere to container width. */
}

figure {
  margin: 1em 0;
  /* Extra wide images within figure tags don't overflow the content area. */
}

table {
  margin: 0 0 1.5em;
  width: 100%;
}

html, body {
  width: 100% !important;
  
}

.page-header .page-title {
    margin-top: 1.5em;
}

.container ul li {
    padding-top: 2px;
    padding-bottom: 2px;
}

/*--------------------------------------------------------------
# Forms
--------------------------------------------------------------*/
/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
header#masthead {
    background-color: #F7F4EF;
    padding: 0.5em 0;
}


.navbar-brand > a:visited, .navbar-brand > a:hover {
  text-decoration: none;
}

.navbar-dark .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba(2, 2, 2, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

#page-sub-header {
  position: relative;
  padding-top: 0.2em;
  padding-bottom: 0.6em;
  font-size: 1.25rem;
  background-color: #ff9900 !important;
}

body:not(.theme-preset-active) #page-sub-header h1 {
  font-size: 1.5em;
  color: #fcfcfc;
  margin: 0;
  border: 0;
  padding: 0;
}

#page-sub-header p {
  display:none;
}

a.page-scroller {
  color: #333;
  font-size: 2.6rem;
  display: inline-block;
  margin-top: 2rem;
}

#logo {
  width: 243px;
	height: 61px;
	    margin-left: 54px;
}

#logo_teacheret_corazones {
  width: 220px;
}



/*--------------------------------------------------------------
## Links
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Menus
--------------------------------------------------------------*/
#masthead nav {
  padding-left: 0;
  padding-right: 0;
}

#masthead .navbar-nav > li > a, .button-reserva {
  color: #222;
  padding: 0.5rem 0.75rem;
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
}

#masthead .navbar-nav > li:last-child > a, .button-reserva {
  padding-top: 6px;
  margin-left: 10px;
  display: inline-block;
}


#menu-nav {
  margin-top: 4px;
}
.navbar-brand {
  height: auto;
}

.navbar-toggle .icon-bar {
  background: #000 none repeat scroll 0 0;
}

.dropdown-menu .dropdown-toggle::after {
  border-bottom: 0.3em solid transparent;
  border-left: 0.3em solid;
  border-top: 0.3em solid transparent;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children {
    position: relative;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children>.dropdown-menu {
    top: 0;
    left: 100%;
    margin-top: -6px;
    margin-left: -1px;
    -webkit-border-radius: 0 6px 6px 6px;
    -moz-border-radius: 0 6px 6px;
    border-radius: 0 6px 6px 6px;
}
.dropdown.menu-item-has-children .dropdown.menu-item-has-children:hover>.dropdown-menu {
    display: block;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children>a:after {
    display: block;
    content: " ";
    float: right;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid;
    border-width: 5px 0 5px 5px;
    border-left-color: #ccc;
    margin-top: 5px;
    margin-right: -10px;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children:hover>a:after {
    border-left-color: #fff;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children.pull-left {
    float: none;
}

.dropdown.menu-item-has-children .dropdown.menu-item-has-children.pull-left>.dropdown-menu {
    left: -100%;
    margin-left: 10px;
    -webkit-border-radius: 6px 0 6px 6px;
    -moz-border-radius: 6px 0 6px 6px;
    border-radius: 6px 0 6px 6px;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
  display: block;
}

.dropdown-item {
  line-height: 1.2;
  padding-bottom: 0.313rem;
  padding-top: 0.313rem;
}

.dropdown-menu {
  min-width: 12.500rem;
}

.dropdown .open .dropdown-menu {
  display: block;
  left: 12.250em;
  top: 0;
}

.dropdown-menu .dropdown-item {
  white-space: normal;
  background: transparent;
  line-height: 1.6;
}
.dropdown-menu .dropdown-item:hover {
  background: transparent;
}



/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}
.screen-reader-text:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  color: #21759b;
  display: block;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: bold;
  height: auto;
  left: 0.313rem;
  line-height: normal;
  padding: 0.938rem 1.438rem 0.875rem;
  text-decoration: none;
  top: 0.313rem;
  width: auto;
  z-index: 100000;
  /* Above WP toolbar. */
}

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
  outline: 0;
}


/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
  content: "";
  display: table;
  table-layout: fixed;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
  clear: both;
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget {
  margin: 0 0 1.5em;
  font-size: 0.875rem;
  /* Make sure select elements fit in widgets. */
}
.widget select {
  max-width: 100%;
}

.widget_search .search-form input[type="submit"] {
  display: none;
}

.nav > li > a:focus,
.nav > li > a:hover {
  background-color: #eee;
  text-decoration: none;
}
.half-rule {
  width: 6rem;
  margin: 2.5rem 0;
}
.widget_categories .nav-link {
  display: inline-block;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/
#content.site-content {
  padding-bottom:0;
  padding-top: 0;
}

.sticky .entry-title::before {
  content: '\f08d';
  
  font-size: 1.563rem;
  left: -2.5rem;
  position: absolute;
  top: 0.375rem;
  font-weight: 900;
}

.sticky .entry-title {
  position: relative;
}

.single .byline,
.group-blog .byline {
  display: inline;
}

.page-content,
.entry-content,
.entry-summary {
  margin: 1.5em 0 0;
}

.entry-content{
  margin-top:0;
}

.page-links {
  clear: both;
  margin: 0 0 1.5em;
}

.page-template-blank-page .entry-content,
.blank-page-with-container .entry-content {
  margin-top: 0;
}




.entry-title > a {
  color: inherit;
}

/*--------------------------------------------------------------
# Infinite scroll
--------------------------------------------------------------*/
/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
  /* Theme Footer (when set to scrolling) */
  display: none;
}

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
  display: block;
}

/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
  max-width: 100%;
  border-radius: 12px;
}

/*--------------------------------------------------------------
## Captions
--------------------------------------------------------------*/
.wp-caption {
  background: #f1f1f1 none repeat scroll 0 0;
  border: 1px solid #f0f0f0;
  max-width: 96%;
  padding: 0.313rem 0.313rem 0;
  text-align: center;
}
.wp-caption img[class*="wp-image-"] {
  border: 0 none;
  height: auto;
  margin: 0;
  max-width: 100%;
  padding: 0;
  width: auto;
}
.wp-caption .wp-caption-text {
  font-size: 0.688rem;
  line-height: 1.063rem;
  margin: 0;
  padding: 0.625rem;
}

.wp-caption-text {
  text-align: center;
}


.entry-meta {
  font-size: 16px;  
  text-align: center;
  margin-top: 6px;
}


/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/
footer#colophon {
  font-size: 85%;
}
body:not(.theme-preset-active) footer#colophon {
  color: #ccc;
  background-color: #131a22;
}

.copyright {
  font-size: 0.875rem;
  margin-bottom: 0;
  text-align: center;
}

.copyright a, footer#colophon a {
  color: inherit;
}




/*--------------------------------------------------------------
## CUSTOM
--------------------------------------------------------------*/
#main {
  box-shadow: none !important;
}

@media only screen and (min-width: 1200px) {
  .container {
    width: 1280px !important;
    
  }
}

.container {
  max-width: 100% !important;
}

.entry-footer {
  margin-top:2em;
  
  background-color: #eee;
}
.navbar-dark .navbar-toggler {
  border-color: #333;
  color: #333;
  padding-top: 6px;
	margin-right: 12px;
}

.entry-footer {
  display: none;
}

/* FROM FUSION BUILDER */

#cookies-eu-banner {
    z-index:99999;
    border-top: 1px solid #b30 !important;
    font-size:1em;
    background-color:#fdfdfd;
}
#cookies-eu-accept {
    font-size:14px;
}
#cookies-eu-reject {
    display:none;
}

table.especificaciones {
    margin-top:0;
}
.especificaciones th {
    vertical-align: bottom;
    border-bottom: 2px solid #080b0f;
    color: #222;
    background: #fff;
    font-size: 24px;
    padding-bottom: 20px;
}

.especificaciones td {
    padding: 14px 12px;
    letter-spacing: 0px;
    font-size: 1em;
}

.fusion-blog-layout-medium .fusion-post-slideshow {
  margin-right: 0;
  width: 100%;
}

.fusion-date-and-formats {
    margin-right:6px;
}

.fusion-blog-layout-medium-alternate .has-post-thumbnail .fusion-post-content {
    margin-left: 420px;
}

ul.check-list > li {
    margin-bottom: 1em;
    list-style: none;
    margin-left:-38px;
}

iframe {
    max-width: 100% !important;
}

.aawp .aawp-product--horizontal {
	border: 0 !important;
}

.aawp .aawp-product--horizontal .aawp-product__thumb {
    width: 180px;
}

.aawp-product__no_content .aawp-product__content, .aawp-product__no_footer .aawp-product__footer {
    display: none;
}


.post-content p a {
    color: #111;
    box-shadow: rgb(0, 117, 178) 0px -2px 0px inset;
    transition: color 0.1s ease-out 0s;
    text-decoration: none;
}

.product_box h2 {
    margin-top: 8px !important;
    margin-left: 8px !important;
    margin-bottom: 32px !important;
}

ul.check-list > li:before, .aawp .aawp-product--horizontal .aawp-product__description>ul li:before {
    content: '\f00c' !important;
    
    color: #58c649 !important;
    padding-right: 8px !important;
}

.img-container img{
  display: block;
  margin: 0 auto;
}

.product-grid-box .ingredientes-esenciales ul {
  padding-left: 0;
  text-align: center;
  margin-bottom: 0.5em;
}


.product-grid-box .ingredientes-esenciales ul li:first-child {
    padding-top: 4px;
}

.product-grid-box .ingredientes-esenciales ul li {
  list-style: none;
  border-bottom: 1px solid #eee;
  padding: 4px 0;
}

.product-grid-box .ingredientes-esenciales i {
	vertical-align: sub;
}

.product-grid-box .cta {
  display: inline-block;
}

.product-grid-box .cta .aawp-button.aawp-button--icon{
  margin: 0 auto;
}

.product-grid-box p.precio {
    font-weight: 500;
    font-size: 1.2em;
}

.product-grid-box p.precio_dosis {
    font-size: 13px;
    margin-top: -28px;
    color: #555;
}

#analisis-hero h2 {
    color: #333 !important;
    font-weight: 700;
    font-size: 1.5em;
    margin: 0 0 6px 0;
}

#analisis-hero, .container, .entry-meta {
    padding: 1em;
}

.text-primary {
	color: #243B37 !important;
}

a {
	color: #133B33;
}


#analisis-hero .bi.bi-star-fill, #analisis-hero .bi.bi-star, #analisis-hero .bi.bi-star-half {
  font-size: 2em;
  margin-top: 1em
}

.top-selection, #analisis-hero {
  background: -moz-linear-gradient(180deg, #fafafa 0%,#fafafa 50%,#ffffff00 0%,#ffffff00 0%);
  background: -webkit-linear-gradient(180deg, #fafafa 0%,#fafafa 50%,#ffffff00 0%,#ffffff00 0%);
	background: linear-gradient(180deg, #fafafa 0%,#fafafa 50%,#ffffff00 0%,#ffffff00 0%);
}

.top-selection h2 {
    font-size: 30px;
    font-weight: 100;
    line-height: 1.2;
	padding: 0 !important;
}

.top-selection .bi.bi-star-half, .top-selection .bi.bi-star-fill, .top-selection .bi.bi-star {
  font-size: 2em;
  margin-bottom: 0.5em;
  display: inline-block;
}


.top-selection .ribbon-top {
  top: 18px;
  right: -55px;
}


.home-hero {
    margin-bottom: 3em;
}

.home-hero h1 {
    font-size: 4.5rem;
    margin-top: 0.7em;
    margin-left: 0;
    letter-spacing: -3px;
}
.home-hero .subtitle {
    font-weight: 400;
    margin-top: 10px;
}

.home-hero h1,  .subtitle, .home-hero p.descripcion {
   text-shadow: 2px 2px 4px #000;
   color: #fefefe;
}

a.subtitle:hover {
  color: #fefefe;
}

.product-box-compatible-vertical {
    /*min-width: 300px;*/
    max-width: 85%;
    min-height: 450px;
}

.product-box-compatible-horizontal {
    margin-bottom:3em;
    padding-right: 1.5em;
    padding-left: 0;
}

.ingretiente {
  margin-bottom: 1em;
}

.bi.bi-star-fill, .bi.bi-star, .bi.bi-star-half {
  margin: 0 2px;
  color: #ffa41c;
  vertical-align: sub;
}

.product-grid-box .low-stimulant {
  background-color: #138294;
}

.product-grid-box .mid-stimulant {
  background-color: #C05802;
}

.product-grid-box .high-stimulant {
  background-color: #dc3545;
}

.product-grid-box .no-stimulant {
	background-color: lightpink;
}
.product-grid-box .no-stimulant span {
	display: block;
}

.product-grid-box .low-stimulant, .product-grid-box .mid-stimulant, .product-grid-box .high-stimulant {
  color: white;
  display: block;
}

#analisis-hero .low-stimulant svg.bi.bi-lightning-fill, #analisis-hero .low-stimulant svg.bi.bi-lightning, #analisis-hero .mid-stimulant svg.bi.bi-lightning-fill, #analisis-hero .mid-stimulant svg.bi.bi-lightning, #analisis-hero .high-stimulant svg.bi.bi-lightning-fill, #analisis-hero .high-stimulant svg.bi.bi-lightning, #analisis-hero .no-stimulant svg.bi.bi-lightning-fill, #analisis-hero .no-stimulant svg.bi.bi-lightning, #analisis-hero .propietary-blend svg.bi.bi-lightning-fill, #analisis-hero .propietary-blend svg.bi.bi-patch-question {
  color: white;
  font-size: 30px;
  margin-bottom: 10px;
 }

 #analisis-hero .estimulante i.bi.bi-question {
    font-size: 1.6em;
    display: inline-block;
    margin-top: -7px;
    color: white;
    vertical-align: text-bottom;
}

 .product-grid-box .propietary-blend {
  background-color: #ededed;
  display: block;
 }

 .product-grid-box .propietary-blend svg.bi.bi-patch-question {
  margin-left: -6px;
  width: 1.5em;
  margin-top: -13px;
 }

 #analisis-hero .propietary-blend svg.bi.bi-lightning-fill {
  margin-top: 2px;
 }
#analisis-hero .propietary-blend svg.bi.bi-patch-question {
  margin-left: -10px;
}


#analisis-hero .estimulante i.bi.bi-lightning-fill, #analisis-hero .estimulante i.bi.bi-lightning {
    font-size: 1.4em;
    color: white;
    vertical-align: text-bottom;
    display: inline-block;
}

#analisis-hero .estimulante.low-stimulant span:first-child, #analisis-hero .estimulante.mid-stimulant span:first-child, #analisis-hero .estimulante.high-stimulant span:first-child, #analisis-hero .estimulante.no-stimulant span:first-child, #analisis-hero .estimulante.propietary-blend span:first-child  {
	color: white;
	text-transform: uppercase;
    font-weight: 700;
    font-size: 22px;
    padding-right: 10px;
}

#analisis-hero .estimulante.low-stimulant, #analisis-hero .estimulante.mid-stimulant, #analisis-hero .estimulante.high-stimulant, #analisis-hero .estimulante.no-stimulant, #analisis-hero .estimulante.propietary-blend {
    padding-top: 4px;
    padding-bottom: 4px;
    padding-left: 10px;
}
	
#analisis-hero .estimulante.mid-stimulant {
	background-color: #c05802;
}

#analisis-hero .estimulante.low-stimulant {
    background-color: #17a2b8;
    
}
#analisis-hero .estimulante.high-stimulant {
  background-color: #dc3545;
}

#analisis-hero .estimulante.no-stimulant {
    background-color: hotpink;
}

#analisis-hero .estimulante.propietary-blend {
  background-color: #666;
}

.mid-stimulant+.rate_bar_wrap{
	border-color: #c05802;
}
.low-stimulant+.rate_bar_wrap{
	border-color: #138294;
}
.high-stimulant+.rate_bar_wrap{
	border-color: #dc3545;
}
.no-stimulant+.rate_bar_wrap{
	border-color: hotpink;
}
.propietary-blend+.rate_bar_wrap{
	border-color: #666;
}

.product-box-top .estimulante {
  margin-top: 10px;
}

/* exopitefilter */ 
.exopite-multifilter-filter-item-post_tag, .exopite-multifilter-filter-reset-search {
  display: none !important;
}

.page-numbers {
    text-align: center;
    padding: 0.8em;
    margin: 0.5em;
    border: 1px solid #ccc;
    background-color: #fafafa;
    border-radius: 4px;
    font-weight: 700;
    font-size: 1em;
}
.exopite-multifilter-filter-item.active:after {
  display: none;
}

/* Sabores */
.sabores ul {
  margin-left: -4px;
  padding-left: 0px;
}
.sabores ul li {
  border: 2px solid #ccc;
  cursor: pointer;
  display: inline-block;
  margin: 4px;
  position: relative;
  padding: 5px 10px 5px 11px;
  background-color: white;
}
.sabores ul li:hover {
  background-color: #f6f6f6;
}
.sabores ul li a {
  border-color: #a2a6ac;
  color: #333;
  font-size: 14px;
  text-decoration: none;
}

@-webkit-keyframes blinker {
  from {opacity: 1.0;}
  to {opacity: 0.0;}
}
.blink{
  text-decoration: blink;
  -webkit-animation-name: blinker;
  -webkit-animation-duration: 1s;
  -webkit-animation-iteration-count:infinite;
  -webkit-animation-timing-function:ease-in-out;
  -webkit-animation-direction: alternate;
}

.information-compra {
    font-weight: 400;
    color: #444;
    margin-top: 2em;
    font-size: 24px;
    background-color: #eee;
    padding: 14px 0;
}

.information-compra .level-item{
  margin: 12px 0;
}

.information-compra p {
  padding:0;
  margin:0;
  display: inline-block;
}

.information-compra .level-item p:first-child {
  font-size: 20px;
  text-transform: capitalize;
}

.information-ingrendients {
    font-weight: 400;
    color: #444;
    font-size: 24px;
  margin-top: 1em;
  
}

.information-ingrendients p {
  padding:0;
  margin:0;
}

.information-ingrendients .level-item{
  margin: 12px 0;
}

.information-ingrendients .level-item p:first-child {
  font-size: 20px;
  font-weight: 100;
}

.boxed-info {
    border: 2px solid #0066B3;
    display: inline-block;
    padding: 6px 7px;
    color: #0066B3;
    text-align: center;
    margin:4px;
	margin-bottom: 1em;
    background-color:#fdfdfd;
}

.boxed-info .name {
    font-style: italic;
    font-weight: 300;
    font-size: 2em;
    text-transform: uppercase;
}
.boxed-info .quantity {
    font-weight: 800;
    font-style: italic;
    font-size: 2.5em;
    padding: 0;
    margin: 0;
    margin-top: -16px;
}

.boxed-info-small {
    border: 2px solid #0066B3;
    padding: 6px 7px;
    color: #0066B3;
    text-align: center;
    margin:4px;
	margin-bottom: 1em;
    background-color:#fdfdfd;
	display: block;
    max-width: fit-content;
}

.boxed-info-small .name {
    font-weight: 500;
    font-size: 1em;
    text-transform: capitalize;
}

img#img-weight {
  height: 48px;
}

img#img-dose {
  height: 36px;
}

img#img-serving-per-container {
  height:40px;
}

.img-tabla-nutricional {
	max-width: 600px;
	width: 100%;
}

.background-color-hero {
  background-color: #f6f6f6;
}
  

.row {
  max-width: 100%;
  margin-left:0;
  margin-right:0;
}


.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl.col, .col-1, .col-10, .col-11, .col-12, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-auto, .col-lg, .col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-auto, .col-md, .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-auto, .col-sm, .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-auto, .col-xl, .col-xl-1, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-auto {
  padding-left: 6px;
  padding-right: 6px;
}


article {
    padding: 0;
}


.wp-block-buttons {
	text-align: center;
	margin: 0 auto;
}

ul.lista-ingredientes-esenciales li {
    list-style: none;
}

#joli-toc-wrapper nav#joli-toc .title #title-label {
	margin-bottom: 0.3em;
}

#joli-toc .joli-nav .item a.joli-h2 {
	padding: 8px !important;
    border-radius: 0 !important;
    margin: 0 !important;
}

#joli-toc-wrapper nav#joli-toc li a:hover {
	background: #eee !important;
}

#joli-toc-wrapper.joli-unfolded nav#joli-toc {
	padding: 20px 10px !important;
	border-radius: 0 !important;
}

#joli-toc-wrapper.joli-unfolded nav#joli-toc #joli-toc-header {
    margin-bottom: 1em;
    margin-top: 0.5em;
}

#joli-toc-wrapper nav#joli-toc {
    width: 100%;
}

#joli-toc-header {
	cursor: default !important;
}

#joli-toc-wrapper nav#joli-toc li.item {
    border-top: 1px solid #eee;
}


p#precio {
    font-size: 36px;
    font-weight: bolder;
    margin-top: 20px;
	margin-bottom: 0;
}
p#precio + p.precio_dosis {
	color: #666;
	font-size: 14px;
	margin-bottom: 0px;
}

#analisis-hero h3 {
    margin-top: 0;
}

#analisis-hero #stars {
  margin-bottom: 1em;
}

#producto_no_disponible {
  font-size: 1.2em;
  color: #dc3545;
  font-weight: 700;
  margin: 2em 0;
}


ul#listado-ingredientes-tags {
    display: inline-block;
    padding-left: 0;
}

ul#listado-ingredientes-tags li {
    list-style: none;
    display: inline-block;
    background-color: #fafafa;
    border: 1px solid #d66600;
    border-radius: 18px;
    padding: 3px 8px;
    margin-bottom: 8px;
    margin-right: 4px;
    color: white !important;
}

ul#listado-ingredientes-tags li:hover {
    background-color: #d666001f;
    cursor: pointer;
}

ul#listado-ingredientes-tags li a {
    color: #111;
	text-decoration: none;
}

ul#a_favor, ul#en_contra {
    padding-left: 0;
}

ul#a_favor li, ul#en_contra li {
    list-style: none;
}

ul#a_favor i.bi.bi-check{
    color: #28a745;
}

ul#en_contra i.bi.bi-x {
    color: #dc3545;
}

ul#a_favor i.bi.bi-check, ul#en_contra i.bi.bi-x {
    display: inline-block;
    font-size: 25px;
}

#pros h4 {
	color:#28a745;
}

#contras h4 {
	color: #dc3545;
}

span#valoracion_puntuacion {
    font-weight: 900;
    font-size: 5em;
    background-color: #ffa41c;
    border-radius: 50%;
    padding: 0px 0.4em;
    color: white;
}

.product-grid-box .estimulante, #puntuacion_final .estimulante{
  padding-left: 0 !important;
  margin-top: 0 !important;
}

#puntuacion_final .estimulante span {
  display: block;
}

#puntuacion_final .estimulante.high-stimulant i {
  color: #dc3545;
}

#puntuacion_final .estimulante.mid-stimulant i{
  color: #c05802
}

#puntuacion_final .estimulante.low-stimulant i{
  color: #17a2b8
}
#bloque_valoracion_final h4 {
	padding-top: 0;
}

#bloque_valoracion_final {
	border: 3px solid #ffa41c;
    padding: 4px 20px;
    margin-top: 2em;
    background-color: #fefefe;
}

#instagram {
  width: 480px;
  height: 600px;
  margin: 20px;
  position: relative;
}

#instagram h1 {
    padding: 20px;
    margin-top: 0;
    font-size: 50px;
}

#img-instagram {
    max-width: 300px;
   
    margin: 0;
    padding: 0;
}


#instagram .information-ingrendients{
  border: 2px solid #aaa;
  background-color: #fefefe;
}


#instagram .information-ingrendients {
  border: 2px solid #aaa;
  background-color: #fefefe;
  z-index: 999;
  position: absolute;
  bottom: 4px;
  left: 4px;
  right: 4px;
}

#instagram .information-ingrendients .level-item p:first-child{
  font-size: 17px !important;
}

#instagram #analisis-hero {
  height:100%;
  padding:0 !important;
}

.instagram-image-stars {
  position: absolute;
  left: -8px;
}

.instagram-boxes {
  position: absolute;
  right: 4px;
  width: 80%;
}

#instagram .boxed-info {
  float:right;
}

#instagram .boxed-info .name {
  font-size:24px;
}
#instagram .boxed-info .quantity {
  font-size:36px;
}

#instagram .mp-message {
  display: none;
}


.embed-responsive-16by9 {
	max-width: 780px;
	margin: 0 auto;
}

#gmaps.embed-responsive-16by9{
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
}

#gmaps{
  width: 100% !important;
}
#gmaps iframe{
  width: 100% !important;
  height: 100% !important;
  display:block;
}

.form-control {
	display: block;
  
    height: 40px;
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #111;
    background-clip: padding-box;
    margin-left: 0;
    margin-top: 8px;
}

.search-submit {
	color: #444;
    border: 1px solid #555;
    height: 30px;
    margin-top: -4px;
    border-radius: 0;
    padding: 2px 7px;
}

.search-submit:hover {
	color: 444;
}

.footer-widget {
    background-color: #f5f5f5;
    padding: 50px 10px 45px 10px;
}

.social-icons i{
  font-size: 52px;
  padding: 16px 36px;
}

.social-icons a{
  text-decoration: none;
}

.bi-facebook {
  color: #3b5998;
}

.bi-youtube {
  color: #c4302b;
}

.bi-instagram {
  color: #fb3958;
}

.total-ingredientes {
    padding-top: 9px;
    padding-bottom: 10px;
    background-color: #f8f9fa;
}

.ribbon-top {
  width: 200px;
  padding: 16px;
  position: absolute;
  text-align: center;
  color: #f0f0f0;
  top: -189px;
  right: -71px;
  transform: rotate(50deg);
  background-color: transparent;
  border-left: 49px solid transparent;
  border-right: 70px solid transparent;
  border-bottom: 58px solid transparent;
  height: 0;
}

.ribbon-top span {
  position: absolute;
  top: 36px;
  
  font-size: 1.2em;
  line-height: 1.3;
  color: #fefefe;
}

.ribbon-top-ventas {
  border-bottom-color: #ee0000;
  background-color: transparent;
}

.ribbon-top-ventas span {
  left: 10px;
}

.ribbon-top-economico {
  border-bottom-color: #4caf50;
  background-color: transparent;
}

.ribbon-top-economico span {
  left: -8px;
}

.ribbon-top-potente {
  border-bottom-color: #2f2f2f;
  background-color: transparent;
}

.ribbon-top-potente span {
  left: 4px;
}

.productlabel {
    border: 2px solid #eff2f4;
    font-weight: 700;
    line-height: normal;
    margin: 0 auto;
    padding: 4px 0 5px 0;
    display: block;
    max-width: 260px;
}

.productlabel>span {
    display: inline-block;
    padding: 10px 20px;
    color: #fefefe;
    font-size: 11px;
    line-height: 1.2em;
    vertical-align: top;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    
}

.productlabel a {
    color: #fafafa;
}

.top-ventas {
  background-color: #ee0000;
}

.top-economico {
  background-color: #4caf50;
}

.top-potente {
   background-color: #2f2f2f;
}

.top1 {
  border: 1px solid #232f3e;
  box-shadow: 0px 5px 21px 0px rgb(32 32 32 / 24%);
}

.display-5 {
	font-weight: 100;
}


.box-shadow {
	box-shadow: 0 1px 3px rgb(0 0 0 / 54%), 0 1px 2px rgb(0 0 0 / 24%);
}


/*--------------------------------------------------------------
# Media Query
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Notebook
--------------------------------------------------------------*/


.card-group {
  display: -webkit-flex;
  display: flex;
  flex-wrap: wrap;
  /* max-height:475px; <-- remove */
}


.card {
  background-color: #fefefe;
  margin: 14px auto !important;
  flex: 2;
  display: flex;           /* new */
  flex-direction: column;  /* new */
  text-align: center;  
  max-width: 400;
}

.card-block {
  padding-bottom: 10px;
  margin-bottom: 1em;
  flex: 1;                /* new */
}

.card-title {
  font-weight: 500 !important;
  margin-top: 0;
  padding-top: 0;
  font-size: 30px;
}

.card-highlights {
    font-size: 13px;
    color: #111;
    padding-top: 6px;
    font-weight: 600;
}

.card-footer {
  padding: 15px;
  background-color: rgb(255 202 212 / 10%);
}

.tarifa-precio {
  font-size: 3.5em;
  font-weight: 500;
  color: #111;
  letter-spacing: -2px;
}

.tarifa-precio ul {
  list-style: none;
  padding-left: 0;
  font-size: 20px;
  letter-spacing: normal;
}

.title-article-hero {
  color: #fefefe;
  text-shadow: 0 0 10px rgb(0 0 0 / 100%);
  font-weight: 700;
  margin-bottom: 0.5em;
}

.title-article-hero.background-color-hero {
 	background-size: cover !important;
	background-position: center center;
}

.title-article-hero .display-4 {
    font-size: 3.5rem;
 
}

.title-article-hero-excerpt {
	font-size: 1.5em;
    background-color: #333e;
    border-radius: 4px;
    padding: 12px 8px;
}
.title-article-hero-excerpt p {
	margin: 0;
}

.footer-articulo {
  border-top: 1px solid #eee;
  padding-top: 2em;
  margin-top: 2em;
  border-bottom: 1px solid #eee;
  margin-bottom: 1em;
  padding-bottom: 1em;
}

#dosis-efectiva {
    max-width: 400px;
    margin: 20px auto;
}

#dosis-efectiva thead, #dosis-efectiva tbody {
	border: 2px solid #9f1e0b;
}

#dosis-efectiva th {
    font-size: 1.3em;
    background-color: #9f1e0b;
}

#dosis-efectiva td {
	font-size: 1.2em;

}

#dosis-efectiva td, #dosis-efectiva th {
	border-top: 2px solid #9f1e0b;
    border-bottom: 2px solid #9f1e0b;
}

#comparadaperfecto {
	width: auto;
	max-width: 100%;
}

#comparadaperfecto th {
    background-color: transparent;
    color: #333;
    font-size: 1.3em;
    border-bottom: 2px solid #333;
    padding-bottom: 9px;
    padding-top: 10px;
}
#comparadaperfecto td {
	color: #fefefe;
	font-size: 1.2em;
}

.tr-green {
	background-color: #198754 !important;
}
.tr-orange {
	background-color: #ffc107 !important;
}
.tr-orange td {
	color: #111 !important;
}
.tr-red {
	background-color: #dc3545!important;
}

#comparadaperfecto th:nth-child(2), #comparadaperfecto th:nth-child(3), #comparadaperfecto td:nth-child(2), #comparadaperfecto td:nth-child(3) {
	text-align: right;
}


a.button-ambito {
  padding: 12px 8px;
  background-color: #eee;
  color: #333;
  display: block;
  margin-left: 15px;
  margin-right: 15px;
}

a.button-ambito:hover {
  text-decoration: none;
  filter: brightness(95%);
}

.section-ambitos {
  margin-top:1em;
  margin-bottom: 1em;
}

.background-pink-light {
  background: rgba(255, 202, 212, 0.1);
  
}

.container-sub-header-home {
	background-color: #bae6c32b;
  /*background-image: url(http://localhost/comnou/wp-content/themes/wp-bootstrap-starter/inc/assets/images/wallpaper2.jpg);
  background-size: cover;*/
}
.container-ultimos-recursos, .container-a-domicilio {
  background-color: #fcfcfc;
}

.container-ultimas-compras-recomendadas {
  background-color: #f5f5f5;
  border-top: 2px solid #87af3b8a;

}

.asterisco p {
  font-size: 13px;
  font-weight: 500;
  color: #111;
}

.container-soy-tere {
  background-color: #f1f9f3;
  border-bottom: 2px solid #ccc;
}


.card.valor-home {
  border: 0;
  background: transparent;
}

.valor-home .card-img-top img {
  width: 120px;
  height: 120px;
}

.bg-valor-oscuro {
  background-color: #f1f9f3;
  border-radius: 20px;
  padding-left:20px;
  padding-right:20px;
}

.bg-valor-claro {
  padding-left: 20px;
  padding-right:20px;
}

.img-valor {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 16 / 9;
    padding: 0;
    border-radius: 18px;
    margin: 10px;
}

p.reserva-email {
  font-size: 1.2em;
}

p.reserva-telf {
  font-size: 2em;
}

p.reserva-email a, p.reserva-telf a{
  font-weight: 500;
}

.btn-reserva {
  color: #fefefe;
  margin-top: -7px;
  padding-top: 10px;
  margin-left: 10px;
}


.ht_ctc_style.ht_ctc_chat_style span {
  font-size: 18px !important;
  color: #222;
  padding-top: 4px;
  padding-bottom: 4px;
  padding-left: 8px;
}

.container-footer-reserva {
  background-color: #bae6c32b;
  border-bottom: 2px solid #87af3b8a;
}

.container-servicios, .por-que-elegirnos {
  background-color: whitesmoke;
}

ul.tarifa {
  padding-left: 0;
}

ul.tarifa li {
  list-style: none;
  padding: 26px 16px;
  border-bottom: 1px solid #ddd;
}

ul.tarifa li:last-child {
  border-bottom: none;
}

ul.tarifa li:nth-child(odd) {
  background-color: #ecf3ed;
}

.tarifa h4 {
  padding: 0;
  margin: 0;
  font-size: 20px;
  padding-bottom: 12px;
  padding-top: 3px;
  color: #444;
}

.tarifa .descripcion {
  margin: 0;
  color: #111;
  font-weight: 300;
}

.tarifa-vehiculo {
  margin-top: 20px;
  margin-bottom: 20px;
}

.tarifa-vehiculo h3 {
  font-size: 32px;
  line-height: 25px;
  padding-top: 16px;
  padding-bottom: 13px;
  padding-left: 25px;
  margin-left: 16px;
  color: #fafafa;

}

.fancy {
  color:#fff;
  display:inline-block;
  position:relative;
  font-size:2em;
  line-height:2em;
  padding:0.5em 1em;
  z-index:0;
}

.fancy::before {
  content: "";
  background-color: #444;
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
  transform: skew(340deg);
}



#cookies-eu-banner {
	padding: 30px 10px;
}
#ht-ctc-chat {
	z-index:999 !important;
}

.button-tarifa {
	background-color: #555;
}
.duros-cleaning {
  text-align: center;
  margin: 1em 0;
}

.duros-cleaning h2.subtitle {
  font-size: 1.25rem;
  color: #222;
  font-weight: 400;
  margin-top: 0.5em;
  position: relative;
  display: inline-block;
  padding-bottom: 0.25em;
}

.duros-cleaning h2.subtitle::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 60%;
  height: 2px;
  background-color: #28a745; /* Color verde para evocar limpieza ecológica */
  transform: translateX(-50%);
}

.card-media {
  padding-top: 0; height: 200px;
}



#servicios .card img {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 16 / 9;
    max-height: unset;
    padding: 0;
      border-top-right-radius: 8px;
    border-top-left-radius: 8px;
}

.img-destacado {
      border-radius: 8px;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    max-height: unset;
    width: 100%;
      transition: transform 0.4s ease, filter 0.4s ease; /* transición suave */

}
.img-destacado:hover {
 transform: scale(1.02); /* leve aumento para destacar */
  filter: drop-shadow(2px 4px 6px rgba(0,0,0,0.3)); /* sombra suave */
}


.badge-secondary {
    background-color: #f2f9f3;
    color: #111;
        font-weight: 400;
    padding: 6px 10px;
    margin-bottom: 0.9em;
    margin-top: 0;
}

i.bi.bi-check2 {
    padding-right: 0.5em;
    color: green;
}

ul.list-unstyled.card-includes, .card-summary {
    font-size: 0.9em;
    text-align: left;
}

.badge-duration {
  text-transform: lowercase;
}

.porque-elegirnos {
  list-style: none;
  padding: 0;
  margin: 0;
}

.porque-elegirnos li {
  margin-bottom: 8px;
}

.porque-elegirnos .check {
  margin-right: 8px;
  font-size: 1.2em;
}


.por-que-elegirnos-titulo {
  margin-top:0;
  padding-top: 0;
}

.text-muted {
 color: #444 !important;
}


@media (max-width: 768px) {
	.home-hero .subtitle {
		font-size: 24px;		
	}
	h1, h1 span {
		font-size: 36px;
		letter-spacing: 0;
	}
	.subtitle {
		margin-top: 1em;
		margin-bottom: 0;
	}
}

#gmaps {
	    border: 0;
    box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .675) !important;
}

@media screen and (min-width: 37.5em) {
  .menu-toggle {
    display: none;
  }
 
}
@media screen and (min-width: 769px) {
  .dropdown-menu li > .dropdown-menu {
    right: -9.875rem;
    top: 1.375rem;
  }
}
@media screen and (max-width: 991px) {
  .navbar-nav .dropdown-menu {
    border: medium none;
    margin-left: 1.250rem;
    padding: 0;
  }

  .dropdown-menu li a {
    padding: 0;
  }

  #masthead .navbar-nav > li > a {
    padding-bottom: 0.625rem;
    padding-top: 0.313rem;
  }

  .navbar-light .navbar-toggler {
    border: medium none;
    outline: none;
  }
}


@media only screen and (max-width: 768px) {
  #logo_teacheret_corazones {
    width: 216px;
  }
  h1{
    font-size: 32px;
    padding: 0;
    margin-top:0;
    margin-bottom:12px;
  }
}



@media only screen and (max-width: 960px) {
  .fusion-body .fusion-blog-layout-medium .fusion-post-slideshow {
    width: 100%;
  }
  .fusion-blog-layout-grid .fusion-post-grid {
        max-width: 100% !important;
        width: auto !important;
    }
    .product-box-compatible-horizontal {
        padding-left: 1.5em;
    }
	
}

@media only screen and (max-width: 640px) {
 
	#logo {
		margin-left: 0;
	}
  
	
    .center_on_mobile {
        text-align: center;
    }
    
    .page-template-portada .fusion_builder_column_3_4 {
        width: 100% !important;
        margin: 0 !important;
    }
    table#tabla_comparativa td:nth-child(4),table#tabla_comparativa td:nth-child(5),table#tabla_comparativa td:nth-child(6),table#tabla_comparativa td:nth-child(7),table#tabla_comparativa td:nth-child(8), table#tabla_comparativa th:nth-child(4),table#tabla_comparativa th:nth-child(5),table#tabla_comparativa th:nth-child(6),table#tabla_comparativa th:nth-child(7),table#tabla_comparativa th:nth-child(8) {
        display: none;
    }
	
}


@media screen and (max-width: 1199px) {
  .navbar-dark .dropdown-item {
    color: #fefefe;
  }
  .navbar-nav .dropdown-menu {
    background: transparent;
    box-shadow: none;
    border: none;
  }
   #masthead .navbar-nav > li {
    padding-bottom: 0.4rem;
    padding-top: 0.4rem;
    text-align: center;
  }
  #masthead .navbar-nav > li > a {
    display: block;
    text-align: center;
  }
}


/* ====== HERO DE CATEGORÍA ====== */
#analisis-hero {
  position: relative;
  min-height: 100px;             /* ajusta a tu gusto */
  display: flex;
  align-items: center;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

/* Cuando hay imagen cargada por inline-style (background-image) */
#analisis-hero::before {
  /* Overlay para legibilidad: degradado sutil vertical */
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.50) 0%,
    rgba(0,0,0,0.30) 35%,
    rgba(0,0,0,0.50) 100%
  );
  pointer-events: none;
}

/* Cuando NO hay imagen: fondo de color liso */
#analisis-hero.no-image {
  background: #0f172a; /* azul oscuro (buen contraste) */
  color: #fff;
}

/* Asegurar que el contenido quede por encima del overlay */
#analisis-hero .container,
#analisis-hero .row,
#analisis-hero .col {
  position: relative;
  z-index: 1;
}

/* Tipografía del título del hero */
#analisis-hero .title-articulo {
  color: #fff;
  margin: 0;
  line-height: 1.2;
  text-shadow: 0 2px 8px rgba(0,0,0,0.75); /* mejora legibilidad */
  font-weight: 700;
  letter-spacing: 0.8px;

}

/* Pre-título (nombre del padre) y título */
#analisis-hero .pretitle-category {
  display: block;
  font-size: 1.25rem;
  letter-spacing: 0.8px;
  margin-bottom: .25rem;
  color: #fafafa; /* gris claro */
}

/* Responsive */
@media (min-width: 576px) {
  #analisis-hero { min-height: 200px; }
  #analisis-hero .title-category { font-size: 2.25rem; }
}
@media (min-width: 768px) {
  #analisis-hero { min-height: 220px; }
  #analisis-hero .title-category { font-size: 2.6rem; }
}
@media (min-width: 992px) {
  #analisis-hero { min-height: 300px; }
  #analisis-hero .title-category { font-size: 3rem; }
}

/* ====== DESCRIPCIÓN DE ARCHIVO ====== */
.archive-description {
  max-width: 850px;
  margin: 1.5rem auto 2rem;
  font-size: 1.05rem;
  line-height: 1.7;
  color: #374151; /* gris legible */
}
.archive-description p:last-child { margin-bottom: 0; }

/* ====== GRID DE TRABAJOS ====== */
.content-area .row > [class*="col"] {
  margin-bottom: 1.25rem;
}

#analisis-hero.has-image.hero-dark::before {
  background: linear-gradient(to bottom, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.55) 40%, rgba(0,0,0,0.65) 100%);
}

.site-footer {
  background-color: #131a22;
  color: #fefefe;
  padding-bottom: 3em;
}

.site-footer a {
  color: #fefefe;  
}

span.pretitle-category {
    position: relative;
    display: inline-block;
    font-size: 0.9em;
    font-weight: 500;
}


.post ul {
  list-style: none;
  padding-left: 0;
}

.post ul li {
  position: relative;
    padding-left: 1.8rem;
    margin-bottom: 12px;
    margin-top: 12px;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.post ul li::before {
  content: "\f26e"; /* Código del icono bi-check-circle-fill */
  font-family: "bootstrap-icons";
  position: absolute;
  left: 0;
  top: 0;
  color: #28a745; /* Verde Bootstrap */
  font-size: 26px;
  line-height: 1;
}

.btn {
  padding: 16px;
  border-radius: .75rem;
}

#masthead .navbar-nav > li:last-child > a, .button-reserva, .btn-primary, .btn-primary:not(:disabled):not(.disabled).active, .btn-primary:not(:disabled):not(.disabled):active, .show>.btn-primary.dropdown-toggle  {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  color: #fefefe;

  border-radius: .75rem;
}

#masthead .navbar-nav > li:last-child > a {
    background-color: #333;
  border-color: #333;
}


.quienes-somos {
  background-color: #111;
  color: #fdfdfd;
}

.subtitle {
    color: #fefefe;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.9);
    font-size: 1.4em;
    font-weight: 400;
    letter-spacing: -0.5px;
}

.servicio-card {
  text-align: center;
}
.frase-destacada {
    font-size: 1.6rem;
    text-align: center;
    color: #333;
    margin-top: 25px;
    margin-bottom: 0;
}

.lista-destacados {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.lista-destacados li {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  font-weight: 500;
  color: #333;
}

.lista-destacados i {
  color: #28a745; /* Verde Bootstrap */
  font-size: 1.1em;
}


.destacados i {
  font-size: 2em;
  color: #dc3545!important;
}

.entry-content.destacados, .entry-content.frase {
  background-color: whitesmoke;
}

h3.por-que-elegirnos-titulo.mt-3 {
  color: #444;
}

.destacado-item {
    background-color: #fdfdfd;
    width: 100%;
    border-radius: 12px;
    margin: 2px 0px;
    padding: 8px;
    box-shadow: rgba(0, 0, 0, 0.02) 0px 1px 3px 0px, rgba(139, 0, 0, 0.35) 0px 0px 0px 1px;
}

.container-fluid.cta-black {
    background-color: #111;
    color: #fdfdfd;
}

.cta-black a {
    color: #fdfdfd;
}

.wpcf7-submit {
  min-width: 40%;
}

.dm-section-wave {
    position: relative;
    background: #000;      /* fondo de la sección (ajusta a tu diseño) */
    color: #fff;
    overflow: hidden;
}

.dm-section-wave-animated {
    position: relative;
    background: #000;  /* fondo principal */
    color: #fff;
    overflow: hidden;
}

/* Contenedor de las olas en la parte inferior */
.dm-waves {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 200%;      /* más ancho para poder desplazar la ola */
    height: 120px;
    pointer-events: none;
}

/* Capas de ola (3 capas para profundidad) */
.dm-wave-layer {
    position: absolute;
    left: 0;
    width: 200%;
    height: 100%;
    background-repeat: repeat-x;
    opacity: 0.55;
    animation: dmWaveMove 12s linear infinite;
}


.div-eventos {
      background: linear-gradient(135deg, rgba(0, 255, 255, 0.08), rgba(255, 0, 128, 0.08)),
              #0a0a0a;
}

.img-evento{
  width:100%;
  height:auto;
  object-fit:contain;
  display:block;
  margin:auto;
  border-radius: 16px;
}

/* Card de eventos más visual */
.event-card {
    background: #111;
    border-radius: 12px;
    overflow: hidden;
    border: 5px solid #00E5FF;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.event-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 0 35px rgba(0, 255, 255, 0.45);
}

.event-image-wrapper {
  position: relative;
  overflow: hidden;
}

.event-image-wrapper img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 819 / 1024;
  object-fit: cover;
}

/* Badge de fecha arriba a la izquierda */
.event-date-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  width: 52px;
  height: 52px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.85);
  border: 2px solid #f70673;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.event-date-day {
  font-size: 1.1rem;
  font-weight: 700;
}

.event-date-month {
  font-size: 0.8rem;
  text-transform: uppercase;
}

/* Fecha larga encima del título */
.event-date-full {
font-size: 0.9rem;
    text-transform: uppercase;
    font-weight: 500 !important;
    color: #cfcacd;;
}

/* Lugar */
.event-place {
  font-size: 1em
}

.event-place-icon {
  margin-right: 6px;
}

/* Botón de comprar */
.event-button {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}


.btn-outline-secondary{
  border-color: #ddd;
  color: #ddd;
  border-width: 2px;
}

.btn-outline-secondary:hover{
  background-color: #eee;
  border-color: #ddd;
  color:#111;
  box-shadow: 0 0 12px #eee;
}


#masthead .navbar-nav > li:last-child > a {
    border-radius: 0.5rem;
    letter-spacing: -0.5px;
}

/* CONTENEDOR DEL EFECTO */
.container-shiny-effect {
    position: relative;
    overflow: hidden;
}

/* LÍNEA SHINY */
.container-shiny-effect::before {
    content: "";
    position: absolute;
    top: 0;
    left: -150%;
    width: 120%;
    height: 100%;
    background: linear-gradient(
        120deg,
        rgba(255,255,255,0) 0%,
        rgba(255,255,255,0.5) 50%,
        rgba(255,255,255,0) 100%
    );
    transform: skewX(-20deg);
    animation: shiny-move 3s ease-in-out infinite;
}


/* ANIMACIÓN */
@keyframes shiny-move {
    0% {
        left: -150%;
    }
    50% {
        left: 150%;
    }
    100% {
        left: 150%;
    }
}



.btn-hero {
  
}

@keyframes gradientShift {
  0% { background-position: 0%; }
  50% { background-position: 100%; }
  100% { background-position: 0%; }
}

/* Sección biografía */
#quien-soy {
  background: #8fa3b221; /* gris claro elegante */
  padding: 50px 0;
  color: #111;
}

/* Títulos dentro de la bio */
#quien-soy h2,
#quien-soy h3,
#quien-soy p {
  color: #111;
}

/* Imagen del DJ */
.bio-photo {
  border-radius: 14px;
  box-shadow: 0 10px 35px #41e4fd33;
  transition: transform .25s ease, box-shadow .25s ease;
  max-width: 100%;
}

/* Efecto hover: profesional, no exagerado */
.bio-photo:hover {
  transform: scale(1.03);
  box-shadow: 0 16px 45px #41e4fd50;
}

/* Caja con bullet points */


/* Lista interior */
.bio-highlight-box ul {
  padding-left: 1.2rem;
  margin: 0;
}

.bio-highlight-box li {
  margin-bottom: 0.45rem;
  font-size: 0.95rem;
}

/* Responsive */
@media (max-width: 768px) {
  #quien-soy {
    text-align: center;
  }

  .bio-photo {
    margin-top: 20px;
    margin-bottom: 20px;
  }
}




/* Botón secundario */
.btn-outline-dark {
  border-width: 2px;
  background-color: #3333330c;
}

.btn-outline-dark:hover {
  background: #111;
  color: #fff;
  box-shadow: 0 0 12px #11111150;
}

.btn-outline-light:hover {
    box-shadow: 0 0 12px #ffffff99;

}

.gap-3 {
  gap: 1rem;
}

.btn {
  text-transform: uppercase;
    font-weight: 900 !important;
    border-width: 2px;
    letter-spacing: 0.33px;
    border-radius: 8px;
    padding: 12px 24px;
    transition: all .25s 
ease, color .25s 
ease;
}

#proximos-eventos {
  position: relative;
  background: #000;
  padding: 60px 0;
  overflow: hidden;
}

#proximos-eventos::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='300' height='80' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 40 Q30 0 60 40 T120 40 T180 40 T240 40 T300 40' stroke='%23ffffff15' stroke-width='2' fill='none'/%3E%3C/svg%3E");
  background-size: 300px 80px;
  opacity: 0.8; /* intensidad del patrón */
  pointer-events: none;
}


/* Sección servicios / tu evento */
#servicios {
  background: #ef24750a; /* claro para contrastar con secciones oscuras */
  color: #111;
}

#redes h2, #famosos-home h2, #quien-soy h2, #servicios h2 {
  font-size: 40px;
  font-weight: 900;
}
#servicios h2 {
  color: #ef2475;
}

/* Cards de servicios */
.servicio-card {
  border-radius: 14px;
  border: none;
  box-shadow: 0 8px 25px rgba(0,0,0,0.12);
  margin: 0 !important;
  background-color: #ffedf4;
  text-shadow: none;
  font-size: 16px;
  color: #111;
  border: 5px solid #00E5FF;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#servicios {
  background:
      linear-gradient(rgba(0,0,0,.65), #111),
      url('inc/assets/images/discoteca.jpg') center/cover no-repeat;
    color: #fff;
    text-shadow: 2px 2px 4px #000;
}

.servicio-card:hover {
  box-shadow: 0 14px 35px rgba(0,0,0,0.22);
}

.servicio-card h3 i {
  font-size: 1.2rem;
  vertical-align: middle;
}

/* Listas dentro de las cards */
.servicio-card ul li {
  position: relative;
  margin-bottom: 0.25rem;
  font-size: 0.95rem;
}


/* Bloque Famosos en la home */
#famosos-home {
  background: #111;          /* fondo oscuro para que las fotos destaquen */
  color: #fff;
}

#famosos-home h2,
#famosos-home p, .famoso-link:hover {
  color: #fefefe;
}



/* Tarjetas de famosos */
.famoso-card {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
}

.famoso-card img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .3s ease;
}

.famoso-link {
  display: block;
  position: relative;
}

/* Overlay con el nombre del famoso */
.famoso-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10,10,10,0.8), transparent);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 8px;
  opacity: 0;
  transition: opacity .3s ease;
}

.famoso-nombre {
  font-size: 0.9rem;
  font-weight: 600;
  text-align: center;
  text-transform: uppercase;
}

/* Efecto hover */
.famoso-card:hover img {
  transform: scale(1.05);
}

.famoso-card:hover .famoso-overlay {
  opacity: 1;
}



.social-icons i {
  font-size: 1.9rem;
  color: #fff;
  transition: 0.3s ease;
}

.social-icons i {
  font-size: 1.8rem;
  color: #fff;
  transition: 0.3s ease;
}

/* Instagram */
footer .instagram:hover {
  text-shadow: 0 0 10px #e1306c,
               0 0 18px #e1306c,
               0 0 28px #e1306c;
}

/* TikTok */
footer  .tiktok:hover {
  text-shadow: 0 0 10px #ff0050,
               0 0 18px #ff0050,
               0 0 28px #00f2ea;
}

/* YouTube */
footer  .youtube:hover {
  text-shadow: 0 0 10px #ff0000,
               0 0 20px #ff0000,
               0 0 30px #ff0000;
}


/* Tarjeta base */
.social-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  border-radius: 18px;
  text-decoration: none !important;
  color: #111;
  border: 2px solid #ddd;
  transition: .3s ease;
}

.social-card.instagram {
  border-color: #E1306C33;
}
.social-card.tiktok {
  border-color: #00E5FF33;
}

.social-card.youtube {
  border-color: #FF000033;
}


.social-card i {
  font-size: 3rem;
  opacity: 0.9;
  transition: .3s ease;
}

a.social-card:hover {
  color: #111 !important;
    transform: translateY(-6px);
}

/* -------- HOVERS POR RED SOCIAL -------- */

/* INSTAGRAM — Glow rosa */
.social-card.instagram:hover {
  border-color: #E1306C;
  box-shadow: 0 0 12px #E1306C,
              0 0 22px rgba(225,48,108,0.5),
              inset 0 0 12px rgba(225,48,108,0.3);

    background-color: #E1306C11;
}


/* TIKTOK — Glow cian + fucsia */
.social-card.tiktok:hover {
  border-color: #00E5FF;
  box-shadow: 0 0 14px #00E5FF,
              0 0 24px rgba(0,229,255,0.7),
              inset 0 0 14px rgba(0,229,255,0.4);
  background-color: #00E5FF11;
}


/* YOUTUBE — Glow rojo */
.social-card.youtube:hover {
  border-color: #FF0000;
  box-shadow: 0 0 12px #FF0000,
              0 0 22px rgba(255,0,0,0.6),
              inset 0 0 12px rgba(255,0,0,0.4);
  background-color: #FF000011;
}



/* Imagen a la derecha */
.contacta-photo {
  border-radius: 16px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.25);
  max-width: 100%;
}

/* Responsive */
@media (max-width: 768px) {
  .contacta-photo {
    margin-top: 30px;
  }
}



form label {
  width: 90%;
}



.home-hero {
  position: relative;
  color: #fff;
  display: flex;
  align-items: flex-start;
  padding-top: 80px;
  padding-bottom: 80px;
  overflow: hidden;
}

/* Fondo animado (debajo de todo) */
.home-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('inc/assets/images/fondo-hero2.jpg')
              center/cover no-repeat;
  z-index: 0; /* Fondo más bajo */
  transform: scale(1.15);
  animation: heroZoom 26s ease-in-out infinite alternate;
}

/* Degradado encima del fondo */
.home-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    rgba(0,0,0,0.15),
    rgba(0,0,0,0.65)
  );
  z-index: 1; /* Degradado por encima del fondo, pero debajo del texto */
}

/* Contenido por encima del degradado */
.home-hero .container {
  position: relative;
  z-index: 2;
}

/* Animación zoom */
@keyframes heroZoom {
  0% {
    transform: scale(1.05) translate3d(0, 0, 0);
  }
  100% {
    transform: scale(1.12) translate3d(2%, 2%, 0);
  }
}

/* Opcional: desactivar animación en móvil */
@media (max-width: 768px) {
  .home-hero::before {
    animation: none;
    transform: scale(1.05);
  }
}
.home-hero h1 {
  animation: pulseGlow 10s ease-in-out infinite;
}

@keyframes pulseGlow {
  0% {
    text-shadow: 0 0 6px rgba(0,229,255,0.15);
  }
  33% {
    text-shadow: 0 0 14px rgba(0,229,255,0.5);
  }
  66% {
    text-shadow: 0 0 6px rgba(247,6,115,0.7);
  }
  100% {
    text-shadow: 0 0 6px rgba(247,6,115,0.17);
  }
}


/* ===========================
   PALETA BASE (CUSTOM PROPERTIES)
   =========================== */
:root {
  --color-primary:        #8FA3B2;  /* azul gris claro */
  --color-primary-dark:   #7A91A1;
  --color-secondary:      #DCC9A3;  /* beige arena claro */
  --color-secondary-dark: #C9B488;
  --color-accent:         #D59C86;  /* terracota clara */
  --color-bg:             #F7F4EF;  /* fondo principal claro */
  --color-bg-alt:         #F0E9DF;  /* fondo alterno suave */
  --color-dark:           #3A3A3A;  /* texto */
  --color-light:          #FFFFFF;  /* blanco */
}

/* ===========================
   BODY / GENERALES
   =========================== */
body {
  background-color: var(--color-bg);
  color: var(--color-dark);
}

a {
  color: var(--color-primary);
}

a:hover,
a:focus {
  color: var(--color-accent);
  text-decoration: none;
}

/* ===========================
   NAVBAR
   =========================== */

.navbar-brand,
.navbar-nav .nav-link {
  color: var(--color-dark) !important;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus,
.navbar-nav .nav-link.active {
  color: var(--color-accent) !important;
}

/* Si usas .navbar-light, ajustamos los colores */
.navbar-light .navbar-brand,
.navbar-light .navbar-nav .nav-link {
  color: var(--color-dark);
}

/* ===========================
   BOTONES
   =========================== */

/* Primary */
.btn-primary {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-light);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary:active:focus {
  background-color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: var(--color-light);
}

/* Secondary */
.btn-secondary {
  background-color: var(--color-secondary);
  border-color: var(--color-secondary);
  color: var(--color-dark);
}

.btn-secondary:hover,
.btn-secondary:focus,
.btn-secondary:active,
.btn-secondary:active:focus {
  background-color: var(--color-secondary-dark);
  border-color: var(--color-secondary-dark);
  color: var(--color-dark);
}

/* Botón outline con el acento melocotón */
.btn-outline-primary {
  color: var(--color-accent);
  border-color: var(--color-accent);
  background-color: #11111199;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active,
.btn-outline-primary:active:focus {
  color: var(--color-light);
  background-color: var(--color-accent);
  border-color: var(--color-accent);
}

/* ===========================
   CARDS
   =========================== */
.card {
  background-color: var(--color-light);
  border: 1px solid rgba(143, 163, 178, 0.25); /* primary muy suave */
  border-radius: 0.75rem;
}

.card-header {
  background-color: var(--color-bg-alt);
  color: var(--color-dark);
  border-bottom: 1px solid rgba(220, 201, 163, 0.7);
}

.card-title {
  color: var(--color-primary);
}

.card-text {
  color: var(--color-dark);
}

/* ===========================
   ALERTS
   (más suaves y acordes con la paleta)
   =========================== */

.alert {
  border-radius: 0.5rem;
}

/* Primary - tono azul grisáceo suave */
.alert-primary {
  color: var(--color-dark);
  background-color: rgba(143, 163, 178, 0.15);
  border-color: rgba(143, 163, 178, 0.5);
}

/* Secondary - tono arena claro */
.alert-secondary {
  color: var(--color-dark);
  background-color: rgba(220, 201, 163, 0.18);
  border-color: rgba(220, 201, 163, 0.55);
}

/* Success - verde apagado */
.alert-success {
  color: var(--color-dark);
  background-color: rgba(164, 186, 152, 0.18);
  border-color: rgba(164, 186, 152, 0.55);
}

/* Danger - usamos el acento melocotón más intenso */
.alert-danger {
  color: var(--color-dark);
  background-color: rgba(213, 156, 134, 0.18);
  border-color: rgba(213, 156, 134, 0.6);
}

/* Info */
.alert-info {
  color: var(--color-dark);
  background-color: rgba(143, 163, 178, 0.12);
  border-color: rgba(143, 163, 178, 0.45);
}

/* Warning */
.alert-warning {
  color: var(--color-dark);
  background-color: rgba(234, 208, 154, 0.18);
  border-color: rgba(234, 208, 154, 0.55);
}

/* ===========================
   UTILIDADES DE COLOR
   =========================== */

.bg-primary    { background-color: var(--color-primary) !important; }
.bg-secondary  { background-color: var(--color-secondary) !important; }
.bg-light      { background-color: var(--color-light) !important; }
.bg-dark       { background-color: var(--color-dark) !important; }
.bg-accent     { background-color: var(--color-accent) !important; }
.bg-page       { background-color: var(--color-bg) !important; }
.bg-page-alt   { background-color: var(--color-bg-alt) !important; }

.text-primary   { color: var(--color-primary) !important; }
.text-secondary { color: var(--color-secondary) !important; }
.text-accent    { color: var(--color-accent) !important; }
.text-dark      { color: var(--color-dark) !important; }
.text-light     { color: var(--color-light) !important; }

/* Secciones alternas para la maquetación (home, galería, etc.) */
.section-alt {
  background-color: var(--color-bg-alt);
}

/* ===========================
   FORMULARIOS
   =========================== */

.form-control {
  background-color: var(--color-light);
  border: 1px solid rgba(143, 163, 178, 0.45);
  color: var(--color-dark);
  border-radius: 0.4rem;
}

.form-control:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 0.2rem rgba(143, 163, 178, 0.35);
}

::placeholder {
  color: rgba(58, 58, 58, 0.5);
}

/* Labels de formularios */
.form-group label {
  color: var(--color-dark);
}

/* ===========================
   BREADCRUMB, PAGINACIÓN, ETC.
   =========================== */

.breadcrumb {
  background-color: transparent;
}

.breadcrumb-item + .breadcrumb-item::before {
  color: rgba(58, 58, 58, 0.4);
}

.page-link {
  color: var(--color-primary);
  background-color: var(--color-light);
  border: 1px solid rgba(143, 163, 178, 0.4);
}

.page-link:hover {
  color: var(--color-light);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.page-item.active .page-link {
  color: var(--color-light);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

/* ===========================
   IMÁGENES DE GALERÍA (base suave)
   =========================== */

.gallery-item img,
.img-thumbnail {
  border-radius: 0.75rem;
  border: 1px solid rgba(143, 163, 178, 0.35);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.gallery-item img:hover,
.img-thumbnail:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
}

/* Opcional: pequeños “marcos” visuales */
.gallery-frame {
  padding: 0.75rem;
  background-color: var(--color-bg-alt);
  border-radius: 1rem;
  border: 1px solid rgba(220, 201, 163, 0.6);
}


/* ===== GALERÍA GENERAL ===== */

.gallery-obras {
  margin-top: 3rem;
}

/* Tarjeta de obra más elegante */
.obra-card {
  display: block;
  text-decoration: none;
  color: inherit;
  border-radius: 18px;
  overflow: hidden;
  position: relative;
  transition: transform .35s ease, box-shadow .35s ease;
  will-change: transform, box-shadow;
}

.obra-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.18);
}

/* Marco de la imagen con proporción fija (vertical tipo cuadro) */
.obra-thumb {
  position: relative;
  width: 100%;
  padding-top: 130%; /* cambia a 100% si quieres cuadrado */
  overflow: hidden;
  background: #f6f1eb;
}

/* Imagen: recorte elegante + animación suave */
.obra-thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .7s ease, filter .7s ease;
  will-change: transform, filter;
}

/* Efecto: zoom ligero y más contraste al pasar el ratón */
.obra-card:hover .obra-thumb img {
  transform: scale(1.06);
    transform: translateY(-8px) rotate(-0.4deg);
  filter: saturate(1.08) contrast(1.05);
}

.obra-overlay-title{
  font-weight: 500;
  letter-spacing: .02em;
}

/* ===== OVERLAY CON TÍTULO Y DETALLES ===== */

.obra-overlay {
  position: absolute;
  inset: 0; /* top, right, bottom, left = 0 */
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.25rem;
  padding: 8px;
  background: linear-gradient(
    to top,
    rgba(12, 8, 5, 0.78),
    rgba(12, 8, 5, 0.35),
    transparent 55%
  );
  opacity: 1;
  transform: translateY(10px);
  transition: opacity .35s ease, transform .35s ease;
}

/* Hacemos visible el overlay al hover */
.obra-card:hover .obra-overlay {
  opacity: 1;
  transform: translateY(0);
}

/* Título dentro del overlay */
.obra-overlay-title {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 26px 6px;
  text-transform: uppercase;
  color: #fdf7ef;
}

/* Meta (técnica, formato, año…) */
.obra-overlay-meta {
  font-size: 0.82rem;
  color: rgba(255, 245, 233, 0.9);
}

/* ===== DETALLE EXTRA: “MARCO” SUTIL ===== */

/* Un pequeño marco claro alrededor que recuerda a un passepartout */
.obra-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.65);
  pointer-events: none;
  opacity: 0;
  transition: opacity .35s ease;
}

.obra-card:hover::before {
  opacity: 1;
}

.btn-hero {
  background-color: #11111199;
  color: var(--color-primary);
}

.obra-pagination ul {
  display: flex;
  justify-content: center;
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.obra-pagination li { margin: 0 .25rem; }

.obra-pagination a,
.obra-pagination span {
  display: block;
  padding: .5rem .75rem;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 10px;
  text-decoration: none;
}

.obra-pagination .current {
  border-color: rgba(0,0,0,.25);
  font-weight: 600;

  
}



/* =========================
   Single Obra (AISLADO)
   Solo afecta dentro de .single-obra-page
   ========================= */

.single-obra-page {
  background: #f7f6f4;
}

.single-obra-page .obra-title {
  font-size: 2.2rem;
  font-weight: 500;
  letter-spacing: -0.02em;
  margin-bottom: .6rem;
  color: #1e1e1e;
}

.single-obra-page .obra-subtitle {
  max-width: 820px;
  margin: 0 auto;
  font-size: 1.05rem;
  line-height: 1.7;
  color: rgba(30,30,30,0.70);
}

/* Media (visor) */
.single-obra-page .obra-media { max-width: 980px; }

.single-obra-page .obra-carousel {
  background: #f7f6f4;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,0.12);
}

.single-obra-page .obra-carousel .carousel-item {
  background: #f7f6f4;
}

.single-obra-page .obra-carousel .carousel-item img {
  object-fit: contain;
  max-height: 72vh;
  background: #f7f6f4;
}

/* Etiqueta discreta sobre la imagen */
.single-obra-page .obra-caption {
  position: absolute;
  left: 14px;
  bottom: 12px;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(30,30,30,0.65);
  background: rgba(247,246,244,0.88);
  padding: 6px 10px;
  border-radius: 999px;
}

/* Controles carrusel */
.single-obra-page .obra-carousel .carousel-control-prev,
.single-obra-page .obra-carousel .carousel-control-next {
  width: 10%;
  opacity: .55;
}
.single-obra-page .obra-carousel .carousel-control-prev:hover,
.single-obra-page .obra-carousel .carousel-control-next:hover {
  opacity: .9;
}

/* Thumbnails */
.single-obra-page .obra-thumbs {
  display: flex;
  gap: 10px;
  margin-top: 14px;
  overflow-x: auto;
  padding-bottom: 6px;
}

.single-obra-page .obra-thumb {
  border: 0;
  padding: 0;
  background: transparent;
  border-radius: 12px;
  overflow: hidden;
  flex: 0 0 auto;
  width: 76px;
  height: 76px;
  opacity: .86;
  box-shadow: 0 10px 20px rgba(0,0,0,0.10);
  transition: transform .18s ease, opacity .18s ease;
}

.single-obra-page .obra-thumb:hover {
  opacity: 1;
  transform: translateY(-2px);
}

.single-obra-page .obra-thumb:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(30,30,30,0.15), 0 10px 20px rgba(0,0,0,0.10);
}

.single-obra-page .obra-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.single-obra-page .obra-amb-note {
  margin-top: 12px;
  font-size: .95rem;
  line-height: 1.6;
  color: rgba(30,30,30,0.60);
}

/* Panel derecho */
.single-obra-page .obra-panel, .single-exposicion-page .obra-panel {
  background: rgba(255,255,255,0.75);
  border: 1px solid rgba(30,30,30,0.07);
  border-radius: 16px;
  padding: 22px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}

.single-obra-page .obra-panel-title, .single-exposicion-page .obra-panel-title {
  font-size: 1.2em;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #444;
  margin: 0 auto;
  margin-bottom: 1em;
}

.single-obra-page .obra-nota, .single-exposicion-page .obra-nota{
  font-size: 1rem;
  line-height: 1.75;
  color: #111;
  margin-bottom: 16px;
}

.single-obra-page .obra-ficha, .single-exposicion-page .obra-ficha{
  list-style: none;
  padding: 0;
  margin: 0 0 18px 0;
  border-top: 1px solid rgba(30,30,30,0.08);
  border-bottom: 1px solid rgba(30,30,30,0.08);
}

.single-obra-page .obra-ficha li, .single-exposicion-page .obra-ficha li {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 0;
  border-top: 1px solid rgba(30,30,30,0.06);
}

.single-obra-page .obra-ficha li:first-child, .single-exposicion-page .obra-ficha li:first-child { border-top: 0; }

.single-obra-page .obra-ficha li span, .single-exposicion-page .obra-ficha li span {
  color: #111;
  font-size: 1rem;
}

.single-obra-page .obra-ficha li strong, .single-exposicion-page .obra-ficha li strong {
  color: rgba(30,30,30,0.85);
  font-weight: 600;
  font-size: .95rem;
  text-align: right;
}

/* Estado */
.single-obra-page .obra-status {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}

.single-obra-page .obra-badge {
  display: inline-block;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.single-obra-page .obra-badge--ok {
  background: rgba(30,30,30,0.08);
  color: rgba(30,30,30,0.80);
}

.single-obra-page .obra-badge--no {
  background: rgba(30,30,30,0.05);
  color: rgba(30,30,30,0.55);
}

.single-obra-page .obra-precio {
  font-size: 1.1rem;
  font-weight: 600;
  color: rgba(30,30,30,0.85);
}

.single-obra-page .obra-precio--muted {
  font-weight: 500;

}

.single-obra-page .obra-open-modal {
  cursor: zoom-in;
}


/* =========================
   Lightbox modal (artístico)
   ========================= */

.obra-modal .modal-dialog {
  max-width: 92vw;
  margin: 0 auto;
}

.obra-modal .modal-content {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.obra-modal .modal-body {
  padding: 0;
}

/* Backdrop más “suave” */
.modal-backdrop.show {
  opacity: .86;
}

/* Imagen centrada, sin “caja” Bootstrap */
.obra-modal-figure {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.obra-modal-img {
  max-height: 86vh;
  max-width: 92vw;
  width: auto;
  height: auto;
  display: block;
  object-fit: contain;
  border-radius: 10px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.55);
}

/* Título discreto */
.obra-modal-caption {
  margin-top: 12px;
  color: rgba(255,255,255,0.82);
  font-size: 0.95rem;
  letter-spacing: .02em;
  text-align: center;
  padding: 0 16px;
}

/* X flotante fina */
.obra-modal-close {
  position: fixed;
  top: 18px;
  right: 22px;
  z-index: 1061; /* por encima del modal */
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.25);
  background: rgba(0,0,0,0.25);
  color: rgba(255,255,255,0.92);
  font-size: 30px;
  line-height: 40px;
  text-align: center;
  padding: 0;
  cursor: pointer;
  transition: background .18s ease, transform .18s ease, opacity .18s ease;
}

.obra-modal-close:hover {
  background: rgba(0,0,0,0.45);
  transform: scale(1.03);
}

/* Evita el “salto” del scroll al abrir modal */
body.modal-open {
  padding-right: 0 !important;
}

/* Responsive pequeños */
@media (max-width: 575.98px) {
  .obra-modal-img {
    max-height: 82vh;
    border-radius: 8px;
  }
  .obra-modal-close {
    top: 12px;
    right: 12px;
  }
}
/* Flechas modal – MISMO ESTILO QUE CARRUSEL */
.obra-modal-nav {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1061;
  width: 48px;
  height: 48px;
  border: 0;
  background: rgba(0,0,0,0.35);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .15s ease, opacity .15s ease;
}

.obra-modal-prev {
  left: 18px;
}

.obra-modal-next {
  right: 18px;
}

/* Heredan el icono de Bootstrap */
.obra-modal-nav .carousel-control-prev-icon,
.obra-modal-nav .carousel-control-next-icon {
  width: 20px;
  height: 20px;
  background-size: 100% 100%;
}

/* Hover coherente */
.obra-modal-nav:hover {
  background: rgba(0,0,0,0.55);
}

/* Móvil */
@media (max-width: 575.98px) {
  .obra-modal-nav {
    width: 40px;
    height: 40px;
  }
}


/* Drift vertical muy sutil */
.hero-drift{
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center 35%;
  will-change: background-position;
  animation: heroDriftY 28s ease-in-out infinite alternate;
}

@keyframes heroDriftY{
  from { background-position: center 28%; }
  to   { background-position: center 42%; }
}


@media (max-width: 767.98px){
  .hero-drift{ animation: none; }
}


/* Si tus .obra-thumb img ya están bien, esto puede no hacer falta */
.coleccion-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Placeholder cuando una colección aún no tiene imagen */
.coleccion-placeholder{
  width: 100%;
  padding-top: 120%; /* proporción similar a card vertical; ajusta si tu thumb ya define altura */
  background: linear-gradient(135deg, rgba(0,0,0,.06), rgba(0,0,0,.02));
}

/* Texto secundario en overlay */
.coleccion-overlay-desc{
  display: block;
  opacity: .85;
  margin-top: .25rem;
  font-size: 1rem;
  margin-bottom: 10px;
  color: #fefefe;
  
}


/* ===============================
   COLECCIONES: título siempre visible
   =============================== */

.coleccion-card .obra-overlay{
  opacity: 1 !important;
  visibility: visible !important;
}

/* Si en hover oscureces más el fondo, mantenlo */
.coleccion-card:hover .obra-overlay{
  opacity: 1;
}

.single-related {
  background: var(--color-bg-alt);
}


/* ==========================
   Colecciones (Home): Legibilidad de texto
   ========================== */

/* Overlay más oscuro abajo, más suave arriba */
.coleccion-card .obra-overlay{
  background: linear-gradient(
    to top,
    rgba(0,0,0,.82) 0%,
    rgba(0,0,0,.55) 40%,
    rgba(0,0,0,.18) 70%,
    rgba(0,0,0,0) 100%
  );
  transform: none;  /* evita desplazamientos que “rompen” lectura */
}
/* ==========================
   Colecciones (Home): Legibilidad de texto
   ========================== */

/* Overlay más oscuro abajo, más suave arriba */
.coleccion-card .obra-overlay{
  background: linear-gradient(
    to top,
    rgba(0,0,0,.82) 0%,
    rgba(0,0,0,.55) 40%,
    rgba(0,0,0,.18) 70%,
    rgba(0,0,0,0) 100%
  );
  transform: none;  /* evita desplazamientos que “rompen” lectura */
}

/* Título siempre muy legible */
.coleccion-card .obra-overlay-title{
  color: rgba(255,255,255,.96);
  text-shadow: 0 2px 10px rgba(0,0,0,.75);
}

/* Descripción: soporte visual + tipografía más legible */
.coleccion-card .coleccion-overlay-desc{
  color: #fff;

  line-height: 1.45;
  

  /* “placa” muy sutil para que nunca se pierda */
  display: inline-block;
  padding: 6px 8px;
  border-radius: 10px;
  background: rgba(0,0,0,.58);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);

  /* no dejes que se haga eterna */
  max-width: 100%;
}


/* Vignette sutil para garantizar base oscura */
.coleccion-card .obra-thumb::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(
    120% 85% at 50% 20%,
    rgba(0,0,0,0) 40%,
    rgba(0,0,0,.22) 100%
  );
  pointer-events:none;
}


/* =====================================
   COLECCIONES – LAYOUT HORIZONTAL
   Solo Home / Colecciones
   ===================================== */

/* Tablet y desktop: cards horizontales */
@media (min-width: 768px) {

  /* La card ocupa más espacio visual */
  .coleccion-card {
    border-radius: 22px;
  }

  /* Cambiamos la proporción SOLO en colecciones */
  .coleccion-card .coleccion-thumb,
  .coleccion-card .obra-thumb {
    padding-top: 100%; /* 16:9 horizontal */
  }

  /* Imagen respira mejor */
  .coleccion-card .obra-thumb img {
    object-position: center center;
  }

  /* Overlay más espacioso */
  .coleccion-card .obra-overlay {
    padding: 20px;
  }

  /* Título más protagonista */
  .coleccion-card .obra-overlay-title {
    font-size: 1.2rem;
    letter-spacing: 0.06em;
  }

}

/* =========================
   TIMELINE EXPOSICIONES
   ========================= */

.anaite-timeline{
  position: relative;
  padding-left: 22px;
}

.anaite-timeline::before{
  content:"";
  position:absolute;
  left: 10px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: rgba(0,0,0,.12);
}

.timeline-item{
  position: relative;
  margin-bottom: 22px;
}

.timeline-dot{
  position:absolute;
  left: 2px;
  top: 18px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #111;
  border: 3px solid #fff;
  box-shadow: 0 0 0 2px rgba(0,0,0,.12);
}

.anaite-timeline--past .timeline-dot{
  background: rgba(17,17,17,.35);
}

.timeline-card{
  margin-left: 18px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 14px 34px rgba(0,0,0,0.08);
}

.timeline-thumb-link{ display:block; height:100%; }
.timeline-thumb{
  width: 100%;
  height: 100%;
  min-height: 220px;
  object-fit: contain; /* clave: NO recorta flyer */
  background: rgba(0,0,0,.03);
  padding: 10px;
}

/* En móvil, que no quede gigante */
@media (max-width: 767.98px){
  .timeline-thumb{ min-height: 180px; }
}

/* HOME — Exposición */
#expo-home .section-title{
  font-weight: 900;
}

.expo-home-flyer{
  width: 100%;
  height: auto;
  max-height: 760px;
  object-fit: contain;     /* clave: se ve completo */
  border-radius: 16px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.12);
  background: rgba(255,255,255,0.35);
}

.expo-home-panel{
  height: 100%;
}

.expo-nota{
font-size:0.95rem;
color:#6b6b6b;
font-style:italic;
margin-top:20px;
}