/* === RESET === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
img, picture, video, canvas, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; }
html { overflow-x: clip; }
body { overflow-x: clip; }
body { font-family: var(--font-main); color: var(--color-text); background: var(--color-bg); line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* Elementor residual — ocultar widgets que no usamos en el tema custom */
.elementor-menu-cart__container,
.elementor-location-header,
.elementor-location-footer { display: none !important; }

/* === LAYOUT === */
.container { max-width: var(--max-width); margin-inline: auto; padding-inline: var(--spacing-lg); }

/* === HEADER === */
.site-header { position: sticky; top: 0; z-index: 100; background: var(--color-bg); box-shadow: 0 4px 16px rgba(173,82,7,0.18), 0 1px 0 rgba(173,82,7,0.12); }
.site-header__inner { max-width: none; margin-inline: 0; padding: 0 60px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: var(--spacing-lg); min-height: var(--header-height); }
.site-header__logo { justify-self: start; }
.site-header__logo img,
.site-header__logo .custom-logo { height: 100px; width: auto; display: block; }
.site-header__logo-text { font-size: 1.5rem; font-weight: 700; color: var(--color-primary); }
.site-header__nav { justify-self: center; display: flex; align-items: center; }
.nav-menu { display: flex; gap: var(--spacing-lg); justify-content: center; }
.nav-menu a { font-family: 'Nunito', sans-serif; font-size: 2rem; font-weight: 800; color: var(--color-primary); transition: opacity 0.2s; }
.nav-menu a:hover { opacity: 0.75; }
.site-header__actions { justify-self: end; display: flex; align-items: center; gap: var(--spacing-md); }
.lang-menu { display: flex; gap: var(--spacing-sm); }
.lang-menu a { font-size: 0.85rem; font-weight: 600; padding: 2px 6px; border-radius: 4px; }
.lang-menu .current-menu-item a { background: var(--color-primary); color: var(--color-white); }
.cart-icon { position: relative; display: flex; align-items: center; color: var(--color-primary); }
.cart-icon:hover { opacity: 0.75; }
.cart-icon__count { position: absolute; top: -6px; right: -8px; background: var(--color-primary); color: white; font-size: 0.7rem; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.site-header__menu-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.site-header__menu-toggle span { display: block; width: 24px; height: 2px; background: var(--color-primary); transition: all 0.3s; }

/* === BUTTONS === */
.btn-primary,
.btn-primary:visited,
.btn-primary:link {
  background: #D5FC6B;
  color: rgb(247, 62, 31);
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  padding: 0.85rem 2rem;
  border-radius: 50px;
  text-decoration: none;
  transition: transform 0.15s, box-shadow 0.15s;
  box-shadow: 0 4px 16px rgba(213,252,107,0.5);
  border: none;
  display: inline-block;
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 6px 22px rgba(213,252,107,0.65); }
.btn-secondary,
.btn-secondary:visited,
.btn-secondary:link {
  background: transparent;
  color: #F73E1F;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  padding: 0.85rem 2rem;
  border-radius: 50px;
  text-decoration: none;
  border: 2px solid #F73E1F;
  transition: background 0.15s, color 0.15s;
  display: inline-block;
}
.btn-secondary:hover { background: #F73E1F; color: #fff; }
.btn-outline { background: transparent; color: var(--color-primary); border: 2px solid var(--color-primary); border-radius: var(--radius); padding: 0.75rem 1.5rem; font-weight: 600; display: inline-block; transition: background 0.2s, color 0.2s; }
.btn-outline:hover { background: var(--color-primary); color: white; }
.btn-cart {
  display: inline-block;
  background: #FDF8D6;
  color: #F73E1F;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 0.9rem;
  padding: 6px 16px;
  border: none;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  text-decoration: none;
  margin-top: 14px;
}
.btn-cart:hover { background: #F73E1F; color: #FDF8D6; }

/* === FOOTER === */
.site-footer { background: #F73E1F; color: #FDF8D6; margin-top: 0; }
.site-footer__top { border-bottom: 1px solid rgba(253,248,214,0.25); }
.site-footer__inner { max-width: var(--max-width); margin-inline: auto; padding: var(--spacing-xl) var(--spacing-lg); display: grid; grid-template-columns: 1.5fr 1fr 1.3fr; gap: var(--spacing-xl); align-items: flex-start; }
.site-footer__col { font-family: 'Poppins', sans-serif; font-size: 0.9rem; font-weight: 300; line-height: 1.6; }
.site-footer__title { font-family: 'Nunito', sans-serif; font-size: 0.85rem; font-weight: 800; color: #FDF8D6; text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: var(--spacing-md); opacity: 0.9; }
.site-footer__company p { margin-bottom: var(--spacing-sm); }
.site-footer__list { display: flex; flex-direction: column; gap: 6px; }
.site-footer__list a { font-family: 'Poppins', sans-serif; font-size: 0.9rem; font-weight: 300; color: #FDF8D6; transition: opacity 0.2s; }
.site-footer__list a:hover { opacity: 0.7; }
.site-footer__bottom { background: #F73E1F; }
.site-footer__bottom-inner { max-width: var(--max-width); margin-inline: auto; padding: var(--spacing-md) var(--spacing-lg); display: flex; align-items: center; justify-content: space-between; gap: var(--spacing-lg); }
.site-footer__bottom-inner p { font-family: 'Poppins', sans-serif; font-size: 0.85rem; font-weight: 300; }
.site-footer__payment img { height: 45px; width: auto; }

/* === BLOG ARCHIVE === */
.blog-archive { background: var(--color-bg); padding: var(--spacing-xl) 0 var(--spacing-2xl); }
.blog-archive__header { text-align: center; margin-bottom: var(--spacing-xl); }
.blog-archive__title { font-family: 'Nunito', sans-serif; font-size: clamp(2.5rem, 5vw, 3.5rem); font-weight: 800; color: #F73E1F; line-height: 1.05; }
.blog-archive__subtitle { font-family: 'Montserrat', sans-serif; font-size: 1rem; font-weight: 400; color: #AD5207; margin-top: 8px; max-width: 540px; margin-inline: auto; }
.blog-archive__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--spacing-xl) var(--spacing-lg); }
.blog-archive-card { background: #fff; border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; box-shadow: 0 2px 14px rgba(173,82,7,0.08); transition: transform 0.2s, box-shadow 0.2s; }
.blog-archive-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(173,82,7,0.15); }
.blog-archive-card__img-link { display: block; }
.blog-archive-card__img { aspect-ratio: 16 / 10; overflow: hidden; background: #fdf4d6; }
.blog-archive-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.blog-archive-card:hover .blog-archive-card__img img { transform: scale(1.04); }
.blog-archive-card__img--empty { background: #fdf4d6; }
.blog-archive-card__body { padding: var(--spacing-lg); display: flex; flex-direction: column; gap: 10px; flex: 1; }
.blog-archive-card__date { font-family: 'Poppins', sans-serif; font-size: 0.8rem; font-weight: 400; color: #AD5207; opacity: 0.75; margin: 0; text-transform: uppercase; letter-spacing: 0.06em; }
.blog-archive-card__title { font-family: 'Nunito', sans-serif; font-size: 1.2rem; font-weight: 700; line-height: 1.3; margin: 0; }
.blog-archive-card__title a { color: #1a1a1a; transition: color 0.15s; }
.blog-archive-card__title a:hover { color: #F73E1F; }
.blog-archive-card__excerpt { font-family: 'Poppins', sans-serif; font-size: 0.92rem; font-weight: 300; line-height: 1.6; color: #AD5207; flex: 1; margin: 0; }
.blog-archive-card__more { font-family: 'Nunito', sans-serif; font-size: 0.9rem; font-weight: 700; color: #F73E1F; transition: opacity 0.15s; margin-top: auto; }
.blog-archive-card__more:hover { opacity: 0.75; }
.blog-archive__pagination { display: flex; justify-content: center; margin-top: var(--spacing-2xl); }
.blog-archive__pagination .page-numbers { font-family: 'Nunito', sans-serif; font-weight: 700; padding: 8px 14px; border-radius: 50px; color: #AD5207; transition: all 0.15s; }
.blog-archive__pagination .page-numbers:hover { background: rgba(247,62,31,0.1); color: #F73E1F; }
.blog-archive__pagination .page-numbers.current { background: #F73E1F; color: #fff; }
.blog-archive__empty { text-align: center; padding: var(--spacing-2xl) 0; color: #AD5207; }

/* === SINGLE POST === */
article.single-post { background: var(--color-bg); padding: var(--spacing-lg) 0 var(--spacing-2xl); }
article.single-post .container { max-width: 760px; }
.single-post__hero { margin: 0 0 var(--spacing-xl); border-radius: 16px; overflow: hidden; aspect-ratio: 16 / 9; background: #fdf4d6; }
.single-post__hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
.single-post__header { margin-bottom: var(--spacing-lg); }
.single-post__meta { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-family: 'Poppins', sans-serif; font-size: 0.85rem; font-weight: 400; color: #AD5207; opacity: 0.85; margin-bottom: var(--spacing-md); }
.single-post__back { font-family: 'Nunito', sans-serif; font-weight: 700; color: #F73E1F; transition: opacity 0.15s; }
.single-post__back:hover { opacity: 0.75; }
.single-post__sep { opacity: 0.5; }
.single-post__title { font-family: 'Nunito', sans-serif; font-size: clamp(1.85rem, 4vw, 2.6rem); font-weight: 800; color: #1a1a1a; line-height: 1.15; }
.single-post__content { font-family: 'Poppins', sans-serif; font-size: 1.05rem; font-weight: 300; line-height: 1.75; color: #1a1a1a; }
.single-post__content h2 { font-family: 'Nunito', sans-serif; font-size: 1.6rem; font-weight: 800; color: #F73E1F; margin: var(--spacing-xl) 0 var(--spacing-md); line-height: 1.2; }
.single-post__content h3 { font-family: 'Nunito', sans-serif; font-size: 1.25rem; font-weight: 700; color: #1a1a1a; margin: var(--spacing-lg) 0 var(--spacing-sm); }
.single-post__content p { margin: 0 0 1.1em; }
.single-post__content a { color: #F73E1F; text-decoration: underline; }
.single-post__content a:hover { opacity: 0.8; }
.single-post__content img { border-radius: 14px; margin-block: var(--spacing-lg); width: 100%; height: auto; }
.single-post__content ul, .single-post__content ol { margin: 0 0 1.1em; padding-left: 1.4em; }
.single-post__content li { margin-bottom: 0.4em; }
.single-post__content blockquote { border-left: 4px solid #F73E1F; padding: 0.5em 1em; margin: 1.5em 0; background: rgba(247,62,31,0.05); font-style: italic; border-radius: 0 8px 8px 0; }
.single-post__content blockquote p:last-child { margin-bottom: 0; }

/* Tables in posts */
.single-post__content table { width: 100%; border-collapse: separate; border-spacing: 0; margin: 1.8em 0; background: #fff; border: 1px solid var(--color-border); border-radius: 12px; overflow: hidden; box-shadow: 0 2px 12px rgba(173,82,7,0.08); font-family: 'Poppins', sans-serif; font-size: 0.95rem; }
.single-post__content table thead tr,
.single-post__content table tr:first-child { background: #F73E1F; color: #FDF8D6; }
.single-post__content table thead th,
.single-post__content table tr:first-child th,
.single-post__content table tr:first-child td { font-family: 'Nunito', sans-serif; font-weight: 800; text-align: left; padding: 14px 18px; color: #FDF8D6; border-right: 1px solid rgba(253,248,214,0.3); }
.single-post__content table thead th:last-child,
.single-post__content table tr:first-child th:last-child,
.single-post__content table tr:first-child td:last-child { border-right: none; }
.single-post__content table th,
.single-post__content table td { padding: 12px 18px; border-bottom: 1px solid var(--color-border); border-right: 1px solid var(--color-border); text-align: left; vertical-align: top; line-height: 1.5; }
.single-post__content table th:last-child,
.single-post__content table td:last-child { border-right: none; }
.single-post__content table tr:last-child td { border-bottom: none; }
.single-post__content table tbody tr:nth-child(even) { background: var(--color-bg); }
.single-post__content table tbody tr:not(:first-child):hover { background: rgba(247,62,31,0.05); }
.single-post__content table thead tr:hover,
.single-post__content table tr:first-child:hover { background: #F73E1F !important; }

/* Wider tables — horizontal scroll on mobile */
.single-post__content .wp-block-table,
.single-post__content figure.wp-block-table { margin: 1.5em 0; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.single-post__content .wp-block-table table,
.single-post__content figure.wp-block-table table { margin: 0; min-width: 100%; }

/* Buttons inside content */
.single-post__content .wp-block-button__link { background: #F73E1F; color: #fff !important; font-family: 'Nunito', sans-serif; font-weight: 700; padding: 12px 28px; border-radius: 50px; text-decoration: none; display: inline-block; transition: transform 0.15s, box-shadow 0.15s; box-shadow: 0 4px 14px rgba(247,62,31,0.3); }
.single-post__content .wp-block-button__link:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(247,62,31,0.4); }

/* Pull-out boxes (Easy Table of Contents, custom resumen, etc) */
.single-post__content .resumen-rapido,
.single-post__content .tiempo-lectura { font-family: 'Poppins', sans-serif; }
.single-post__content .resumen-rapido { background: var(--color-bg); border-left: 4px solid #d4a017; padding: 14px 18px; border-radius: 0 8px 8px 0; margin: 1.5em 0; }
.single-post__content .resumen-rapido strong { font-family: 'Nunito', sans-serif; color: #F73E1F; }
.single-post__content .tiempo-lectura { display: inline-block; font-size: 0.9rem; color: #AD5207; opacity: 0.8; margin-bottom: var(--spacing-md); }

/* Easy Table of Contents — softer, branded */
.single-post__content #ez-toc-container { background: #fff; border: 1px solid var(--color-border); border-radius: 12px; padding: 18px 22px; margin: 1.5em 0; }
.single-post__content #ez-toc-container .ez-toc-title { font-family: 'Nunito', sans-serif; font-weight: 800; color: #F73E1F; text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.9rem; }
.single-post__content #ez-toc-container nav ul li a { color: #1a1a1a; text-decoration: none; }
.single-post__content #ez-toc-container nav ul li a:hover { color: #F73E1F; }

.single-post__footer { margin-top: var(--spacing-2xl); padding-top: var(--spacing-lg); border-top: 1px solid var(--color-border); }

/* Post author widget */
.post-author { display: grid; grid-template-columns: 220px 1fr; gap: 28px; margin: 3rem 0 2rem; padding: 0; background: #FDF8D6; border: 1px solid var(--color-border); border-radius: 16px; overflow: hidden; box-shadow: 0 2px 12px rgba(173,82,7,0.08); align-items: stretch; }
.post-author__photo { position: relative; background: #F73E1F; min-height: 280px; border-top-left-radius: 16px; border-bottom-left-radius: 16px; overflow: hidden; }
.post-author__photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.post-author__body { padding: 28px 28px 28px 0; align-self: center; }
.post-author__eyebrow { font-family: 'Poppins', sans-serif; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--color-brown); margin: 0 0 4px; font-weight: 600; }
.post-author__name { font-family: 'Nunito', sans-serif; font-size: 1.6rem; font-weight: 800; color: var(--color-text); margin: 0 0 2px; }
.post-author__role { font-family: 'Poppins', sans-serif; font-size: 0.95rem; color: var(--color-brown); margin: 0 0 12px; font-style: italic; }
.post-author__bio { font-family: 'Poppins', sans-serif; font-size: 0.98rem; line-height: 1.65; color: var(--color-text); margin: 0; }
@media (max-width: 640px) {
    .post-author { grid-template-columns: 1fr; gap: 0; }
    .post-author__photo { min-height: 380px; border-top-left-radius: 16px; border-top-right-radius: 16px; border-bottom-left-radius: 0; }
    .post-author__photo img { object-position: center 12%; }
    .post-author__body { padding: 22px 24px; }
}

/* === PAGE === */
.page-content { max-width: 860px; margin-inline: auto; padding-block: var(--spacing-xl); }
.page-content h1 { font-size: 2rem; font-weight: 700; margin-bottom: var(--spacing-lg); }
.page-content p { margin-bottom: var(--spacing-md); }

/* === 404 === */
.error-404 { text-align: center; padding-block: var(--spacing-2xl); }
.error-404 h1 { font-size: 6rem; font-weight: 700; color: var(--color-primary); line-height: 1; }
.error-404 p { font-size: 1.1rem; margin-block: var(--spacing-lg); }

/* === HOME === */

/* --- Hero --- */
.hero-section { position: relative; background: var(--color-bg) var(--hero-bg) center/cover no-repeat; min-height: 560px; overflow: hidden; isolation: isolate; }
.hero-section__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(95deg, rgba(253,248,214,0.97) 0%, rgba(253,248,214,0.92) 28%, rgba(253,248,214,0.55) 52%, rgba(253,248,214,0.15) 75%, rgba(253,248,214,0) 100%); }
.hero {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 560px) 1fr;
  grid-template-areas: "text quote";
  align-items: center;
  column-gap: 2rem;
  max-width: 1200px;
  width: 100%;
  padding: 5rem 4rem 4rem 4rem;
  margin: 0 auto;
  min-height: 560px;
}
.hero-text { grid-area: text; display: flex; flex-direction: column; gap: 1.5rem; }
.hero-eyebrow { font-size: 0.9rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: #F73E1F; opacity: 0.85; }
.hero-title { font-family: 'Nunito', sans-serif; font-size: clamp(2.4rem, 4.5vw, 3.8rem); font-weight: 900; line-height: 1.05; color: #F73E1F; text-shadow: 0 1px 0 rgba(253,248,214,0.6); }
.hero-subtitle { font-family: 'Montserrat', sans-serif; font-size: clamp(1rem, 1.8vw, 1.2rem); line-height: 1.6; color: #5a3614; font-weight: 500; max-width: 460px; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 0.5rem; }
.hero-badge { font-size: 0.85rem; font-weight: 600; color: #AD5207; opacity: 0.8; }
.hero-quote { grid-area: quote; justify-self: end; align-self: center; background: #ffffff; border-radius: 14px; padding: 18px 20px; width: 100%; max-width: 340px; box-shadow: 0 12px 32px rgba(0,0,0,0.18), 0 4px 10px rgba(0,0,0,0.08); }
.hero-quote__text { font-family: 'Poppins', sans-serif; font-size: 14px; font-weight: 300; line-height: 1.5; font-style: italic; color: #1a1a1a; }
.hero-quote__stars { display: block; color: #f5c518; font-size: 1rem; letter-spacing: 1.5px; margin-bottom: 8px; }
.hero-quote__author { font-family: 'Nunito', sans-serif; font-size: 12px; font-weight: 700; color: #1a1a1a; opacity: 0.8; display: block; margin-top: 10px; }

/* --- Delivery bar --- */
.delivery-bar { background: var(--color-bg); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.delivery-bar__inner { max-width: var(--max-width); margin-inline: auto; padding: 0.65rem var(--spacing-lg); display: flex; align-items: center; justify-content: center; gap: 1rem; flex-wrap: wrap; font-size: 0.9rem; font-weight: 600; color: #AD5207; }
.delivery-bar__sep { opacity: 0.4; }

/* --- Process section --- */
.process-section { background: var(--color-bg); padding-top: 30px; padding-bottom: 50px; }
.process-intro { max-width: 820px; margin-inline: auto; display: flex; align-items: center; gap: 24px; margin-bottom: 45px; }
.process-intro__photo { flex-shrink: 0; width: 110px; height: 110px; border-radius: 50%; overflow: hidden; box-shadow: 0 4px 14px rgba(173,82,7,0.18); border: 3px solid #fff; }
.process-intro__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.process-intro__text-wrap { display: flex; flex-direction: column; gap: 12px; }
.process-intro__text { font-family: 'Montserrat', sans-serif; font-size: 17px; font-weight: 400; font-style: italic; line-height: 1.55; color: var(--color-text); padding: 0; margin: 0; }
.process-cards { max-width: 1200px; margin-inline: auto; display: flex; gap: 40px; justify-content: center; flex-wrap: wrap; }
.process-card { width: 30%; min-width: 260px; display: flex; flex-direction: column; }
.process-card__visual { position: relative; height: 271px; background-size: cover; background-position: center; border-radius: 18px; overflow: hidden; isolation: isolate; box-shadow: 0 4px 16px rgba(173,82,7,0.10); }
.process-card__visual::before { content: ''; position: absolute; inset: 0; z-index: 1; background: rgba(26,15,5,0.45); }
.process-card__num { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 3; font-family: 'Nunito', sans-serif; font-size: 7rem; font-weight: 900; line-height: 1; letter-spacing: -0.05em; color: #FDF8D6; }
.process-card__content { padding: 28px 0 0 0; text-align: center; }
.process-card__title { font-family: 'Nunito', sans-serif; font-size: 25px; font-weight: 700; color: #F73E1F; line-height: 1.1; margin-bottom: 18px; }
.process-card__desc { font-family: 'Montserrat', sans-serif; font-size: 17px; font-weight: 300; line-height: 1.5; color: #AD5207; }

/* --- Products section (red) --- */
.products-section { background: #F73E1F; padding-bottom: 60px; }
.products-section > .container { padding-top: 80px; }
.products-section__shape { line-height: 0; display: block; }
.products-section__shape svg { height: 30px; width: 100%; display: block; }
.section-title { font-family: 'Nunito', sans-serif; font-size: 35px; font-weight: 800; text-align: center; margin-bottom: var(--spacing-xl); }
.section-title--cream { color: #FDF8D6; }
.products-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 38px 59px; }
.product-card { display: block; border-radius: 0; overflow: hidden; background: transparent; border: none; color: inherit; text-decoration: none; transition: transform 0.2s; }
.product-card:hover { transform: translateY(-4px); }
.product-card__img { overflow: hidden; }
.product-card__img img { width: 100%; height: auto; border-radius: 12px; display: block; }
.product-card__body { padding: var(--spacing-md) 0; text-align: center; }
.product-card__name { font-size: 20px; font-weight: 500; text-transform: uppercase; color: #FDF8D6; margin-bottom: 6px; }
.product-card__price { font-size: 24px; font-weight: 700; color: #FDF8D6; margin-bottom: 0; }
.product-card__price .woocommerce-Price-amount { color: #FDF8D6; }

/* --- Blog section --- */
.blog-section { background: var(--color-bg); padding-bottom: var(--spacing-2xl); }
.blog-section > .container { padding-top: 30px; }
.blog-section__shape { line-height: 0; display: block; }
.blog-section__shape svg { height: 30px; width: 100%; display: block; }
.blog-section .section-title { color: #F73E1F; padding-top: 30px; }
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 35px 30px; }
.blog-card { border-radius: 22px; overflow: hidden; background: var(--color-white); }
.blog-card__img-link { display: block; }
.blog-card__img { overflow: hidden; border-radius: 12px; }
.blog-card__img img { width: 100%; height: 200px; object-fit: cover; border-radius: 12px; }
.blog-card__body { padding: var(--spacing-md) var(--spacing-md) var(--spacing-lg); }
.blog-card__title { font-family: 'Nunito', sans-serif; font-size: 21px; font-weight: 700; line-height: 1.3; }
.blog-card__title a { color: #F73E1F; }
.blog-card__title a:hover { opacity: 0.8; }

/* --- Contact section --- */
.contact-section { background: var(--color-bg); }
.contact-section__inner { max-width: var(--max-width); margin-inline: auto; padding: 5%; display: flex; flex-direction: row; gap: 30px; align-items: center; }
.contact-section__info { flex: 1; display: flex; flex-direction: column; gap: 20px; padding-right: 6%; }
.contact-section__title { font-family: 'Nunito', sans-serif; font-size: 42px; font-weight: 800; color: #F73E1F; text-align: right; line-height: 1; }
.contact-section__label { font-family: 'Nunito', sans-serif; font-size: 18px; font-weight: 700; color: #F73E1F; text-align: right; line-height: 1; }
.contact-section__list { text-align: right; }
.contact-section__list li { font-family: 'Poppins', sans-serif; font-size: 16px; font-weight: 300; line-height: 1.5; color: #AD5207; }
.contact-section__list a { color: #AD5207; transition: opacity 0.2s; }
.contact-section__list a:hover { opacity: 0.75; }
.contact-section__social { display: flex; flex-direction: column; align-items: flex-end; }
.contact-section__image { flex: 1; display: flex; justify-content: center; align-items: center; }
.contact-section__image img { width: 67%; height: auto; border-radius: 50px; display: block; }

/* === SOCIAL PROOF STRIP === */
.social-proof-strip { background: #1e1e1e; }
.social-proof-strip__inner { max-width: var(--max-width); margin-inline: auto; padding: 16px var(--spacing-lg); display: flex; align-items: center; justify-content: center; gap: 1.75rem; font-family: 'Nunito', sans-serif; font-size: 19px; font-weight: 700; color: #e8e0c8; white-space: nowrap; flex-wrap: wrap; }
.social-proof-strip__item { display: inline-flex; align-items: center; gap: 10px; color: inherit; transition: opacity 0.2s; }
.social-proof-strip__item:hover { opacity: 0.75; }
.social-proof-strip__icon { width: 26px; height: 26px; flex-shrink: 0; }
.social-proof-strip__sep { opacity: 0.35; font-size: 1.2rem; }

/* === PRODUCT CARD BADGE === */
.product-card__img { position: relative; }
.product-card--featured { outline: 2px solid rgba(253,248,214,0.55); outline-offset: 4px; border-radius: 14px; }
.product-card__badge { position: absolute; top: 10px; left: 10px; background: #FDF8D6; color: #F73E1F; font-family: 'Nunito', sans-serif; font-size: 11px; font-weight: 900; letter-spacing: 0.12em; padding: 5px 14px; border-radius: 50px; text-transform: uppercase; box-shadow: 0 2px 12px rgba(0,0,0,0.25); }

/* === TRUST STRIP === */
.trust-strip { background: var(--color-bg); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.trust-strip__inner { max-width: var(--max-width); margin-inline: auto; padding: var(--spacing-lg); display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--spacing-md); }
.trust-item { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 6px; }
.trust-item__icon { font-size: 1.6rem; line-height: 1; }
.trust-item__label { font-family: 'Nunito', sans-serif; font-size: 14px; font-weight: 700; color: #F73E1F; line-height: 1.2; }
.trust-item__text { font-family: 'Poppins', sans-serif; font-size: 12px; font-weight: 300; color: #AD5207; line-height: 1.4; }

/* === PRODUCTS URGENCY === */
.products-section__deadline { text-align: center; color: #FDF8D6; font-family: 'Poppins', sans-serif; font-size: 14px; font-weight: 300; opacity: 0.9; margin-top: -28px; margin-bottom: var(--spacing-xl); }

/* === TESTIMONIALS === */
.testimonials-section { background: var(--color-bg); padding-bottom: var(--spacing-2xl); }
.testimonials-section__shape { line-height: 0; display: block; margin-bottom: var(--spacing-xl); margin-top: -1px; }
.testimonials-section__shape svg { height: 30px; width: 100%; display: block; }
.testimonials-carousel { position: relative; margin-top: var(--spacing-xl); }
.testimonials-grid { display: flex; gap: var(--spacing-lg); overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding: 8px 4px; -ms-overflow-style: none; scrollbar-width: none; }
.testimonials-grid::-webkit-scrollbar { display: none; }
.testimonial-card { flex: 0 0 calc((100% - var(--spacing-lg) * 2) / 3); scroll-snap-align: start; background: #fff; border-radius: 16px; padding: var(--spacing-lg); display: flex; flex-direction: column; gap: 12px; box-shadow: 0 2px 12px rgba(173,82,7,0.08); }
.testimonial-card__stars { color: #f5c518; font-size: 1rem; letter-spacing: 2px; }
.testimonial-card__text { font-family: 'Poppins', sans-serif; font-size: 15px; font-weight: 300; line-height: 1.7; color: #AD5207; flex: 1; }
.testimonial-card__author { font-family: 'Nunito', sans-serif; font-size: 14px; font-weight: 700; color: #F73E1F; }
.testimonial-card__source { font-weight: 400; opacity: 0.65; font-size: 12px; }
.testimonials-carousel__btn { position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 50%; border: none; background: #F73E1F; color: #FDF8D6; cursor: pointer; z-index: 5; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 14px rgba(247,62,31,0.35); transition: background 0.2s, transform 0.2s; }
.testimonials-carousel__btn:hover { background: #d52e10; transform: translateY(-50%) scale(1.08); }
.testimonials-carousel__btn--prev { left: -22px; }
.testimonials-carousel__btn--next { right: -22px; }

/* === BLOG (sin shape) === */
.blog-section { background: var(--color-bg); padding: var(--spacing-xl) 0 var(--spacing-2xl); }
.blog-section .section-title { color: #F73E1F; }

/* === SECTION TITLE MODIFIER === */
.section-title--red { color: #F73E1F; }

/* === FAQ === */
.faq-section { background: var(--color-bg); padding: var(--spacing-xl) 0 var(--spacing-2xl); }
.faq-list { max-width: 760px; margin-inline: auto; margin-top: var(--spacing-xl); display: flex; flex-direction: column; gap: 8px; }
.faq-item { background: #fff; border-radius: 10px; overflow: hidden; border: 1px solid var(--color-border); }
.faq-item__question { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: var(--spacing-md); padding: var(--spacing-md) var(--spacing-lg); background: none; border: none; cursor: pointer; text-align: left; font-family: 'Nunito', sans-serif; font-size: 16px; font-weight: 700; color: #1a1a1a; transition: color 0.2s; }
.faq-item__question:hover,
.faq-item__question[aria-expanded="true"] { color: #F73E1F; }
.faq-item__icon { flex-shrink: 0; color: #F73E1F; transition: transform 0.3s ease; }
.faq-item__question[aria-expanded="true"] .faq-item__icon { transform: rotate(45deg); }
.faq-item__answer { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.3s ease; }
.faq-item__answer.is-open { grid-template-rows: 1fr; }
.faq-item__answer-inner { overflow: hidden; }
.faq-item__answer-inner p { padding: 0 var(--spacing-lg) var(--spacing-md); font-family: 'Poppins', sans-serif; font-size: 15px; font-weight: 300; line-height: 1.7; color: #AD5207; }

/* === STICKY ORDER BAR === */
.sticky-order-bar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 200; background: #F73E1F; color: #FDF8D6; transform: translateY(100%); transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); pointer-events: none; }
.sticky-order-bar.is-visible { transform: translateY(0); pointer-events: auto; }
.sticky-order-bar__inner { max-width: var(--max-width); margin-inline: auto; padding: 12px var(--spacing-lg); display: flex; align-items: center; justify-content: space-between; gap: var(--spacing-md); }
.sticky-order-bar__text { font-family: 'Nunito', sans-serif; font-size: 15px; font-weight: 700; }
.sticky-order-bar__btn { background: #D5FC6B; color: rgb(247, 62, 31); font-family: 'Nunito', sans-serif; font-weight: 700; font-size: 15px; padding: 8px 24px; border-radius: 50px; white-space: nowrap; transition: background 0.2s; }
.sticky-order-bar__btn:hover { background: #c4f050; }

/* === PIEROGI TOAST === */
.hamur-toast { position: fixed; left: 50%; top: calc(var(--header-height) + 16px); transform: translateX(-50%) translateY(-120%); display: flex; align-items: flex-start; gap: 10px; max-width: calc(100% - 32px); width: 380px; background: #fff; color: #1a4d7d; border-left: 4px solid #4a7fb5; border-radius: 12px; padding: 14px 16px 14px 14px; box-shadow: 0 12px 32px rgba(0,0,0,0.18), 0 4px 10px rgba(0,0,0,0.08); font-family: 'Nunito', sans-serif; font-size: 0.92rem; line-height: 1.4; opacity: 0; pointer-events: none; transition: transform 0.3s cubic-bezier(0.2, 0.7, 0.2, 1), opacity 0.3s; z-index: 9999; }
.hamur-toast--visible { transform: translateX(-50%) translateY(0); opacity: 1; pointer-events: auto; }
.hamur-toast__icon { color: #d4a017; font-size: 1.05rem; flex-shrink: 0; line-height: 1.4; }
.hamur-toast__msg { flex: 1; }
.hamur-toast__msg strong { font-weight: 800; }
.hamur-toast__close { flex-shrink: 0; background: none; border: none; cursor: pointer; color: #5a7a99; font-size: 1.4rem; line-height: 1; padding: 0 4px; transition: color 0.15s; }
.hamur-toast__close:hover { color: #1a4d7d; }

/* === CROSS-SELL POPUP (cart) === */
.hamur-cross-sell { position: fixed; inset: 0; z-index: 9998; display: none; align-items: center; justify-content: center; padding: 1rem; opacity: 0; transition: opacity 0.25s ease; }
.hamur-cross-sell.is-open { display: flex; opacity: 1; }
.hamur-cross-sell__backdrop { position: absolute; inset: 0; background: rgba(26,15,5,0.55); cursor: pointer; }
.hamur-cross-sell__panel { position: relative; background: #fff; border-radius: 18px; padding: 32px 28px 28px; max-width: 420px; width: 100%; text-align: center; box-shadow: 0 24px 60px rgba(0,0,0,0.28); transform: translateY(20px) scale(0.96); transition: transform 0.3s cubic-bezier(0.2,0.8,0.2,1); }
.hamur-cross-sell.is-open .hamur-cross-sell__panel { transform: translateY(0) scale(1); }
.hamur-cross-sell__close { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border: none; background: var(--color-bg); color: #AD5207; font-size: 1.4rem; line-height: 1; border-radius: 50%; cursor: pointer; transition: background 0.15s, color 0.15s; }
.hamur-cross-sell__close:hover { background: #F73E1F; color: #fff; }
.hamur-cross-sell__icon { font-size: 3rem; line-height: 1; margin-bottom: 12px; }
.hamur-cross-sell__title { font-family: 'Nunito', sans-serif; font-size: 1.5rem; font-weight: 800; color: #F73E1F; line-height: 1.2; margin: 0 0 10px; }
.hamur-cross-sell__text { font-family: 'Poppins', sans-serif; font-size: 0.95rem; font-weight: 300; line-height: 1.55; color: #5a3614; margin: 0 0 22px; }
.hamur-cross-sell__actions { display: flex; flex-direction: column; gap: 10px; align-items: center; }
.hamur-cross-sell__cta { width: 100%; max-width: 280px; }
.hamur-cross-sell__skip { background: none; border: none; cursor: pointer; font-family: 'Nunito', sans-serif; font-size: 0.85rem; font-weight: 600; color: #AD5207; text-decoration: underline; padding: 4px 8px; }
.hamur-cross-sell__skip:hover { color: #F73E1F; }

/* === RESPONSIVE === */
@media (max-width: 768px) {
  .site-header__inner { display: flex; align-items: center; justify-content: space-between; padding: 0 1rem; gap: 0.75rem; }
  .site-header__logo { order: 1; margin-right: auto; }
  .site-header__actions { order: 2; margin-right: 1rem; }
  .site-header__menu-toggle { order: 3; display: flex; }
  .site-header__nav { display: none; position: absolute; top: var(--header-height); right: 12px; left: auto; bottom: auto; width: auto; min-width: 0; background: var(--color-bg); padding: 12px 18px; z-index: 99; border-radius: 12px; box-shadow: 0 8px 24px rgba(173,82,7,0.18); border: 1px solid var(--color-border); }
  .site-header__nav.is-open { display: block; }
  .nav-menu { flex-direction: column; gap: 0; font-size: 1.1rem; align-items: stretch; }
  .nav-menu li { white-space: nowrap; }

  /* Footer */
  .site-footer__inner { grid-template-columns: 1fr; gap: var(--spacing-lg); }
  .site-footer__bottom-inner { flex-direction: column; text-align: center; }

  /* Blog archive */
  .blog-archive__grid { grid-template-columns: 1fr; gap: var(--spacing-lg); }
  .single-post__title { font-size: 1.65rem; }
  .single-post__content { font-size: 1rem; }
  /* Tables scroll horizontally on mobile */
  .single-post__content table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%; white-space: nowrap; font-size: 0.85rem; }
  .single-post__content table th,
  .single-post__content table td { padding: 10px 14px; white-space: normal; min-width: 110px; }
  .single-post__content table thead th,
  .single-post__content table tr:first-child th,
  .single-post__content table tr:first-child td { padding: 12px 14px; }

  /* Hero */
  .hero-section { background-image: var(--hero-bg-mobile, var(--hero-bg)); background-position: center 30%; min-height: 0; }
  .hero-section__overlay { background: linear-gradient(180deg, rgba(253,248,214,0) 0%, rgba(253,248,214,0.55) 35%, rgba(253,248,214,0.92) 60%, rgba(253,248,214,0.98) 100%); }
  .hero { grid-template-columns: 1fr; grid-template-areas: "image" "text" "quote"; text-align: center; padding: 60px 1.5rem 1.5rem; row-gap: 0.75rem; min-height: 0; }
  .hero-text { gap: 0.75rem; align-items: center; }
  .hero-subtitle { max-width: 100%; }
  .hero-actions { justify-content: center; margin-top: 0; flex-wrap: nowrap; }
  .btn-primary, .btn-primary:visited, .btn-primary:link,
  .btn-secondary, .btn-secondary:visited, .btn-secondary:link { padding: 0.7rem 1.2rem; font-size: 0.9rem; }
  .hero-title { font-size: 2rem; }
  .hero-quote { margin: 0 auto; max-width: 100%; justify-self: center; }

  /* Delivery bar */
  .delivery-bar__sep { display: none; }
  .delivery-bar__inner { flex-direction: column; gap: 0.25rem; text-align: center; }

  /* Process */
  .process-intro { flex-direction: column; gap: 14px; text-align: center; }
  .process-intro__photo { width: 90px; height: 90px; }
  .process-intro__text { padding: 0; font-size: 16px; line-height: 1.55; }
  .process-intro__text-wrap { gap: 10px; }
  .process-cards { gap: 50px; }
  .process-card { width: 100%; }
  .process-card__visual { min-height: 200px; height: 200px; }
  .process-card__num { font-size: 5.5rem; }
  .process-card__title { font-size: 22px; margin-bottom: 15px; }

  /* Products */
  .products-grid { grid-template-columns: 1fr; gap: 24px; max-width: 360px; margin-inline: auto; }
  .product-card__name { font-size: 14px; line-height: 1.5; }
  .product-card__price { font-size: 18px; }
  .section-title { font-size: 26px; margin-bottom: var(--spacing-md); }
  .blog-section .section-title { padding-top: 0; }

  /* Blog */
  .blog-grid { grid-template-columns: 1fr; }

  /* Trust strip */
  .trust-strip__inner { grid-template-columns: repeat(2, 1fr); gap: var(--spacing-sm); padding: var(--spacing-md); }

  /* Testimonials carousel */
  .testimonial-card { flex: 0 0 85%; }
  .testimonials-carousel { padding-bottom: 60px; margin-top: var(--spacing-md); }
  .testimonials-carousel__btn { top: auto; bottom: 0; transform: none; width: 40px; height: 40px; }
  .testimonials-carousel__btn:hover { transform: scale(1.08); }
  .testimonials-carousel__btn--prev { left: calc(50% - 50px); }
  .testimonials-carousel__btn--next { right: auto; left: calc(50% + 10px); }
  .testimonials-section { padding-bottom: var(--spacing-md); }
  .blog-section { padding: var(--spacing-md) 0 var(--spacing-xl); }

  /* FAQ */
  .faq-item__question { font-size: 15px; padding: var(--spacing-md); }
  .faq-item__answer-inner p { padding: 0 var(--spacing-md) var(--spacing-md); }

  /* Sticky bar */
  .sticky-order-bar__text { font-size: 13px; }
  .sticky-order-bar__btn { font-size: 13px; padding: 7px 18px; }

  /* Contact */
  .contact-section__inner { flex-direction: column-reverse; padding: 10% 5%; gap: 40px; }
  .contact-section__info { padding-right: 0; gap: 15px; }
  .contact-section__title { text-align: left; font-size: 35px; }
  .contact-section__label { text-align: left; }
  .contact-section__list { text-align: left; }
  .contact-section__social { align-items: flex-start; }
  .contact-section__image img { width: 98px; border-radius: 0; margin-left: auto; }
}
