/*
Theme Name: Authentic Mokka
Theme URI: https://authenticmokka.com
Author: Authentic Mokka
Description: Tema oficial Authentic Mokka. Compatible con WooCommerce.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
License: Privado
Text Domain: mokka
*/

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Dancing+Script:wght@700&family=Crimson+Pro:ital,wght@0,300;0,400;1,300&display=swap');

/* RESET TOTAL — elimina estilos residuales de temas anteriores */
html,body,div,span,h1,h2,h3,h4,h5,h6,p,a,img,ul,li,nav,header,footer,section,article,main,figure {
  margin:0; padding:0; border:0; font-size:100%; vertical-align:baseline;
}
body { line-height:1; }
ul { list-style:none; }
img { max-width:100%; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --red:  #BB1E18; --redk: #8a1510;
  --grey: #C2C1C0; --gold: #FAD7A0;
  --black:#0e0e0e; --white:#f8f7f5;
  --fd:'Bebas Neue',Impact,sans-serif;
  --fs:'Dancing Script',cursive;
  --fb:'Crimson Pro',Georgia,serif;
}
html { scroll-behavior:smooth; }
body { background:var(--white); color:var(--black); font-family:var(--fb); overflow-x:hidden; }
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; height:auto; object-fit:cover; }
button { cursor:pointer; border:none; font-family:inherit; }
ul { list-style:none; }

