/*
Theme Name:        Aromas de Armero
Theme URI:         https://aromasdearmero.com
Author:            Aromas de Armero
Author URI:        https://aromasdearmero.com
Description:       Tema personalizado para Aromas de Armero — Café Especial desde Armero, Tolima. Diseñado para WooCommerce, Elementor y pasarela PSE. Incluye paleta de marca completa, tipografías Playfair Display + Lato + Cormorant Garamond, y todos los componentes de la tienda.
Version:           1.0.0
Requires at least: 6.0
Tested up to:      6.9
Requires PHP:      8.0
License:           GNU General Public License v2 or later
License URI:       http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       aromas-armero
Tags:              e-commerce, woocommerce, elementor, coffee, colombia, custom-colors, custom-typography, full-site-editing
*/

/* ══════════════════════════════════════════════════
   AROMAS DE ARMERO — ESTILOS GLOBALES DEL TEMA
   ══════════════════════════════════════════════════ */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Lato:wght@300;400;700;900&family=Cormorant+Garamond:ital,wght@0,300;0,600;1,300;1,600&family=DM+Mono:wght@300;400;500&display=swap');

/* ── VARIABLES ── */
:root {
  --color-espresso:    #1A0C04;
  --color-coffee:      #2E1608;
  --color-mocha:       #5C2E0E;
  --color-caramel:     #C07A30;
  --color-gold:        #D4A040;
  --color-gold-light:  #EAB84A;
  --color-cream:       #F5EDE0;
  --color-cream-light: #FDFAF4;
  --color-sage:        #5B7250;
  --color-ink:         #2A1408;
  --color-red:         #B84040;

  --font-serif:   'Playfair Display', Georgia, serif;
  --font-body:    'Lato', sans-serif;
  --font-elegant: 'Cormorant Garamond', serif;
  --font-mono:    'DM Mono', monospace;

  --shadow-sm:   0 2px 8px rgba(26,12,4,.15);
  --shadow-md:   0 8px 24px rgba(26,12,4,.22);
  --shadow-lg:   0 16px 48px rgba(26,12,4,.32);
  --shadow-gold: 0 4px 20px rgba(192,120,48,.35);

  --transition: .22s ease;
  --radius-sm:  2px;
  --radius-md:  4px;
  --radius-pill:20px;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  color: var(--color-ink);
  background: var(--color-cream-light);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-caramel); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-gold); }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-thumb { background: rgba(192,120,48,.3); border-radius: 3px; }
::selection { background: rgba(192,120,48,.22); color: var(--color-espresso); }

/* ── TIPOGRAFÍA ── */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-serif);
  color: var(--color-espresso);
  line-height: 1.1;
  font-weight: 700;
  margin: 0 0 .5em;
}
h1 { font-size: clamp(36px,5vw,64px); font-weight: 900; }
h2 { font-size: clamp(26px,4vw,44px); }
h3 { font-size: clamp(20px,3vw,32px); }
h4 { font-size: clamp(17px,2vw,22px); }
p  { font-family: var(--font-body); font-size: 16px; line-height: 1.72; margin: 0 0 1em; }

.eyebrow {
  font-family: var(--font-elegant);
  font-size: 12px; letter-spacing: 4px;
  text-transform: uppercase; color: var(--color-caramel);
  font-style: italic; display: block; margin-bottom: 12px;
}
.lead {
  font-family: var(--font-elegant);
  font-size: clamp(17px,2vw,20px);
  font-weight: 300; font-style: italic;
  line-height: 1.7; color: var(--color-coffee);
}
blockquote {
  font-family: var(--font-elegant);
  font-size: clamp(18px,2.2vw,22px);
  font-style: italic; font-weight: 300;
  color: var(--color-coffee);
  border-left: 3px solid var(--color-caramel);
  padding-left: 24px; margin: 28px 0; line-height: 1.65;
}
blockquote cite {
  display: block; font-size: 12px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--color-caramel);
  margin-top: 14px; font-style: normal; font-weight: 700;
}