/* ANN BAR */
.ann-bar { background:var(--red); padding:.55rem 1rem; text-align:center; font-family:var(--fd); font-size:13px; letter-spacing:.2em; color:var(--gold); }
.ann-bar strong { color:#fff; }
.ann-bar .sep { margin:0 .8rem; opacity:.35; }

/* HEADER */
.site-header { position:sticky; top:0; z-index:200; background:var(--red); border-bottom:.5px solid rgba(0,0,0,.15); display:flex; align-items:center; justify-content:space-between; padding:1rem 2.5rem; }
.header-logo { display:flex; align-items:center; }

/* Logo PNG — sobreescribe dimensiones inline de WordPress */
.header-logo img,
.header-logo .custom-logo-link img,
.header-logo .custom-logo {
  height: 38px !important;
  width: auto !important;
  max-height: 38px !important;
  max-width: 200px !important;
  display: block !important;
  object-fit: contain !important;
}
.custom-logo-link { display:flex; align-items:center; line-height:1; }

.header-logo .logo-text { display:flex; flex-direction:column; line-height:1; }
.header-logo .logo-text .sc { font-family:var(--fs); font-size:11px; color:var(--gold); }
.header-logo .logo-text .wk { font-family:var(--fd); font-size:21px; color:#fff; letter-spacing:.08em; line-height:.85; }
.header-nav ul { display:flex; gap:2rem; }
.header-nav a { font-family:var(--fd); font-size:13px; letter-spacing:.2em; color:rgba(255,255,255,.75); transition:color .2s; }
.header-nav a:hover, .header-nav .current-menu-item > a { color:#fff; }
.header-actions { display:flex; align-items:center; gap:1.2rem; }
.header-search-link { font-family:var(--fd); font-size:13px; letter-spacing:.15em; color:rgba(255,255,255,.65); transition:color .2s; }
.header-search-link:hover { color:#fff; }
.header-cart-link { font-family:var(--fd); font-size:13px; letter-spacing:.18em; color:var(--black); background:var(--gold); padding:.55rem 1.4rem; transition:background .2s; }
.header-cart-link:hover { background:#e8c37a; }

/* HERO */
.hero { position:relative; height:100svh; min-height:600px; overflow:hidden; }
.hero__img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; }
.hero__overlay { position:absolute; inset:0; background:linear-gradient(105deg,rgba(14,14,14,.22) 0%,transparent 60%); }
.hero__content { position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; justify-content:flex-end; align-items:flex-start; padding:4rem 3.5rem; }
.hero__pill { display:inline-block; font-family:var(--fd); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); background:rgba(14,14,14,.55); border:1px solid rgba(250,215,160,.3); padding:.45rem 1rem; margin-bottom:1.2rem; }
.hero__title { font-family:var(--fd); font-size:clamp(64px,10vw,130px); color:#fff; letter-spacing:.02em; line-height:.88; margin-bottom:.6rem; }
.hero__sub { font-family:var(--fd); font-size:13px; letter-spacing:.25em; color:var(--grey); text-transform:uppercase; margin-bottom:2rem; }
.hero__buttons { display:flex; gap:1rem; flex-wrap:wrap; }
.btn-primary { display:inline-block; font-family:var(--fd); font-size:14px; letter-spacing:.26em; text-transform:uppercase; color:#fff; background:var(--red); padding:1.05rem 3rem; transition:background .2s,transform .15s; }
.btn-primary:hover { background:var(--redk); transform:translateY(-2px); }
.btn-secondary { display:inline-block; font-family:var(--fd); font-size:14px; letter-spacing:.26em; text-transform:uppercase; color:#fff; border:1px solid rgba(255,255,255,.35); padding:1.05rem 2.5rem; transition:border-color .2s,background .2s; }
.btn-secondary:hover { border-color:#fff; background:rgba(255,255,255,.1); }

/* TRUST */
.trust-bar { background:var(--black); padding:1.2rem 2rem; display:flex; align-items:center; justify-content:center; gap:1.2rem; flex-wrap:wrap; }
.trust-bar__stars { font-size:18px; color:var(--gold); letter-spacing:.1em; }
.trust-bar__rating { font-family:var(--fd); font-size:22px; color:#fff; letter-spacing:.08em; }
.trust-bar__sep { color:rgba(255,255,255,.15); }
.trust-bar__label { font-family:var(--fb); font-size:14px; font-style:italic; color:rgba(194,193,192,.5); }

/* MARQUEE */
.marquee { background:var(--grey); padding:.9rem 0; overflow:hidden; white-space:nowrap; }
.marquee__track { display:inline-flex; gap:2.5rem; animation:marquee-scroll 22s linear infinite; }
.marquee__item { font-family:var(--fd); font-size:12px; letter-spacing:.3em; text-transform:uppercase; color:rgba(14,14,14,.55); display:flex; align-items:center; gap:1rem; flex-shrink:0; }
.marquee__dot { width:3px; height:3px; background:var(--red); border-radius:50%; flex-shrink:0; }
@keyframes marquee-scroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* CLASSIC MOKKA */
.classic-mokka { padding:4rem 2rem 5rem; background:var(--white); }
.classic-mokka__header { text-align:center; margin-bottom:2.5rem; }
.classic-mokka__eyebrow { font-family:var(--fs); font-size:16px; color:var(--red); display:block; margin-bottom:.3rem; }
.classic-mokka__title { font-family:var(--fd); font-size:clamp(44px,7vw,86px); letter-spacing:.04em; line-height:.88; }
.classic-mokka__subtitle { font-family:var(--fb); font-size:16px; font-style:italic; color:#888; margin-top:.4rem; }
.classic-mokka__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.classic-card { display:flex; flex-direction:column; }
.classic-card__img-wrap { position:relative; aspect-ratio:3/4; overflow:hidden; display:block; }
.classic-card__img-wrap img { width:100%; height:100%; object-fit:cover; object-position:top; transition:transform .7s ease; }
.classic-card:hover .classic-card__img-wrap img { transform:scale(1.05); }
.classic-card__placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; }
.classic-card__placeholder span { font-family:var(--fd); font-size:28px; letter-spacing:.1em; opacity:.18; }
.p-gold  { background:var(--gold); }  .p-gold span  { color:var(--black); }
.p-black { background:var(--black); } .p-black span { color:#fff; }
.p-red   { background:var(--red); }   .p-red span   { color:#fff; }
.p-cream { background:#e8e5e0; }       .p-cream span { color:var(--black); }
.classic-card__hover { position:absolute; inset:0; background:rgba(14,14,14,0); display:flex; align-items:center; justify-content:center; transition:background .3s; z-index:2; }
.classic-card:hover .classic-card__hover { background:rgba(14,14,14,.2); }
.classic-card__hover span { font-family:var(--fd); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:#fff; border:1px solid rgba(255,255,255,.5); padding:.6rem 1.4rem; opacity:0; transform:translateY(6px); transition:opacity .3s,transform .3s; }
.classic-card:hover .classic-card__hover span { opacity:1; transform:translateY(0); }
.classic-card__info { padding:1.1rem 1rem 1.4rem; background:var(--white); display:flex; flex-direction:column; gap:.4rem; flex:1; }
.classic-card__meta { display:flex; align-items:baseline; justify-content:space-between; gap:.5rem; }
.classic-card__name { font-family:var(--fd); font-size:17px; letter-spacing:.1em; text-transform:uppercase; color:var(--black); }
.classic-card__price { font-family:var(--fd); font-size:16px; color:var(--red); white-space:nowrap; }
.classic-card__desc { font-family:var(--fb); font-size:13px; font-style:italic; color:#999; }
.classic-card__btn { display:block; width:100%; text-align:center; font-family:var(--fd); font-size:13px; letter-spacing:.24em; text-transform:uppercase; color:#fff; background:var(--black); padding:.9rem 1rem; margin-top:auto; border:none; cursor:pointer; transition:background .2s,transform .15s; }
.classic-card__btn:hover { background:var(--red); transform:translateY(-2px); }

/* STATEMENT */
.statement { background:var(--red); padding:8rem 3rem; text-align:center; }
.statement__inner { max-width:820px; margin:0 auto; }
.statement__eyebrow { font-family:var(--fs); font-size:20px; color:var(--gold); opacity:.8; display:block; margin-bottom:.8rem; }
.statement__title { font-family:var(--fd); font-size:clamp(68px,12vw,140px); color:var(--gold); letter-spacing:.03em; line-height:.85; margin-bottom:2rem; }
.statement__text { font-size:17px; color:rgba(250,215,160,.75); font-style:italic; font-weight:300; max-width:500px; margin:0 auto 2.5rem; line-height:1.8; }
.btn-gold { display:inline-block; font-family:var(--fd); font-size:13px; letter-spacing:.28em; text-transform:uppercase; color:var(--red); background:var(--gold); padding:1.1rem 3rem; transition:background .2s,transform .15s; }
.btn-gold:hover { background:#fff; transform:translateY(-2px); }

/* WOOCOMMERCE */
.woo-section { padding:5rem 2rem; background:var(--white); }
.woo-section .sec-ey { font-family:var(--fs); font-size:15px; color:var(--red); display:block; }
.woo-section .sec-ttl { font-family:var(--fd); font-size:clamp(40px,5vw,60px); letter-spacing:.04em; line-height:.88; margin-bottom:2.5rem; }
.woo-products-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.woo-card { background:#eae9e7; position:relative; }
.woo-card__img { aspect-ratio:3/4; overflow:hidden; position:relative; display:block; }
.woo-card__img img { width:100%; height:100%; object-fit:cover; object-position:top; transition:transform .7s; }
.woo-card:hover .woo-card__img img { transform:scale(1.06); }
.woo-card__info { padding:1rem .9rem 1.3rem; background:var(--white); }
.woo-card__name { font-family:var(--fd); font-size:16px; letter-spacing:.1em; text-transform:uppercase; color:var(--black); }
.woo-card__price, .woo-card__price .woocommerce-Price-amount { font-family:var(--fd); font-size:15px; color:var(--red); margin-top:.3rem; }
.woo-card__price del .woocommerce-Price-amount { color:#aaa; font-size:12px; }
.woo-card__btn, .woo-card .button, .woo-card .add_to_cart_button { display:block; width:100%; text-align:center; font-family:var(--fd); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:#fff !important; background:var(--black) !important; padding:.8rem 1rem; margin-top:.8rem; border:none; cursor:pointer; transition:background .2s; border-radius:0 !important; }
.woo-card .button:hover, .woo-card .add_to_cart_button:hover { background:var(--red) !important; }
.woocommerce-message, .woocommerce-info { font-family:var(--fb); background:var(--white); border-top:3px solid var(--red); padding:1rem 1.5rem; margin:1rem 2rem; }

/* REVIEWS */
.reviews-section { padding:6rem 2.5rem; background:var(--white); }
.reviews-section .sec-ey { font-family:var(--fs); font-size:15px; color:var(--red); display:block; }
.reviews-section .sec-ttl { font-family:var(--fd); font-size:clamp(40px,5vw,58px); letter-spacing:.04em; }
.reviews-header { text-align:center; margin-bottom:3.5rem; }
.reviews__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.review-card { background:#f3f2f0; padding:2rem 1.8rem; position:relative; }
.review-card::before { content:'"'; font-family:var(--fs); font-size:80px; color:var(--red); opacity:.12; position:absolute; top:.5rem; left:1.2rem; line-height:1; pointer-events:none; }
.review-card__stars { color:var(--red); font-size:14px; margin-bottom:.8rem; }
.review-card__text { font-size:15px; font-style:italic; color:#444; line-height:1.8; margin-bottom:1.2rem; }
.review-card__author { display:flex; align-items:center; gap:.8rem; }
.review-card__avatar { width:36px; height:36px; border-radius:50%; background:var(--grey); display:flex; align-items:center; justify-content:center; font-family:var(--fd); font-size:14px; color:var(--red); flex-shrink:0; }
.review-card__name { font-family:var(--fd); font-size:13px; letter-spacing:.12em; color:var(--black); display:block; }
.review-card__loc { font-size:11px; color:#aaa; font-style:italic; }
.review-card__badge { font-family:var(--fd); font-size:9px; letter-spacing:.2em; color:var(--red); border:1px solid var(--red); padding:.2rem .5rem; margin-left:auto; }

/* EMAIL */
.email-section { background:var(--black); padding:6rem 2.5rem; }
.email-section__inner { max-width:600px; margin:0 auto; text-align:center; }
.email-section__eyebrow { font-family:var(--fs); font-size:16px; color:var(--gold); display:block; margin-bottom:.5rem; }
.email-section__title { font-family:var(--fd); font-size:clamp(36px,5vw,58px); color:#fff; letter-spacing:.04em; line-height:.9; margin-bottom:1rem; }
.email-section__text { font-size:15px; font-style:italic; color:rgba(194,193,192,.6); margin-bottom:2rem; }
.email-section__form { display:flex; max-width:460px; margin:0 auto; }
.email-section__input { flex:1; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-right:none; padding:1rem 1.4rem; font-family:var(--fb); font-size:15px; color:#fff; outline:none; transition:border-color .2s; }
.email-section__input::placeholder { color:rgba(255,255,255,.25); font-style:italic; }
.email-section__input:focus { border-color:var(--red); }
.email-section__btn { font-family:var(--fd); font-size:13px; letter-spacing:.22em; text-transform:uppercase; background:var(--red); color:#fff; border:none; padding:1rem 1.8rem; cursor:pointer; transition:background .2s; white-space:nowrap; }
.email-section__btn:hover { background:var(--redk); }
.email-section__legal { font-size:11px; color:rgba(194,193,192,.3); font-style:italic; margin-top:1rem; }
.email-section__legal a { border-bottom:1px solid rgba(194,193,192,.2); color:inherit; }

/* FOOTER */
.site-footer { background:var(--black); padding:5rem 2.5rem 2.5rem; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; margin-bottom:3.5rem; }
.footer-brand__script { font-family:var(--fs); font-size:13px; color:var(--grey); display:block; }
.footer-brand__name { font-family:var(--fd); font-size:32px; letter-spacing:.08em; color:#fff; line-height:.85; display:block; margin-bottom:1.1rem; }
.footer-brand__desc { font-size:13px; font-style:italic; color:rgba(194,193,192,.4); line-height:1.8; max-width:230px; }
.footer-payments { display:flex; gap:.6rem; margin-top:1.5rem; flex-wrap:wrap; }
.payment-badge { font-family:var(--fd); font-size:10px; letter-spacing:.15em; color:rgba(194,193,192,.4); border:.5px solid rgba(194,193,192,.15); padding:.3rem .7rem; }
.footer-col h4 { font-family:var(--fd); font-size:11px; letter-spacing:.3em; text-transform:uppercase; color:rgba(194,193,192,.5); margin-bottom:1.2rem; }
.footer-col ul li { margin-bottom:.6rem; }
.footer-col ul a { font-size:14px; font-style:italic; color:rgba(194,193,192,.35); transition:color .2s; }
.footer-col ul a:hover { color:#fff; }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; padding-top:2rem; border-top:.5px solid rgba(255,255,255,.05); flex-wrap:wrap; gap:1rem; }
.footer-tagline { font-family:var(--fd); font-size:11px; letter-spacing:.35em; text-transform:uppercase; color:var(--red); }
.footer-social { display:flex; gap:1.2rem; }
.footer-social a { font-family:var(--fd); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:rgba(194,193,192,.3); transition:color .2s; }
.footer-social a:hover { color:#fff; }
.footer-copy { font-size:11px; color:rgba(194,193,192,.18); }

/* 404 */
.page-404 { text-align:center; padding:8rem 2rem; background:var(--black); min-height:60vh; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.page-404 .ey { font-family:var(--fs); font-size:18px; color:var(--gold); display:block; margin-bottom:.5rem; }
.page-404 h1 { font-family:var(--fd); font-size:clamp(80px,15vw,180px); color:#fff; line-height:.85; margin-bottom:1.5rem; }
.page-404 p { font-style:italic; color:var(--grey); margin-bottom:2.5rem; }

/* RESPONSIVE */
@media(max-width:1024px){
  .classic-mokka__grid { grid-template-columns:repeat(2,1fr); }
  .woo-products-grid { grid-template-columns:repeat(2,1fr); }
  .footer-top { grid-template-columns:1fr 1fr; }
  .reviews__grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px){
  .site-header { padding:.8rem 1.2rem; }
  .header-nav, .header-search-link { display:none; }
  .hero__content { padding:2rem 1.5rem; }
  .hero__title { font-size:clamp(52px,14vw,80px); }
  .classic-mokka { padding:2.5rem 1rem 3rem; }
  .classic-mokka__grid { grid-template-columns:repeat(2,1fr); gap:1px; }
  .trust-bar { gap:.7rem; padding:1rem 1.2rem; }
  .reviews__grid { grid-template-columns:1fr; }
  .email-section__form { flex-direction:column; }
  .email-section__input { border-right:1px solid rgba(255,255,255,.12); border-bottom:none; }
  .footer-top { grid-template-columns:1fr; }
  .statement { padding:5rem 1.5rem; }
  .woo-products-grid { grid-template-columns:repeat(2,1fr); gap:1px; }
}

/* ══ NUCLEAR OVERRIDE — mata cualquier estilo del tema anterior ══ */
body{background:#f8f7f5!important;font-family:'Crimson Pro',Georgia,serif!important;}
.site-header{background:#BB1E18!important;display:flex!important;align-items:center!important;justify-content:space-between!important;padding:1rem 2.5rem!important;position:sticky!important;top:0!important;z-index:9999!important;border:none!important;box-shadow:none!important;}
.site-header *{box-sizing:border-box!important;}
.header-nav{display:flex!important;}
.header-nav ul{display:flex!important;gap:2rem!important;list-style:none!important;margin:0!important;padding:0!important;}
.header-nav a{color:rgba(255,255,255,.75)!important;font-family:'Bebas Neue',Impact,sans-serif!important;font-size:13px!important;letter-spacing:.2em!important;text-decoration:none!important;}
.header-cart-link{background:#FAD7A0!important;color:#0e0e0e!important;font-family:'Bebas Neue',Impact,sans-serif!important;padding:.55rem 1.4rem!important;border:none!important;}
.hero{height:100vh!important;min-height:600px!important;position:relative!important;overflow:hidden!important;}
.ann-bar{background:#BB1E18!important;color:#FAD7A0!important;font-family:'Bebas Neue',Impact,sans-serif!important;text-align:center!important;padding:.55rem 1rem!important;display:block!important;}
.classic-mokka{display:block!important;padding:4rem 2rem 5rem!important;}
.classic-mokka__grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:2px!important;}
.site-footer{background:#0e0e0e!important;color:#f8f7f5!important;}
/* Eliminar márgenes/paddings que WordPress añade */
.wp-site-blocks,.entry-content,.page,.post{margin:0!important;padding:0!important;}
#page,#content,#primary,#secondary,#main,.site-content{all:unset;display:block;}