/* ── LAYOUT ── */
.container       { max-width: 1140px; margin: 0 auto; padding: 0 5vw; }
.container-narrow{ max-width: 760px;  margin: 0 auto; padding: 0 5vw; }
.section         { padding: 80px 5vw; }
.section-sm      { padding: 48px 5vw; }
.section-lg      { padding: 110px 5vw; }
.section-dark    { background: var(--color-espresso); }
.section-cream   { background: var(--color-cream); }

.gold-rule          { width: 44px; height: 2px; background: var(--color-caramel); margin: 16px 0 48px; border: none; display: block; }
.gold-rule.center   { margin: 16px auto 48px; }
.gold-rule.sm       { width: 28px; height: 1.5px; margin: 12px 0 28px; }

/* ── BOTONES ── */
.btn,.btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  background: linear-gradient(135deg,var(--color-caramel),var(--color-gold));
  color: var(--color-espresso) !important;
  padding: 15px 36px; font-family: var(--font-body);
  font-size: 11px; font-weight: 900; letter-spacing: 2.5px;
  text-transform: uppercase; border: none; border-radius: var(--radius-sm);
  cursor: pointer; transition: var(--transition);
  text-decoration: none !important; box-shadow: var(--shadow-gold);
}
.btn:hover,.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(192,120,48,.5);
  color: var(--color-espresso) !important;
}
.btn-secondary {
  display: inline-flex; align-items: center; gap: 9px;
  background: transparent; color: var(--color-espresso) !important;
  padding: 14px 34px; font-family: var(--font-body);
  font-size: 11px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; border: 1.5px solid var(--color-caramel);
  border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition);
  text-decoration: none !important;
}
.btn-secondary:hover { background: var(--color-caramel); color: var(--color-cream-light) !important; }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 9px;
  background: transparent; color: var(--color-cream) !important;
  padding: 14px 34px; font-family: var(--font-body);
  font-size: 11px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; border: 1px solid rgba(192,120,48,.35);
  border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition);
  text-decoration: none !important;
}
.btn-ghost:hover { border-color: var(--color-gold); color: var(--color-gold) !important; }
.btn-dark {
  background: var(--color-espresso); color: var(--color-cream) !important;
  padding: 15px 36px; font-family: var(--font-body);
  font-size: 11px; font-weight: 900; letter-spacing: 2.5px;
  text-transform: uppercase; border: none; border-radius: var(--radius-sm);
  display: inline-flex; align-items: center; gap: 9px;
  transition: var(--transition); cursor: pointer; text-decoration: none !important;
}
.btn-dark:hover { background: var(--color-coffee); transform: translateY(-2px); color: var(--color-cream) !important; }
.btn-whatsapp {
  background: #25D366; color: white !important;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 13px 28px; border-radius: var(--radius-sm);
  font-weight: 700; font-size: 13px; text-decoration: none !important;
  transition: var(--transition); font-family: var(--font-body);
}
.btn-whatsapp:hover { background: #1ebe5a; transform: translateY(-2px); color: white !important; }
.btn-lg { padding: 20px 52px; font-size: 13px; letter-spacing: 3px; }
.btn-sm { padding: 10px 22px; font-size: 10px; }
.btn-full { width: 100%; }

/* ── COMPONENTES DE MARCA ── */
.origin-tag {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(192,120,48,.1); border: .5px solid rgba(192,120,48,.32);
  padding: 7px 18px; border-radius: var(--radius-pill);
  font-size: 11px; letter-spacing: 2px; color: var(--color-caramel);
  text-transform: uppercase; font-weight: 700; font-family: var(--font-body);
}
.origin-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--color-caramel); flex-shrink: 0;
  animation: pulseDot 2s infinite;
}
@keyframes pulseDot {
  0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.75)}
}
.badge-sca {
  display: inline-flex; flex-direction: column;
  align-items: center; justify-content: center;
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--color-gold); color: var(--color-espresso);
  font-family: var(--font-serif); box-shadow: var(--shadow-md);
}
.badge-sca__num  { font-size: 24px; font-weight: 900; line-height: 1; }
.badge-sca__label{ font-size: 8px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700; }
.process-tag {
  display: inline-block; background: rgba(192,120,48,.1);
  border: .5px solid rgba(192,120,48,.3); color: var(--color-caramel);
  font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  padding: 5px 14px; border-radius: var(--radius-pill);
  font-weight: 700; font-family: var(--font-body);
}
.tasting-note {
  font-family: var(--font-elegant); font-size: 18px; font-style: italic;
  color: var(--color-coffee); border-left: 2px solid var(--color-caramel);
  padding-left: 18px; line-height: 1.55;
}
.stock-bar  { height: 4px; background: rgba(255,255,255,.08); border-radius: 2px; overflow: hidden; }
.stock-fill { height: 100%; background: linear-gradient(90deg,var(--color-caramel),var(--color-gold)); border-radius: 2px; transition: width 1.2s ease; }
.guarantee-box {
  display: flex; align-items: flex-start; gap: 10px;
  background: rgba(91,114,80,.09); border: .5px solid rgba(91,114,80,.25);
  padding: 14px 18px; border-radius: var(--radius-sm);
}
.guarantee-box p { font-family: var(--font-elegant); font-style: italic; font-size: 13px; color: var(--color-sage); margin: 0; }

/* ── FADE IN ── */
.fade-in           { opacity: 0; transform: translateY(22px); transition: opacity .65s ease, transform .65s ease; }
.fade-in.visible   { opacity: 1; transform: none; }
.fade-in-left      { opacity: 0; transform: translateX(-24px); transition: opacity .65s ease, transform .65s ease; }
.fade-in-left.visible  { opacity: 1; transform: none; }
.fade-in-right     { opacity: 0; transform: translateX(24px);  transition: opacity .65s ease, transform .65s ease; }
.fade-in-right.visible { opacity: 1; transform: none; }
.stagger > *:nth-child(1){transition-delay:.05s}
.stagger > *:nth-child(2){transition-delay:.12s}
.stagger > *:nth-child(3){transition-delay:.19s}
.stagger > *:nth-child(4){transition-delay:.26s}
.stagger > *:nth-child(5){transition-delay:.33s}
.stagger > *:nth-child(6){transition-delay:.40s}

/* ── WOOCOMMERCE — BOTONES ── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .button.alt,
.woocommerce-page a.button,
.woocommerce-page button.button {
  background: linear-gradient(135deg,var(--color-caramel),var(--color-gold)) !important;
  color: var(--color-espresso) !important;
  font-family: var(--font-body) !important;
  font-weight: 900 !important; font-size: 11px !important;
  letter-spacing: 2px !important; text-transform: uppercase !important;
  border: none !important; border-radius: var(--radius-sm) !important;
  padding: 13px 28px !important; transition: var(--transition) !important;
  box-shadow: var(--shadow-gold) !important; cursor: pointer !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce-page a.button:hover,
.woocommerce-page button.button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 32px rgba(192,120,48,.5) !important;
  color: var(--color-espresso) !important;
}
.woocommerce span.onsale {
  background: var(--color-caramel) !important;
  border-radius: var(--radius-pill) !important;
  font-family: var(--font-body) !important;
  font-weight: 900 !important; font-size: 10px !important;
  letter-spacing: 1.5px !important; text-transform: uppercase !important;
  padding: 5px 12px !important; min-height: auto !important; min-width: auto !important;
  line-height: 1 !important; top: 12px !important; right: 12px !important; left: auto !important;
}
.woocommerce .price ins .woocommerce-Price-amount,
.woocommerce span.price .woocommerce-Price-amount {
  font-family: var(--font-serif) !important;
  color: var(--color-gold) !important; font-size: 1.4em !important;
}
.woocommerce-loop-product__title {
  font-family: var(--font-serif) !important;
  color: var(--color-espresso) !important;
  font-weight: 700 !important;
}
.woocommerce .star-rating span::before { color: var(--color-gold) !important; }

/* ── WOOCOMMERCE — CHECKOUT ── */
.woocommerce form .form-row label {
  font-family: var(--font-body) !important;
  font-size: 10px !important; letter-spacing: 2px !important;
  text-transform: uppercase !important; font-weight: 700 !important;
  color: rgba(42,20,8,.55) !important; margin-bottom: 6px !important;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: .5px solid rgba(42,20,8,.15) !important;
  border-radius: var(--radius-sm) !important;
  font-family: var(--font-body) !important;
  font-size: 14px !important; padding: 13px 16px !important;
  color: var(--color-ink) !important;
  transition: var(--transition) !important; outline: none !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--color-caramel) !important;
  box-shadow: 0 0 0 3px rgba(192,120,48,.12) !important;
}
#place_order {
  font-size: 13px !important; padding: 18px 40px !important;
  width: 100% !important; letter-spacing: 2.5px !important;
}
.woocommerce table.shop_table th {
  background: var(--color-espresso) !important;
  color: var(--color-cream) !important;
  font-family: var(--font-body) !important;
  font-size: 10px !important; letter-spacing: 2px !important;
  text-transform: uppercase !important; padding: 14px 18px !important;
}
.woocommerce table.shop_table td {
  font-family: var(--font-body) !important;
  font-size: 14px !important; padding: 14px 18px !important;
  border-color: rgba(192,120,48,.1) !important;
}
.woocommerce-message  { background: rgba(91,114,80,.1) !important; border-top-color: var(--color-sage) !important; color: var(--color-sage) !important; }
.woocommerce-error    { background: rgba(184,64,64,.08) !important; border-top-color: var(--color-red) !important; }
.woocommerce-info     { border-top-color: var(--color-caramel) !important; background: rgba(192,120,48,.08) !important; }

/* ── ELEMENTOR ── */
.elementor-nav-menu a.elementor-item {
  font-family: var(--font-body) !important; font-size: 11px !important;
  letter-spacing: 1.5px !important; text-transform: uppercase !important;
  font-weight: 700 !important; color: rgba(245,237,224,.42) !important;
  transition: color var(--transition) !important;
}
.elementor-nav-menu a.elementor-item:hover,
.elementor-nav-menu a.elementor-item.elementor-item-active {
  color: var(--color-cream) !important;
}
.elementor-nav-menu .sub-menu {
  background: var(--color-espresso) !important;
  border: .5px solid rgba(192,120,48,.2) !important;
  border-radius: var(--radius-sm) !important;
}
.elementor-button {
  font-family: var(--font-body) !important; font-weight: 700 !important;
  letter-spacing: 2px !important; text-transform: uppercase !important;
  border-radius: var(--radius-sm) !important; transition: var(--transition) !important;
}
.elementor-accordion .elementor-tab-title {
  font-family: var(--font-body) !important; font-weight: 700 !important; color: var(--color-espresso) !important;
}
.elementor-accordion .elementor-tab-title.elementor-active { color: var(--color-caramel) !important; }

/* ── FOOTER ── */
.site-footer {
  background: #0A0400 !important; color: rgba(245,237,224,.4) !important;
  border-top: .5px solid rgba(192,120,48,.12) !important;
}
.site-footer a { color: rgba(245,237,224,.32) !important; transition: color var(--transition) !important; }
.site-footer a:hover { color: var(--color-cream) !important; }
.site-footer h4,.site-footer .widget-title {
  font-family: var(--font-body) !important; font-size: 10px !important;
  letter-spacing: 3px !important; text-transform: uppercase !important;
  color: var(--color-gold) !important; margin-bottom: 16px !important; font-weight: 700 !important;
}

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  h1{font-size:38px!important} h2{font-size:28px!important}
}
@media (max-width: 768px) {
  h1{font-size:32px!important} h2{font-size:24px!important} h3{font-size:20px!important}
  .section{padding:56px 5vw}
  .btn,.btn-primary,.btn-secondary,.btn-dark,.btn-ghost{width:100%;justify-content:center}
}
@media (max-width: 480px) {
  .section{padding:44px 5vw}
}
@media print {
  nav,footer,.site-footer,.aromas-whatsapp-float{display:none!important}
  body{background:white!important;color:black!important}
}
