/* ============================================================
   Wael Barber Supply — custom.css
   Estética LUXURY barber — crema hueso + espresso + dorado.
   Cormorant (display serif) + Montserrat (UI/cuerpo).
   Variables de color en brand-colors.php (:root).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant:wght@400;500;600;700&family=Montserrat:wght@300;400;500;600;700&display=swap');

/* ---------- Base ---------- */
* { scroll-behavior: smooth; }

:root {
    --shadow-sm: 0 2px 14px rgba(26,23,20,.06);
    --shadow-md: 0 10px 34px rgba(26,23,20,.12);
    --shadow-lg: 0 22px 60px rgba(26,23,20,.18);
}

html { overflow-x: hidden; }          /* evita scroll horizontal en móvil (widgets fixed) */
body {
    background-color: var(--bg);
    color: var(--text);
    font-family: 'Montserrat', system-ui, sans-serif;
    font-weight: 400;
    overflow-x: hidden;
    max-width: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
/* Atmósfera de fondo en capa fija aparte (evita repaints/parpadeo) */
body::before {
    content: ''; position: fixed; inset: 0; z-index: -1; pointer-events: none;
    background:
        radial-gradient(900px 500px at 80% -10%, rgba(21,127,112,.05), transparent 70%),
        radial-gradient(700px 500px at -10% 10%, rgba(21,127,112,.03), transparent 70%);
}

h1, h2, h3, h4, h5, .font-display {
    font-family: 'Cormorant', Georgia, serif;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: none;
    line-height: 1.12;
}

.h6, h6 { font-family: 'Montserrat', sans-serif; font-weight: 600; text-transform: none; letter-spacing: .01em; }

a { color: var(--gold); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--gold-2); }

.text-muted-2 { color: var(--muted) !important; }
.text-gold { color: var(--gold) !important; }
.bg-surface { background-color: var(--surface) !important; }
.bg-surface-2 { background-color: var(--surface-2) !important; }
.border-soft { border: 1px solid var(--border) !important; }

.eyebrow { font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 3px; font-weight: 600; font-size: .72rem; color: var(--gold); }

::selection { background: var(--gold); color: #fff; }

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--surface-2); border-radius: 0; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

/* ---------- Botones ---------- */
.btn {
    font-family: 'Montserrat', sans-serif;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-weight: 600;
    border-radius: 12px;
}
.btn-gold {
    background: var(--gold);
    color: #0a0a0a;
    border: 1px solid var(--gold);
    padding: .65rem 1.5rem;
    transition: background .2s ease, color .2s ease, transform .2s ease;
}
.btn-gold:hover { background: var(--gold-2); border-color: var(--gold-2); color: #0a0a0a; transform: translateY(-1px); }
.btn-gold:focus-visible { outline: 3px solid var(--gold); outline-offset: 2px; }

.btn-outline-gold {
    border: 1px solid var(--gold); color: var(--gold);
    background: transparent; transition: all .2s ease;
}
.btn-outline-gold:hover { background: var(--gold); color: #0a0a0a; }

.btn-ghost { color: var(--text); border: 1px solid var(--border); background: transparent; }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); }

.btn-wa { background: #25d366; color: #fff; border: none; }
.btn-wa:hover { background: #1ebe5d; color: #fff; }

/* ---------- Top bar de anuncios ---------- */
.topbar { background: var(--surface-2); border-bottom: 1px solid var(--border); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1.5px; font-size: .78rem; }
.topbar .container { padding-top: 7px; padding-bottom: 7px; }
.topbar i { color: var(--gold); }
.topbar .tb-item { color: var(--muted); }

/* ---------- Hairline dorada bajo el navbar (firma sobria) ---------- */
.barber-pole {
    height: 2px;
    background: linear-gradient(90deg,
        transparent 0%, rgba(21,127,112,.25) 12%, var(--gold) 50%,
        rgba(21,127,112,.25) 88%, transparent 100%);
    animation: none;
}
@keyframes barber-move { to { background-position: 68px 0; } }

/* ---------- Sellos / badges vintage ---------- */
.seal {
    display: inline-flex; align-items: center; gap: 6px;
    border: 1px solid var(--gold); color: var(--gold);
    font-family: 'Montserrat', sans-serif; text-transform: uppercase;
    letter-spacing: 1.5px; font-size: .72rem; font-weight: 600;
    padding: 5px 12px; border-radius: 12px;
}
.seal i { font-size: .9rem; }

/* ---------- Navbar ---------- */
.navbar-wael {
    background: rgba(10,10,10,.92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border);
    position: sticky; top: 0; z-index: 1030;
}
.navbar-wael .brand-logo {
    font-family: 'Cormorant', Georgia, serif; font-size: 2rem; font-weight: 700;
    color: var(--text); letter-spacing: .5px; text-transform: none;
}
.navbar-wael .brand-logo span { color: var(--gold); }
.navbar-logo { height: 46px; width: auto; }
.footer-logo { height: 96px; width: auto; }
@media (max-width: 575.98px){ .navbar-logo { height: 38px; } }
.navbar-wael .nav-link {
    color: var(--text); font-family: 'Montserrat', sans-serif;
    font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px; transition: color .2s ease;
}
.navbar-wael .nav-link:hover { color: var(--gold); }
.navbar-icon { color: var(--text); font-size: 1.25rem; position: relative; transition: color .2s ease; }
.navbar-icon:hover { color: var(--gold); }
.cart-count {
    position: absolute; top: -8px; right: -10px;
    background: var(--gold); color: #0a0a0a; font-size: .68rem; font-weight: 700;
    min-width: 18px; height: 18px; border-radius: 9px;
    display: inline-flex; align-items: center; justify-content: center; padding: 0 4px;
}

/* Buscador */
.search-wael .form-control {
    background: var(--surface); border: 1px solid var(--border); color: var(--text);
    border-radius: 12px 0 0 12px;
}
.search-wael .form-control::placeholder { color: var(--muted); }
.search-wael .form-control:focus { box-shadow: none; border-color: var(--gold); }
.search-wael .btn { border-radius: 0 12px 12px 0; }
.search-results {
    position: absolute; top: 100%; left: 0; right: 0; z-index: 1040;
    background: var(--surface); border: 1px solid var(--border);
    max-height: 360px; overflow-y: auto; display: none;
}
.search-results a {
    display: flex; gap: .75rem; align-items: center; padding: .6rem .8rem;
    color: var(--text); border-bottom: 1px solid var(--border);
}
.search-results a:hover { background: var(--surface-2); }
.search-results img { width: 44px; height: 44px; object-fit: cover; }

/* Mega-menú */
.mega-menu .dropdown-menu { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; }
.mega-menu .dropdown-item { color: var(--text); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; }
.mega-menu .dropdown-item:hover { background: var(--surface-2); color: var(--gold); }

/* ---------- Cards de producto ---------- */
.card-producto {
    position: relative;
    background: var(--surface); border: 1px solid var(--border); border-radius: 16px;
    overflow: hidden; transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
    height: 100%; display: flex; flex-direction: column;
    box-shadow: var(--shadow-sm);
}
.card-producto::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: var(--gold); transform: scaleX(0); transform-origin: left;
    transition: transform .25s ease; z-index: 3;
}
.card-producto:hover { border-color: var(--gold); transform: translateY(-6px); box-shadow: var(--shadow-md); }
.card-producto:hover::before { transform: scaleX(1); }
.card-producto .img-wrap .badge { z-index: 5; }   /* badge siempre sobre la imagen, incluso en hover */
.card-producto .img-wrap {
    position: relative; aspect-ratio: 1/1; border-radius: 16px 16px 0 0;
    background: radial-gradient(circle at 50% 38%, #1b1b1b 0%, #0e0e0e 100%);
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.card-producto .img-wrap img { width: 100%; height: 100%; object-fit: contain; padding: 16px; transition: transform .35s ease; }
.card-producto .cuerpo { padding: 16px; display: flex; flex-direction: column; flex-grow: 1; }
.card-producto:hover .img-wrap img { transform: scale(1.06); }
.card-producto .marca { color: var(--gold); font-family: 'Montserrat', sans-serif; font-size: .68rem; text-transform: uppercase; letter-spacing: 2.5px; font-weight: 600; }
.card-producto .nombre { color: var(--text); font-family: 'Cormorant', Georgia, serif; font-size: 1.35rem; font-weight: 600; line-height: 1.15; text-transform: none; letter-spacing: 0; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-producto .precio { color: var(--text); font-family: 'Cormorant', Georgia, serif; font-weight: 700; font-size: 1.7rem; letter-spacing: 0; }
.card-producto .precio-old { color: var(--muted); text-decoration: line-through; font-size: .85rem; }

.badge { font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; border-radius: 6px; font-weight: 600; }
.badge-oferta { background: var(--err); color: #fff; }
.badge-stock-out { background: var(--surface-2); color: var(--muted); }
.badge-marca { background: transparent; color: var(--gold); border: 1px solid var(--border); }

/* ---------- Hero editorial luxury (espresso + marco dorado) ---------- */
.hero-full { position: relative; width: 100%; }
.hero-slide {
    position: relative; min-height: 540px; display: flex; align-items: center;
    padding: 72px 0;
    background:
        radial-gradient(1100px 520px at 78% 8%, rgba(21,127,112,.16), transparent 62%),
        linear-gradient(120deg, #1a2c29 0%, #13211f 55%, #0d1716 100%);
    overflow: hidden;
}
/* hairline dorada superior e inferior */
.hero-slide::before, .hero-slide::after {
    content: ''; position: absolute; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(21,127,112,.55), transparent);
}
.hero-slide::before { top: 0; }
.hero-slide::after { bottom: 0; }
.hero-glow {
    position: absolute; width: 460px; height: 460px; right: -80px; top: -120px;
    background: radial-gradient(circle, rgba(21,127,112,.22), transparent 70%);
    pointer-events: none; filter: blur(8px);
}
.hero-content { position: relative; z-index: 2; }

/* Columna de texto */
.hero-copy { color: #f4efe7; }
.hero-eyebrow {
    display: inline-flex; align-items: center; gap: 12px; margin-bottom: 22px;
    font-family: 'Montserrat', sans-serif; text-transform: uppercase;
    letter-spacing: 3.5px; font-size: .72rem; font-weight: 600; color: var(--gold);
}
.hero-rule { display: inline-block; width: 38px; height: 1px; background: var(--gold); opacity: .8; }
.hero-title {
    font-family: 'Cormorant', Georgia, serif; font-weight: 600;
    font-size: clamp(2.8rem, 5.4vw, 4.6rem); line-height: 1.04; letter-spacing: 0;
    color: #fbf8f3; margin-bottom: 18px;
}
.hero-sub {
    font-size: 1.06rem; line-height: 1.7; color: rgba(244,239,231,.74);
    max-width: 520px; margin-bottom: 30px;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 30px; }
.hero-actions .btn-outline-gold { color: var(--gold); border-color: rgba(21,127,112,.55); }
.hero-actions .btn-outline-gold:hover { background: var(--gold); color: #1a1714; border-color: var(--gold); }

/* Fila de confianza: separadores dorados, sin cajas */
.hero-trust { display: flex; flex-wrap: wrap; align-items: center; gap: 10px 20px; }
.hero-trust-item {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: 'Montserrat', sans-serif; text-transform: uppercase;
    letter-spacing: 1.5px; font-size: .72rem; font-weight: 600; color: rgba(244,239,231,.82);
}
.hero-trust-item i { color: var(--gold); font-size: 1.05rem; }
.hero-trust-item + .hero-trust-item { padding-left: 20px; border-left: 1px solid rgba(21,127,112,.28); }

/* Visual enmarcado en dorado */
.hero-visual { display: flex; justify-content: center; }
.hero-frame {
    position: relative; margin: 0; width: 100%; max-width: 460px; aspect-ratio: 4/3;
    border-radius: 16px; overflow: hidden; padding: 10px;
    background: linear-gradient(160deg, rgba(21,127,112,.30), rgba(21,127,112,.06));
    box-shadow: 0 30px 70px rgba(0,0,0,.45);
}
.hero-frame::after {
    content: ''; position: absolute; inset: 10px; border-radius: 10px;
    border: 1px solid rgba(21,127,112,.45); pointer-events: none; z-index: 2;
}
.hero-frame img {
    width: 100%; height: 100%; object-fit: cover; border-radius: 10px;
    display: block; background: #0d1716;
}

/* Carrusel */
.hero-carousel .carousel-control-prev, .hero-carousel .carousel-control-next { width: 6%; opacity: .55; }
.hero-carousel .carousel-control-prev:hover, .hero-carousel .carousel-control-next:hover { opacity: 1; }
.hero-carousel .carousel-indicators { margin-bottom: 1rem; }
.hero-carousel .carousel-indicators [data-bs-target] { width: 26px; height: 3px; border-radius: 0; background: var(--gold); opacity: .4; }
.hero-carousel .carousel-indicators .active { opacity: 1; }
@media (max-width: 991.98px){
    .hero-slide { min-height: 0; padding: 56px 0; text-align: left; }
    .hero-visual { margin-top: 8px; }
    .hero-frame { max-width: 380px; }
    /* Flechas del carrusel estorban en táctil: se usa swipe + indicadores */
    .hero-carousel .carousel-control-prev, .hero-carousel .carousel-control-next { display: none; }
    /* Mini-cart no más ancho que la pantalla */
    #miniCart { --bs-offcanvas-width: min(360px, 90vw); max-width: 90vw; }
}
@media (max-width: 575.98px){
    .hero-slide { padding: 44px 0; }
    .hero-trust-item + .hero-trust-item { padding-left: 0; border-left: 0; }
    .hero-sub { font-size: 1rem; }
    .hero-title { font-size: clamp(2rem, 9vw, 2.6rem); overflow-wrap: break-word; }
    .hero-glow { width: 280px; height: 280px; right: -60px; }
}

/* ---------- Beneficios ---------- */
.benefit { display: flex; align-items: center; gap: .75rem; color: var(--muted); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; }
.benefit i { color: var(--gold); font-size: 1.5rem; }

/* ---------- Secciones ---------- */
.section-title { position: relative; display: inline-block; }
.section-title::after { content: ''; display: block; width: 56px; height: 3px; background: var(--gold); margin-top: 8px; }

/* Franjas full-width con fondos alternados (ritmo tipo Nordico) */
.band { width: 100%; padding: 56px 0; }
.band-surface { background: var(--surface); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.band-tight { padding: 28px 0; }
.band-accent {
    background:
        linear-gradient(120deg, rgba(21,127,112,.10), transparent 60%),
        var(--surface);
    border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
@media (max-width: 575.98px){ .band { padding: 40px 0; } }

/* Franja de marcas (banda oscura) */
.brands-strip { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.brands-strip .brand-chip { flex: 1 1 140px; max-width: 200px; }

/* Encabezado de categoría / catálogo (estilo barber) */
.catalog-head {
    position: relative; padding: 34px 0;
    background: linear-gradient(120deg, var(--surface) 0%, #13211f 85%);
    border-bottom: 1px solid var(--border);
}
.catalog-head::after {
    content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 3px;
    background: repeating-linear-gradient(45deg,
        #c62828 0 8px, #f5f0e6 8px 16px, #1c5fa8 16px 24px, #f5f0e6 24px 32px);
    background-size: 45px 45px; opacity: .55;
}

/* ---------- Cards de categoría con imagen ---------- */
.cat-card {
    position: relative; display: flex; aspect-ratio: 1/1.05; overflow: hidden;
    border-radius: 16px; border: 1px solid var(--border); box-shadow: var(--shadow-sm);
    transition: transform .25s ease, border-color .2s ease, box-shadow .2s ease; text-decoration: none;
}
.cat-card:hover { transform: translateY(-5px); border-color: var(--gold); box-shadow: var(--shadow-md); }
.cat-card > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; background: #fff; transition: transform .4s ease; }
.cat-card:hover > img { transform: scale(1.06); }
.cat-card-empty { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: radial-gradient(circle at 50% 38%, #1b1b1b, #0c0c0c); }
.cat-card-empty i { font-size: 2.6rem; color: var(--gold); opacity: .55; }
.cat-card-overlay { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.9) 0%, rgba(0,0,0,.35) 45%, rgba(0,0,0,.05) 100%); }
.cat-card-body { position: relative; z-index: 2; margin-top: auto; padding: 16px; width: 100%; }
.cat-card-title { display: block; color: #fff; font-family: 'Cormorant', Georgia, serif; font-weight: 600; font-size: 1.7rem; letter-spacing: 0; line-height: 1.05; }
.cat-card-count { display: block; color: rgba(255,255,255,.7); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; font-size: .78rem; margin-top: 2px; }

/* ---------- Marcas ---------- */
.brand-chip {
    background: var(--surface); border: 1px solid var(--border); border-radius: 12px;
    padding: 1rem; display: flex; align-items: center; justify-content: center;
    color: var(--text); font-family: 'Montserrat', sans-serif; font-weight: 600;
    text-transform: uppercase; letter-spacing: 1.5px; transition: all .2s ease; min-height: 72px;
}
.brand-chip:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.brand-logo-img { max-height: 42px; max-width: 130px; object-fit: contain; opacity: .92; transition: opacity .2s; }
.brand-chip:hover .brand-logo-img { opacity: 1; }

/* ---------- Auth (login / registro) split ---------- */
.auth-split { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: stretch; }
.auth-aside {
    position: relative; overflow: hidden; border-radius: 16px;
    background: linear-gradient(135deg, #16302c 0%, #0d1716 75%);
    border: 1px solid var(--border); box-shadow: var(--shadow-md);
    padding: 48px; display: flex; align-items: center;
}
.auth-aside::before {
    content: ''; position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(520px 300px at 90% 0%, rgba(21,127,112,.10), transparent 70%);
}
.auth-aside::after {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 6px;
    background: repeating-linear-gradient(45deg,#c62828 0 12px,#f5f0e6 12px 24px,#1c5fa8 24px 36px,#f5f0e6 36px 48px);
    background-size: 68px 68px;
}
.auth-aside-inner { position: relative; z-index: 1; }
.auth-benefits { list-style: none; padding: 0; margin: 26px 0 0; }
.auth-benefits li { display: flex; align-items: center; gap: 12px; padding: 9px 0; color: var(--text); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; }
.auth-benefits i { color: var(--gold); font-size: 1.35rem; flex-shrink: 0; }
.auth-card { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 30px; box-shadow: var(--shadow-md); }
@media (max-width: 991.98px){ .auth-split { grid-template-columns: 1fr; } .auth-aside { display: none; } }

/* ---------- Admin: zonas de envío ---------- */
.zona-badge { background: var(--gold); color: #0a0a0a; font-family: 'Montserrat', sans-serif; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 4px 12px; border-radius: 6px; font-size: .8rem; }
.zona-prov { border-color: var(--gold) !important; box-shadow: 0 0 0 2px rgba(21,127,112,.12); }
.zona-nota { background: rgba(21,127,112,.08); border: 1px solid var(--border); border-radius: 10px; padding: 12px; color: var(--muted); line-height: 1.6; }
.dist-list { max-height: 200px; overflow-y: auto; border: 1px solid var(--border); border-radius: 10px; padding: 8px; }
.dist-row { border-bottom: 1px solid var(--border); }
.dist-row:last-child { border-bottom: 0; }
.rounded-10 { border-radius: 10px; }
.label-upper { text-transform: uppercase; letter-spacing: 1px; }

/* ---------- Toggle de envío (Lima / Provincia) ---------- */
.envio-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.envio-opt { margin: 0; cursor: pointer; }
.envio-opt input { position: absolute; opacity: 0; pointer-events: none; }
.envio-card { display: flex; align-items: center; gap: 12px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 14px; padding: 14px; transition: border-color .2s, background .2s; height: 100%; }
.envio-card i { font-size: 1.6rem; color: var(--gold); flex-shrink: 0; }
.envio-card strong { display: block; font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: .5px; }
.envio-card small { color: var(--muted); }
.envio-opt:hover .envio-card { border-color: var(--gold); }
.envio-opt input:checked + .envio-card { border-color: var(--gold); background: rgba(21,127,112,.07); }
@media (max-width: 575.98px){ .envio-toggle { grid-template-columns: 1fr; } }

/* ---------- Aviso zona sin cobertura ---------- */
.zona-roja-aviso {
    display: flex; gap: 12px; align-items: flex-start;
    background: rgba(220,38,38,.12); border: 1px solid rgba(220,38,38,.5);
    border-radius: 14px; padding: 14px 16px;
}
.zona-roja-aviso > i { color: #ef4444; font-size: 1.5rem; flex-shrink: 0; }
.zona-roja-aviso strong { color: var(--text); }
.btn:disabled, .btn.disabled { opacity: .5; cursor: not-allowed; }

/* ---------- Mapa de entrega ---------- */
.mapa-entrega { height: 320px; border-radius: 14px; overflow: hidden; border: 1px solid var(--border); }
.mapa-entrega .leaflet-control-attribution { font-size: 9px; }
@media (max-width: 575.98px){ .mapa-entrega { height: 260px; } }

/* ---------- Métodos de pago (tarjetas) ---------- */
.pay-options { display: grid; gap: 12px; }
.pay-option { display: block; cursor: pointer; margin: 0; }
.pay-option input { position: absolute; opacity: 0; pointer-events: none; }
.pay-card {
    display: flex; align-items: center; gap: 14px;
    background: var(--surface-2); border: 1px solid var(--border);
    border-radius: 14px; padding: 14px 16px; transition: border-color .2s, background .2s, transform .15s;
}
.pay-option:hover .pay-card { border-color: var(--gold); transform: translateY(-2px); }
.pay-option input:checked + .pay-card { border-color: var(--gold); background: rgba(21,127,112,.06); }
.pay-ico { width: 44px; height: 44px; border-radius: 10px; background: var(--bg); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pay-ico i { font-size: 1.4rem; color: var(--gold); }
.pay-info { flex-grow: 1; min-width: 0; }
.pay-info strong { display: block; color: var(--text); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: .5px; }
.pay-info small { color: var(--muted); }
.pay-check { color: var(--gold); font-size: 1.3rem; opacity: 0; transition: opacity .2s; flex-shrink: 0; }
.pay-option input:checked + .pay-card .pay-check { opacity: 1; }
.pay-detail { background: var(--surface-2); border: 1px solid var(--border); border-radius: 14px; padding: 16px; }
.pay-qr { width: 150px; height: 150px; object-fit: contain; background: #fff; border-radius: 12px; padding: 8px; flex-shrink: 0; }
.pay-qr-empty { display: flex; align-items: center; justify-content: center; background: var(--bg); border: 1px dashed var(--border); color: var(--muted); }
.pay-qr-empty i { font-size: 3rem; }

/* ---------- Páginas legales ---------- */
.legal h2 { color: var(--gold); margin-top: 1.6rem; margin-bottom: .6rem; }
.legal p, .legal li { color: var(--muted); line-height: 1.7; }
.legal strong { color: var(--text); }
.legal ul { padding-left: 1.2rem; }
.legal li { margin-bottom: .4rem; }

/* ---------- Caja de confianza (producto) ---------- */
.trust-box { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.trust-item {
    display: flex; align-items: center; gap: 10px;
    background: var(--surface-2); border: 1px solid var(--border);
    border-radius: 12px; padding: 12px 14px;
}
.trust-item i { color: var(--gold); font-size: 1.5rem; flex-shrink: 0; }
.trust-item strong { display: block; color: var(--text); font-size: .82rem; font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: .5px; line-height: 1.15; }
.trust-item span { color: var(--muted); font-size: .72rem; }
@media (max-width: 575.98px){ .trust-box { grid-template-columns: 1fr; } }

/* ---------- Galería producto ---------- */
.galeria-main { position: relative; background: var(--surface-2); border: 1px solid var(--border); border-radius: 12px; aspect-ratio: 1/1; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.gal-zoom-hint {
    position: absolute; top: 12px; right: 12px; z-index: 2;
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(10,10,10,.6); border: 1px solid var(--border); color: var(--gold);
    display: flex; align-items: center; justify-content: center; font-size: 1.15rem;
    pointer-events: none; transition: background .2s, transform .2s;
}
.galeria-main:hover .gal-zoom-hint { background: var(--gold); color: #0a0a0a; transform: scale(1.05); }

/* Visor a pantalla completa con zoom */
.lightbox { position: fixed; inset: 0; z-index: 2000; background: rgba(0,0,0,.93); display: none; align-items: center; justify-content: center; }
.lightbox.open { display: flex; }
.lightbox img { max-width: 92vw; max-height: 88vh; object-fit: contain; background: #fff; border-radius: 8px; cursor: zoom-in; user-select: none; -webkit-user-drag: none; transition: transform .15s ease; }
.lightbox img.zoomed { cursor: zoom-out; }
.lightbox-close { position: absolute; top: 18px; right: 22px; z-index: 2; width: 46px; height: 46px; border-radius: 50%; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.3); color: #fff; font-size: 1.3rem; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background .2s; }
.lightbox-close:hover { background: rgba(255,255,255,.25); }
.art-modal-body { max-width: 92vw; max-height: 88vh; display: flex; }
.art-modal-body img, .art-modal-body video { max-width: 92vw; max-height: 88vh; object-fit: contain; border-radius: 8px; background: #000; }
.galeria-main img { width: 100%; height: 100%; object-fit: contain; padding: 24px; transition: transform .3s ease; }
.galeria-thumbs { display: flex; gap: .5rem; flex-wrap: wrap; }
.galeria-thumb { width: 64px; height: 64px; border-radius: 12px; background: var(--surface-2); overflow: hidden; border: 2px solid var(--border); cursor: pointer; transition: border-color .2s ease; }
.galeria-thumb.active, .galeria-thumb:hover { border-color: var(--gold); }
.galeria-thumb img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }

/* ---------- Forms ---------- */
.form-control, .form-select {
    background: var(--surface); border: 1px solid var(--border); color: var(--text); border-radius: 12px;
}
.form-control::placeholder { color: var(--muted); }
.form-control:focus, .form-select:focus { background: var(--surface); color: var(--text); border-color: var(--gold); box-shadow: 0 0 0 .2rem rgba(21,127,112,.12); }
.form-label { color: var(--text); font-family: 'Montserrat', sans-serif; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; font-size: .85rem; }
.form-check-input { background-color: var(--surface-2); border: 1px solid var(--muted); cursor: pointer; }
.form-check-input:checked { background-color: var(--gold); border-color: var(--gold); box-shadow: 0 0 0 2px rgba(21,127,112,.25); }
.form-check-input:focus { border-color: var(--gold); box-shadow: 0 0 0 .2rem rgba(21,127,112,.2); }
.form-check-label { cursor: pointer; }
.form-check-input:checked ~ .form-check-label { color: var(--gold); }

/* ---------- Cantidad ---------- */
.qty-group { display: inline-flex; align-items: center; border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.qty-group button { background: var(--surface-2); color: var(--text); border: none; width: 40px; height: 42px; font-size: 1.1rem; }
.qty-group button:hover { color: var(--gold); }
.qty-group input { width: 52px; height: 42px; text-align: center; background: var(--surface); border: none; color: var(--text); }

/* ---------- Tablas ---------- */
.table-dark-wael {
    --bs-table-bg: transparent;
    --bs-table-color: var(--text);
    --bs-table-border-color: var(--border);
    --bs-table-striped-bg: rgba(255,255,255,.02);
    --bs-table-striped-color: var(--text);
    --bs-table-hover-bg: rgba(21,127,112,.06);
    --bs-table-hover-color: var(--text);
    color: var(--text);
}
.table-dark-wael > :not(caption) > * > * { background-color: transparent; color: var(--text); }
.table-dark-wael th { color: var(--muted); border-color: var(--border); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.table-dark-wael td { border-color: var(--border); vertical-align: middle; }

/* ---------- Footer ---------- */
.footer-wael { background: var(--surface); border-top: 1px solid var(--border); color: var(--muted); margin-top: 64px; }
.footer-wael h6 { color: var(--text); }
.footer-wael a { color: var(--muted); }
.footer-wael a:hover { color: var(--gold); }
.footer-wael .social a { font-size: 1.5rem; color: var(--text); }
.footer-wael .social a:hover { color: var(--gold); }

/* Franja de marcas del footer */
.footer-brands { border-bottom: 1px solid var(--border); padding: 26px 0; }
.footer-brands-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 20px; }
.footer-brand {
    font-family: 'Montserrat', sans-serif; font-size: 1.5rem; letter-spacing: 2px;
    color: var(--muted); opacity: .7; transition: opacity .2s, color .2s; flex: 1 1 auto; text-align: center;
}
.footer-brand:hover { opacity: 1; color: var(--gold); }

/* Newsletter */
.newsletter-form { max-width: 520px; }
.newsletter-form .form-control { border-radius: 50px 0 0 50px; padding: .7rem 1.2rem; }
.newsletter-form .btn { border-radius: 0 50px 50px 0; padding-left: 1.6rem; padding-right: 1.6rem; }

/* Iconos circulares de contacto */
.footer-ico {
    width: 64px; height: 64px; border-radius: 50%;
    background: var(--surface-2); border: 1px solid var(--border);
    display: flex; align-items: center; justify-content: center; margin: 0 auto 14px;
    transition: border-color .2s, transform .2s;
}
.footer-ico i { font-size: 1.6rem; color: var(--gold); }
.col-lg-3:hover .footer-ico { border-color: var(--gold); transform: translateY(-3px); }

/* Barra legal inferior */
.footer-bottom { background: var(--bg); border-top: 1px solid var(--border); padding: 22px 0; }
.footer-bottom a { color: var(--muted); text-transform: uppercase; font-family: 'Montserrat', sans-serif; letter-spacing: 1px; }
.footer-bottom a:hover { color: var(--gold); }

/* ---------- Mini-cart (preview) ---------- */
.mini-cart-item {
    display: flex; gap: 12px; align-items: center;
    background: var(--surface-2); border: 1px solid var(--border);
    border-radius: 14px; padding: 10px; margin-bottom: 10px;
}
.mini-cart-thumb { width: 56px; height: 56px; object-fit: contain; background: #0e0e0e; border-radius: 10px; flex-shrink: 0; padding: 5px; }
.mini-cart-name { font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: .5px; font-size: .85rem; color: var(--text); }
.mini-cart-remove { background: transparent; border: none; color: var(--muted); font-size: 1.15rem; line-height: 1; padding: 2px; }
.mini-cart-remove:hover { color: var(--err); }
#miniCart { border-radius: 18px 0 0 18px; }

/* ---------- Sección TikTok ---------- */
.tiktok-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
.tiktok-card {
    position: relative; aspect-ratio: 9/14; border-radius: 14px; overflow: hidden;
    background: radial-gradient(circle at 50% 35%, #1b1b1b, #0c0c0c); border: 1px solid var(--border);
    display: flex; align-items: flex-end; transition: transform .2s, border-color .2s;
}
.tiktok-card:hover { transform: translateY(-4px); border-color: var(--gold); }
.tiktok-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.tiktok-card .tk-overlay { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.8), transparent 55%); }
.tiktok-card .tk-title {
    position: relative; z-index: 2; padding: 12px; color: #fff;
    font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: .5px; font-size: .8rem; font-weight: 600;
}
.tiktok-card .tk-play { position: absolute; top: 10px; right: 10px; z-index: 2; color: #fff; font-size: 1.1rem; opacity: .85; }
.tiktok-card { cursor: pointer; }

/* Modal reproductor de TikTok */
.tk-modal { position: fixed; inset: 0; z-index: 2000; background: rgba(0,0,0,.92); display: none; align-items: center; justify-content: center; padding: 20px; }
.tk-modal.open { display: flex; }
.tk-modal-box { position: relative; width: 100%; max-width: 340px; }
.tk-modal-body { width: 100%; height: min(80vh, 720px); background: #000; border-radius: 14px; overflow: hidden; }
.tk-modal-body iframe { width: 100%; height: 100%; border: 0; }
.tk-modal-close { position: absolute; top: -48px; right: 0; width: 42px; height: 42px; border-radius: 50%; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.3); color: #fff; font-size: 1.2rem; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background .2s; }
.tk-modal-close:hover { background: rgba(255,255,255,.28); }
@media (max-width: 991.98px){ .tiktok-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 575.98px){ .tiktok-grid { grid-template-columns: repeat(2, 1fr); } .footer-brand { flex-basis: 40%; } }

/* ---------- ART · Máquinas personalizadas ---------- */
.nav-art { color: var(--gold) !important; }
.art-hero {
    position: relative; padding: 80px 0 64px;
    background: linear-gradient(120deg, #16302c 0%, #0d1716 80%);
    border-bottom: 1px solid var(--border); overflow: hidden;
}
.art-hero::before {
    content: ''; position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(700px 360px at 80% 0%, rgba(21,127,112,.08), transparent 70%);
}
.art-hero::after {
    content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 4px;
    background: repeating-linear-gradient(45deg,#c62828 0 10px,#f5f0e6 10px 20px,#1c5fa8 20px 30px,#f5f0e6 30px 40px);
    background-size: 56px 56px; opacity: .6;
}
.art-hero-inner { position: relative; z-index: 1; }

/* Grid de la página ART (masonry-like con CSS columns) */
.art-grid { columns: 4 240px; column-gap: 16px; }
.art-card {
    position: relative; margin: 0 0 16px; break-inside: avoid; border-radius: 14px; overflow: hidden;
    border: 1px solid var(--border); background: #0e0e0e; cursor: pointer; display: block;
    transition: transform .25s ease, border-color .2s ease, box-shadow .2s ease;
}
.art-card:hover { transform: translateY(-4px); border-color: var(--gold); box-shadow: var(--shadow-md); }
.art-card img, .art-card video { width: 100%; display: block; }
.art-card video { background: #000; }
.art-overlay { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.75) 0%, rgba(0,0,0,.05) 45%, transparent 100%); opacity: 0; transition: opacity .25s; pointer-events: none; }
.art-card:hover .art-overlay { opacity: 1; }
.art-play { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 2; color: #fff; font-size: 2.6rem; opacity: .9; text-shadow: 0 2px 12px rgba(0,0,0,.6); pointer-events: none; }
.art-cap { position: absolute; left: 0; bottom: 0; z-index: 2; padding: 14px; width: 100%; opacity: 0; transform: translateY(8px); transition: opacity .25s, transform .25s; pointer-events: none; }
.art-card:hover .art-cap { opacity: 1; transform: translateY(0); }
.art-cap strong { display: block; color: #fff; font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: .5px; }
.art-cap span { display: block; color: rgba(255,255,255,.75); font-size: .82rem; }

/* Teaser de ART en la home */
.art-teaser-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.art-teaser-card { position: relative; aspect-ratio: 1/1; border-radius: 14px; overflow: hidden; border: 1px solid var(--border); background: #0e0e0e; display: block; transition: transform .2s, border-color .2s; }
.art-teaser-card:hover { transform: translateY(-3px); border-color: var(--gold); }
.art-teaser-card img, .art-teaser-card video { width: 100%; height: 100%; object-fit: cover; }
.art-teaser-empty { aspect-ratio: 16/9; border: 1px dashed var(--border); border-radius: 16px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; color: var(--muted); }
.art-teaser-empty i { font-size: 3rem; color: var(--gold); opacity: .6; }
.art-teaser-empty span { font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 2px; }

/* Previews/miniaturas en admin ART */
.art-preview { width: 100%; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); background: #0e0e0e; }
.art-preview img, .art-preview video { width: 100%; display: block; max-height: 320px; object-fit: contain; background: #000; }
.art-thumb { width: 48px; height: 48px; object-fit: cover; border-radius: 8px; border: 1px solid var(--border); background: #0e0e0e; flex-shrink: 0; }
.art-thumb-vid, .art-thumb-empty { display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 1.2rem; }
.art-thumb-empty { color: var(--muted); }

@media (max-width: 991.98px){ .art-grid { columns: 3 200px; } }
@media (max-width: 575.98px){
    .art-grid { columns: 2 140px; column-gap: 10px; }
    .art-card { margin-bottom: 10px; }
    .art-hero { padding: 54px 0 44px; }
    .art-play { font-size: 2rem; }
}

/* ---------- Widget / Bot de WhatsApp (ref: adspublicidaddigital) ---------- */
.wa-widget { position:fixed; bottom:24px; right:24px; z-index:1100; display:flex; flex-direction:column; align-items:flex-end; gap:12px; pointer-events:none; }
.wa-fab { width:60px; height:60px; background:#25d366; border:none; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; box-shadow:0 6px 28px rgba(37,211,102,0.5); transition:transform .2s, box-shadow .2s; position:relative; flex-shrink:0; pointer-events:auto; }
.wa-fab:hover { transform:scale(1.08); box-shadow:0 10px 36px rgba(37,211,102,0.6); }
.wa-fab-icon { transition:opacity .2s; line-height:0; }
.wa-badge { position:absolute; top:-2px; right:-2px; width:20px; height:20px; background:#ef4444; color:#fff; border-radius:50%; font-size:.65rem; font-weight:800; display:flex; align-items:center; justify-content:center; animation:wa-pulse 2s ease-in-out infinite; }
.wa-chat { width:min(330px, calc(100vw - 32px)); max-width:calc(100vw - 32px); background:#fff; border-radius:18px; overflow:hidden; box-shadow:0 16px 50px rgba(0,0,0,0.45); transform:translateY(20px) scale(.95); opacity:0; pointer-events:none; transition:transform .3s cubic-bezier(.34,1.56,.64,1), opacity .25s; transform-origin:bottom right; }
.wa-chat-open { transform:translateY(0) scale(1); opacity:1; pointer-events:all; }
.wa-chat-header { background:#075e54; padding:14px 16px; display:flex; align-items:center; gap:10px; }
.wa-avatar { width:44px; height:44px; background:#25d366; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.85rem; font-weight:800; color:#fff; flex-shrink:0; letter-spacing:-.5px; font-family:'Montserrat',sans-serif; }
.wa-info { flex:1; min-width:0; }
.wa-name { color:#fff; font-weight:700; font-size:.9rem; font-family:'Montserrat',sans-serif; text-transform:none; letter-spacing:0; }
.wa-status { color:rgba(255,255,255,.75); font-size:.72rem; display:flex; align-items:center; gap:5px; margin-top:2px; }
.wa-dot { width:7px; height:7px; background:#25d366; border-radius:50%; display:inline-block; animation:wa-blink 2s ease-in-out infinite; }
.wa-close-btn { background:rgba(255,255,255,.15); border:none; color:#fff; width:28px; height:28px; border-radius:50%; font-size:.85rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s; flex-shrink:0; }
.wa-close-btn:hover { background:rgba(255,255,255,.3); }
.wa-chat-body { background:#ece5dd; padding:16px 12px; min-height:160px; max-height:260px; overflow-y:auto; }
.wa-messages { display:flex; flex-direction:column; gap:8px; }
.wa-msg { max-width:82%; padding:8px 12px; border-radius:10px; font-size:.87rem; line-height:1.5; animation:wa-msgin .3s ease; word-break:break-word; }
.wa-msg-in { background:#fff; color:#1a1a1a; border-radius:0 10px 10px 10px; align-self:flex-start; box-shadow:0 1px 2px rgba(0,0,0,0.1); }
.wa-typing { background:#fff; border-radius:0 10px 10px 10px; align-self:flex-start; display:flex; gap:4px; padding:12px 14px; box-shadow:0 1px 2px rgba(0,0,0,0.1); }
.wa-typing span { width:7px; height:7px; background:#aaa; border-radius:50%; animation:wa-typingdot 1.2s ease-in-out infinite; }
.wa-typing span:nth-child(2){animation-delay:.2s}
.wa-typing span:nth-child(3){animation-delay:.4s}
.wa-chat-footer { background:#f0f0f0; padding:12px; }
.wa-open-btn { display:flex; align-items:center; justify-content:center; gap:8px; background:#25d366; color:#fff!important; text-decoration:none; border-radius:50px; padding:10px 16px; font-size:.85rem; font-weight:700; transition:background .2s, transform .15s; width:100%; font-family:'Montserrat',sans-serif; text-transform:uppercase; letter-spacing:1px; }
.wa-open-btn:hover { background:#1ebe5d; transform:translateY(-1px); }
@keyframes wa-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.2)} }
@keyframes wa-blink { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes wa-msgin { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
@keyframes wa-typingdot { 0%,80%,100%{transform:translateY(0);opacity:.4} 40%{transform:translateY(-6px);opacity:1} }
@media (max-width:575.98px){ .wa-widget{right:12px;bottom:16px} }

/* ---------- Admin ---------- */
.admin-sidebar { background: var(--surface); border-right: 1px solid var(--border); min-height: 100vh; width: 240px; }
.admin-sidebar a { color: var(--muted); display: block; padding: .7rem 1rem; border-radius: 12px; font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.admin-sidebar a:hover, .admin-sidebar a.active { background: var(--surface-2); color: var(--gold); }
.admin-card { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow-sm); }
.search-toolbar { max-width: 360px; flex: 1; }
.prod-thumb { width: 36px; height: 36px; object-fit: contain; background: #0e0e0e; border-radius: 6px; flex-shrink: 0; }
.prod-thumb-lg { width: 70px; height: 70px; object-fit: contain; background: #0e0e0e; border-radius: 10px; flex-shrink: 0; border: 1px solid var(--border); }
.gal-admin-item { position: relative; width: 76px; height: 76px; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); background: #0e0e0e; flex-shrink: 0; }
.gal-admin-item img { width: 100%; height: 100%; object-fit: contain; padding: 5px; }
.gal-admin-del { position: absolute; top: 3px; right: 3px; width: 22px; height: 22px; border-radius: 50%; background: rgba(220,38,38,.92); color: #fff; display: flex; align-items: center; justify-content: center; font-size: .65rem; line-height: 1; }
.gal-admin-del:hover { background: #ef4444; color: #fff; transform: scale(1.1); }
.banner-preview { width: 100%; aspect-ratio: 21/9; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); background: #0e0e0e; }
.banner-preview img { width: 100%; height: 100%; object-fit: cover; }
.banner-thumb { width: 80px; height: 44px; object-fit: cover; border-radius: 8px; border: 1px solid var(--border); background: #0e0e0e; flex-shrink: 0; }
.banner-thumb-empty { display: flex; align-items: center; justify-content: center; color: var(--muted); font-size: 1.1rem; }
.tk-preview { width: 120px; aspect-ratio: 9/16; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); background: #0e0e0e; }
.tk-preview img { width: 100%; height: 100%; object-fit: cover; }
.tk-thumb { width: 38px; height: 54px; object-fit: cover; border-radius: 6px; border: 1px solid var(--border); background: #0e0e0e; flex-shrink: 0; }
.tk-thumb-empty { display: flex; align-items: center; justify-content: center; color: var(--muted); font-size: 1rem; }
.cat-admin-preview { width: 100%; height: 100px; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); background: #0e0e0e; }
.cat-admin-preview img { width: 100%; height: 100%; object-fit: cover; }
.cat-admin-thumb { width: 44px; height: 44px; object-fit: cover; border-radius: 8px; border: 1px solid var(--border); background: #0e0e0e; flex-shrink: 0; }
.cat-admin-thumb-empty { display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 1.1rem; }
.marca-admin-preview { width: 100%; height: 90px; border-radius: 10px; border: 1px solid var(--border); background: #0d1716; display: flex; align-items: center; justify-content: center; padding: 10px; }
.marca-admin-preview img { max-width: 100%; max-height: 100%; object-fit: contain; }
.marca-admin-thumb { width: 56px; height: 40px; object-fit: contain; border-radius: 6px; border: 1px solid var(--border); background: #0d1716; flex-shrink: 0; padding: 3px; }
.marca-admin-thumb-empty { display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 1.1rem; }
.admin-sidebar a.active { border-left: 3px solid var(--gold); }
.nav-badge { background: var(--err); color: #fff; font-size: .68rem; font-weight: 700; border-radius: 10px; padding: 1px 7px; margin-left: 4px; vertical-align: middle; }
.stat-card .value { font-size: 2rem; color: var(--gold); font-family: 'Montserrat', sans-serif; letter-spacing: 1px; }

/* ---------- Modal (dark) ---------- */
.modal-content.bg-surface { background: var(--surface); color: var(--text); border-radius: 16px; }
.modal-content .modal-title { font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; }
.comp-img { max-width: 100%; max-height: 72vh; border-radius: 10px; background: #fff; }
.comp-frame { width: 100%; height: 72vh; border: 0; border-radius: 10px; background: #fff; }

/* Modales (TODOS): el cuerpo hace scroll interno y nunca excede la pantalla,
   por lo que el header y el footer (botones Cancelar/Actualizar) quedan siempre visibles.
   No depende de las clases de Bootstrap: se aplica a cualquier .modal-body del sistema. */
.modal-body {
    max-height: calc(100vh - 165px);
    max-height: calc(100dvh - 165px);   /* dvh respeta la barra del navegador en móvil */
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
.modal-dialog-scrollable .modal-body { min-height: 0; }
@media (max-width: 575.98px) {
    .modal-body { max-height: calc(100dvh - 130px); }
}

/* ---------- Utilidades ---------- */
.divider { height: 1px; background: var(--border); border: 0; }
img { max-width: 100%; }

/* ---------- Accesibilidad ---------- */
:focus-visible { outline: 3px solid var(--gold); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;   /* corta los loops infinitos (badge/dot/typing) */
        transition-duration: .01ms !important;
        scroll-behavior: auto !important;
    }
}

/* ---------- Utilidades de layout (reemplazan estilos inline) ---------- */
.min-w-0 { min-width: 0; }
.mw-180 { max-width: 180px; }
.mw-280 { max-width: 280px; }
.mw-480 { max-width: 480px; }
.mw-520 { max-width: 520px; }
.mw-720 { max-width: 720px; }
.mw-820 { max-width: 820px; }
.w-140 { width: 140px; }
.w-100px { width: 100px; }
.w-80px { width: 80px; }
.login-card { width: 100%; max-width: 400px; }
.hero-content { position: relative; z-index: 2; }
.hero-img { max-height: 300px; opacity: .9; }
.cart-thumb { width: 56px; height: 56px; object-fit: contain; background: var(--surface-2); border-radius: 12px; }
.icon-xl { font-size: 3.5rem; }
.tabs-card { border-radius: 0 0 14px 14px; }
.sticky-90 { top: 90px; }
.accordion-button:focus { box-shadow: none; }
.accordion-button:not(.collapsed) { background: var(--surface-2); color: var(--gold); }
.accordion-button { font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.accordion-button::after { filter: invert(1); }

/* ---------- Tabs (Bootstrap nav-tabs en dark) ---------- */
.nav-tabs { --bs-nav-tabs-border-color: var(--border); }
.nav-tabs .nav-link { color: var(--muted); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1px; border: none; }
.nav-tabs .nav-link.active { color: var(--gold) !important; background: transparent; border-bottom: 2px solid var(--gold); }

/* ---------- Responsive: tablet ---------- */
@media (max-width: 991.98px) {
    .footer-wael { margin-top: 40px; }
    .sticky-90 { position: static !important; top: auto; }   /* no fijar columnas en táctil */
}

/* ---------- Responsive: móvil ---------- */
@media (max-width: 575.98px) {
    /* Tipografía display más contenida (evita desbordes en 320-375px) */
    h1, h2, h3 { letter-spacing: .5px; }
    .hero-slide { min-height: 380px; }
    .hero-slide h1, .hero-slide .display-5 { font-size: clamp(1.9rem, 8.5vw, 2.6rem); }
    .hero-content { padding-top: 6px; padding-bottom: 6px; }
    .hero-overlay { background: linear-gradient(0deg, rgba(10,10,10,.96) 8%, rgba(10,10,10,.5) 100%); }
    .section-title { font-size: 1.55rem; }
    .eyebrow { font-size: .7rem; letter-spacing: 3px; }
    .navbar-wael .brand-logo { font-size: 1.35rem; }
    .navbar-collapse { max-height: 82vh; overflow-y: auto; }

    /* Botones: menos tracking y padding para que no rompan línea */
    .btn { letter-spacing: 1px; min-height: 44px; }
    .btn-gold { padding: .6rem 1rem; }

    /* Cards de producto compactas (van en col-6 = 2 por fila) */
    .card-producto .cuerpo { padding: 12px; }
    .card-producto .img-wrap img { padding: 12px; }
    .card-producto .marca { font-size: .64rem; letter-spacing: 1.5px; }
    .card-producto .nombre { font-size: .9rem; letter-spacing: .3px; overflow-wrap: anywhere; }
    .card-producto .precio { font-size: 1.3rem; }
    .card-producto .mb-3 { margin-bottom: .6rem !important; }
    .card-producto .d-flex.gap-2 { gap: 6px !important; }
    .card-producto .btn-gold { padding: .55rem .4rem; font-size: .76rem; letter-spacing: .5px; }
    .card-producto .btn-gold .bi { display: none; }   /* sin ícono: gana ancho para el texto */
    .btn-fav { padding: .55rem; width: 44px; flex-shrink: 0; }

    /* Beneficios */
    .benefit { font-size: .8rem; gap: .5rem; }
    .benefit i { font-size: 1.2rem; }

    /* Marcas / categorías */
    .cat-card-title { font-size: 1.15rem; overflow-wrap: anywhere; }
    .brand-chip { min-height: 60px; padding: .75rem; font-size: .9rem; }

    /* Galería de producto */
    .galeria-main img { padding: 14px; }
    .galeria-thumb { width: 52px; height: 52px; }

    /* Cantidad: targets táctiles cómodos */
    .qty-group button { width: 44px; height: 44px; }
    .qty-group input { height: 44px; }

    /* Newsletter apilado (deja de comprimirse) */
    .newsletter-form .input-group { flex-direction: column; }
    .newsletter-form .form-control { width: 100% !important; flex: 0 0 auto !important; border-radius: 50px !important; margin-bottom: 10px; text-align: center; }
    .newsletter-form .btn { border-radius: 50px !important; width: 100%; }

    /* Footer: correos/direcciones largas que no rompen línea */
    .footer-wael p, .footer-wael .text-muted-2 { overflow-wrap: anywhere; word-break: break-word; }
    .footer-ico { width: 54px; height: 54px; }
    .footer-ico i { font-size: 1.4rem; }
    .footer-brand { font-size: 1.15rem; }
    .footer-brands-row { gap: 12px; }
    .footer-wael .social a { font-size: 1.35rem; }

    /* Modal / comprobante a pantalla casi completa */
    .comp-img, .comp-frame { max-height: 65vh; }
    .pay-qr { width: 130px; height: 130px; }

    /* Carrito: tabla → tarjetas apiladas (sin scroll horizontal) */
    .cart-table { border: 0; }
    .cart-table thead { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
    .cart-table, .cart-table tbody, .cart-table tr, .cart-table td { display: block; width: 100%; }
    .cart-table tr {
        background: var(--surface); border: 1px solid var(--border);
        border-radius: 14px; padding: 12px; margin-bottom: 12px;
    }
    .cart-table td { border: 0 !important; padding: .35rem 0; text-align: right; }
    .cart-table td[data-label]::before {
        content: attr(data-label); float: left; color: var(--muted);
        font-family: 'Montserrat', sans-serif; text-transform: uppercase;
        letter-spacing: 1px; font-size: .78rem; font-weight: 600;
    }
    .cart-table td[data-label="Producto"] { text-align: left; padding-bottom: .6rem; }
    .cart-table td[data-label="Producto"]::before { display: none; }
    .cart-table td[data-label="Cantidad"] .form-control { display: inline-block; }
    .cart-table .cart-remove-cell { text-align: right; padding-top: .4rem; }
}

/* ============================================================
   TEMA CLARO PREMIUM  ·  cuerpo claro + detalles oscuros (navbar/hero/footer)
   ============================================================ */
body { background-color: var(--bg); color: var(--text); }
body::before { display: none; }                 /* sin glows oscuros sobre fondo claro */
.section-title::after, .eyebrow { color: var(--gold); }

/* Sombras suaves estilo limpio */
.card-producto, .brand-chip, .admin-card, .cat-card, .tiktok-card, .art-card,
.envio-card, .pay-card, .trust-item, .mini-cart-item {
    box-shadow: 0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.06);
}
.card-producto:hover, .cat-card:hover { box-shadow: 0 14px 30px rgba(16,24,40,.13); }

/* Navbar OSCURO (detalle) con texto claro */
.topbar { background: var(--dark-2); border-bottom: 0; }
.topbar .tb-item, .topbar i { color: rgba(255,255,255,.72); }
.navbar-wael { background: var(--dark); backdrop-filter: none; -webkit-backdrop-filter: none; border-bottom: 0; box-shadow: 0 2px 10px rgba(16,24,40,.08); }
.navbar-wael .nav-link, .navbar-icon { color: #e9edf0 !important; }
.navbar-wael .nav-link:hover, .navbar-icon:hover, .navbar-wael .nav-art { color: var(--gold) !important; }
.search-wael .form-control { background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.16); color: #fff; }
.search-wael .form-control::placeholder { color: rgba(255,255,255,.55); }
.search-wael .form-control:focus { border-color: var(--gold); }
.mega-menu .dropdown-menu { box-shadow: 0 14px 40px rgba(16,24,40,.14); }

/* Botón acento (turquesa) con texto blanco */
.btn-gold { color: #fff; }
.btn-gold:hover { color: #fff; }
.btn-outline-gold:hover, .btn-gold:focus-visible { color: #fff; }
::selection { background: var(--gold); color: #fff; }

/* Fondos de imagen claros, crema cálida (antes negros) */
.card-producto .img-wrap { background: #f3efe9; }
.galeria-main { background: #f3efe9; }
.mini-cart-thumb, .cart-thumb { background: #f3efe9; }
.cat-card-empty { background: #ece6dd; }
.cat-card-empty i { opacity: .4; }
.tiktok-card, .art-card, .art-teaser-card { background: #ece6dd; }
.brand-chip { background: #fff; }

/* Bandas: superficie blanca, acento dorado tenue */
.band-surface { background: #fff; }
.band-accent { background: linear-gradient(120deg, rgba(21,127,112,.10), transparent 60%), #fff; }
.art-teaser.band-surface { background: #fff; }

/* Hero permanece oscuro: textos claros encima */
.hero-slide h1, .hero-slide .display-5, .hero-slide .display-6 { color: #f7f9fa; }
.hero-slide .text-muted-2 { color: rgba(255,255,255,.74) !important; }
/* art-hero tiene fondo OSCURO: textos claros */
.art-hero h1, .art-hero .display-3 { color: #fbf8f3; }
.art-hero .text-muted-2 { color: rgba(244,239,231,.74) !important; }
.art-hero .eyebrow { color: var(--gold); }

/* ============================================================
   MEGA MENÚ de categorías (con imágenes + destacados)
   ============================================================ */
/* Panel a TODO el ancho del contenedor (no pegado a un lado) */
.navbar-wael .container { position: relative; }
.mega-menu { position: static; }
.mega-panel {
    position: absolute; top: 100%; left: 0; right: 0; width: auto; max-width: none;
    padding: 0; overflow: hidden;
    border: 1px solid var(--border); border-radius: 16px;
    box-shadow: 0 26px 64px rgba(19,33,31,.20); background: #fff; margin-top: .6rem;
}
.mega-inner { display: grid; grid-template-columns: 1fr 320px; }
.mega-cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; padding: 20px; align-content: start; }
.mega-cat { display: flex; align-items: center; gap: 11px; padding: 8px 10px; border-radius: 10px; color: var(--text); transition: background .15s ease, color .15s ease; }
.mega-cat:hover { background: var(--surface-2); color: var(--gold); }
.mega-cat-ico { width: 40px; height: 40px; border-radius: 10px; background: var(--surface-2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; }
.mega-cat-ico img { width: 100%; height: 100%; object-fit: cover; }
.mega-cat-ico i { font-size: 1.15rem; color: var(--gold); }
.mega-cat-name { font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: .8rem; line-height: 1.15; }
/* Columna destacada (oscura) */
.mega-feature { background: linear-gradient(165deg, var(--dark) 0%, #0d1716 100%); color: #f4efe7; padding: 18px; display: flex; flex-direction: column; gap: 10px; }
.mega-feature-title { font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 2.5px; font-size: .68rem; color: var(--gold); font-weight: 600; }
.mega-prod { display: flex; gap: 11px; align-items: center; color: #f4efe7; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09); border-radius: 12px; padding: 9px; transition: border-color .2s ease; }
.mega-prod:hover { border-color: var(--gold); color: #fff; }
.mega-prod-img { width: 56px; height: 56px; border-radius: 9px; background: #fff; flex-shrink: 0; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.mega-prod-img img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
.mega-prod-name { display: block; font-family: 'Montserrat', sans-serif; font-size: .76rem; font-weight: 600; line-height: 1.2; max-height: 2.4em; overflow: hidden; }
.mega-prod-price { display: block; font-family: 'Cormorant', Georgia, serif; font-weight: 700; font-size: 1.15rem; color: var(--gold); margin-top: 2px; }
.mega-allcat { margin-top: auto; color: var(--gold); font-family: 'Montserrat', sans-serif; text-transform: uppercase; letter-spacing: 1.5px; font-size: .72rem; font-weight: 600; display: inline-flex; align-items: center; gap: 6px; }
.mega-allcat:hover { color: #fff; gap: 10px; }
@media (max-width: 991.98px){
    /* En móvil el menú está dentro del colapsable: panel plano, sin Popper */
    .mega-panel { position: static !important; transform: none !important; inset: auto !important;
        width: 100% !important; box-shadow: none; margin-top: 6px; border-radius: 12px; }
    .mega-inner { grid-template-columns: 1fr; }
    .mega-cats { grid-template-columns: 1fr 1fr; padding: 12px; }
    .mega-feature { display: none; }
}

/* ============================================================
   HERO · ondas teal ANIMADAS en la base + glow animado (plus visual)
   ============================================================ */
.hero-full { position: relative; }
.hero-waves { position: absolute; left: 0; right: 0; bottom: -1px; height: 100px; pointer-events: none; z-index: 6; overflow: hidden; }
.hero-wave {
    position: absolute; left: 0; bottom: 0; width: 200%;
    background-repeat: repeat-x; background-position: left bottom;
    background-size: 50% 100%; will-change: transform;
}
/* Onda 1 (teal profundo, lenta, hacia la izquierda) */
.hero-wave-1 {
    height: 100px; z-index: 1;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3E%3Cpath d='M0,50 C240,10 480,10 720,50 C960,90 1200,90 1440,50 L1440,100 L0,100 Z' fill='%23157f70' fill-opacity='0.55'/%3E%3C/svg%3E");
    animation: waveSlide 18s linear infinite;
}
/* Onda 2 (teal claro, media, hacia la derecha) */
.hero-wave-2 {
    height: 84px; z-index: 2;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3E%3Cpath d='M0,60 C240,95 480,95 720,60 C960,25 1200,25 1440,60 L1440,100 L0,100 Z' fill='%232a9d8f' fill-opacity='0.45'/%3E%3C/svg%3E");
    animation: waveSlide 11s linear infinite reverse;
}
/* Onda 3 (crema, funde con el cuerpo, lenta a la izquierda) */
.hero-wave-3 {
    height: 64px; z-index: 3;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3E%3Cpath d='M0,55 C240,20 480,20 720,55 C960,90 1200,90 1440,55 L1440,100 L0,100 Z' fill='%23faf8f5'/%3E%3C/svg%3E");
    animation: waveSlide 24s linear infinite;
}
@keyframes waveSlide { from { transform: translateX(0); } to { transform: translateX(-50%); } }
/* Glow teal con deriva suave */
.hero-glow { animation: heroGlowDrift 10s ease-in-out infinite; }
@keyframes heroGlowDrift {
    0%, 100% { transform: translate(0,0) scale(1); opacity: .85; }
    50%      { transform: translate(-34px, 22px) scale(1.14); opacity: 1; }
}
/* Las olas son decorativas y se piden con movimiento: se mantienen animadas
   aunque el sistema tenga "reduce motion" (la regla global las congelaría). */
@media (prefers-reduced-motion: reduce) {
    .hero-wave-1 { animation: waveSlide 18s linear infinite !important; }
    .hero-wave-2 { animation: waveSlide 11s linear infinite reverse !important; }
    .hero-wave-3 { animation: waveSlide 24s linear infinite !important; }
    .hero-glow   { animation: heroGlowDrift 10s ease-in-out infinite !important; }
}
@media (max-width: 575.98px){
    .hero-waves { height: 56px; }
    .hero-wave-1 { height: 56px; }
    .hero-wave-2 { height: 46px; }
    .hero-wave-3 { height: 36px; }
}

/* Footer OSCURO (detalle) */
.footer-wael { background: var(--dark); color: rgba(255,255,255,.62); border-top: 0; }
.footer-wael h6, .footer-wael .social a { color: #f1f4f6; }
.footer-wael a { color: rgba(255,255,255,.62); }
.footer-wael a:hover { color: var(--gold); }
.footer-brands { border-bottom-color: rgba(255,255,255,.10); }
.footer-ico { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); }
.footer-bottom { background: #0c1413; border-top: 1px solid rgba(255,255,255,.06); }
.footer-bottom a { color: rgba(255,255,255,.55); }
.newsletter-form .form-control { background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.16); color: #fff; }
.newsletter-form .form-control::placeholder { color: rgba(255,255,255,.5); }

/* Scrollbar claro */
::-webkit-scrollbar-track { background: #e9ecef; }
::-webkit-scrollbar-thumb { background: #ccd2d8; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

/* ---- Tipografía moderna: menos MAYÚSCULAS y menos tracking (look actual, no retro) ---- */
.btn, .btn-gold { text-transform: none; letter-spacing: 0; font-weight: 600; }
.navbar-wael .nav-link { text-transform: none; letter-spacing: 0; font-weight: 600; }
.card-producto .nombre { text-transform: none; letter-spacing: 0; font-weight: 600; }
.card-producto .marca { text-transform: uppercase; letter-spacing: .07em; font-size: .68rem; }
.cat-card-title, .cat-card-count { text-transform: none; letter-spacing: 0; }
.form-label { text-transform: none; letter-spacing: 0; font-weight: 600; }
.mega-menu .dropdown-item { text-transform: none; letter-spacing: 0; }
.accordion-button, .nav-tabs .nav-link { text-transform: none; letter-spacing: 0; }
.footer-wael a, .footer-bottom a { text-transform: none; letter-spacing: 0; }
.benefit, .pay-info strong, .envio-card strong, .trust-item strong, .mini-cart-name,
.modal-content .modal-title, .admin-sidebar a, .table-dark-wael th, .h6, h6 {
    text-transform: none; letter-spacing: 0;
}
.topbar { text-transform: none; letter-spacing: .01em; }
/* Chips/tags: mayúscula sutil (se ve moderno en piezas pequeñas) */
.seal, .badge, .zona-badge, .eyebrow, .label-upper { letter-spacing: .05em; }
/* Títulos display: serif elegante, peso medio (look luxury, no sans pesado) */
.display-3, .display-4, .display-5, .display-6 {
    font-family: 'Cormorant', Georgia, serif; font-weight: 700; letter-spacing: 0;
}
/* Botones algo más redondeados (estética limpia) */
.btn { border-radius: 8px; }
.card-producto, .cat-card, .admin-card, .brand-chip { border-radius: 14px; }
/* Botón acento con micro-mayúscula sobria (firma luxury) */
.btn-gold, .btn-outline-gold { text-transform: uppercase; letter-spacing: 1.5px; font-size: .8rem; font-weight: 600; }

/* ============================================================
   HEADER LUXURY  ·  topbar fino + navbar limpio + buscador sobrio
   ============================================================ */
/* Topbar: espresso, centrado, separadores dorados */
.topbar { background: var(--dark-2); font-size: .72rem; letter-spacing: 1.2px; text-transform: uppercase; }
.topbar .container { padding-top: 9px; padding-bottom: 9px; }
.topbar .tb-item { color: rgba(244,239,231,.62); font-weight: 500; }
.topbar i { color: var(--gold); opacity: .9; }

/* Navbar: más aire, sombra sutil, hairline dorada inferior */
.navbar-wael { background: var(--dark); box-shadow: none; border-bottom: 1px solid rgba(21,127,112,.14); }
.navbar-wael .container { padding-top: .35rem; padding-bottom: .35rem; }
.navbar-logo { height: 60px; }
.footer-logo { height: 112px; }
.navbar-wael .nav-link {
    text-transform: uppercase; letter-spacing: 1.5px; font-size: .78rem; font-weight: 600;
    padding-left: .85rem !important; padding-right: .85rem !important; color: #ece6dd !important;
    position: relative;
}
.navbar-wael .nav-link::after {
    content: ''; position: absolute; left: .85rem; right: .85rem; bottom: 2px; height: 1px;
    background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform .25s ease;
}
.navbar-wael .nav-link:hover::after { transform: scaleX(1); }
.navbar-wael .nav-art { color: var(--gold) !important; letter-spacing: 2px; }
.navbar-icon { font-size: 1.15rem; color: #ece6dd !important; }

/* Buscador: pill sobrio, acotado, botón dorado integrado */
.search-wael { max-width: 440px; }
.search-wael .input-group { border: 1px solid rgba(21,127,112,.28); border-radius: 50px; overflow: hidden; background: rgba(255,255,255,.05); transition: border-color .2s ease; }
.search-wael .input-group:focus-within { border-color: var(--gold); }
.search-wael .form-control {
    background: transparent !important; border: 0 !important; color: #f4efe7 !important;
    border-radius: 0 !important; padding: .55rem 1.1rem; font-size: .9rem; box-shadow: none !important;
}
.search-wael .form-control::placeholder { color: rgba(244,239,231,.5) !important; letter-spacing: .3px; }
.search-wael .btn-gold {
    background: transparent; border: 0; color: var(--gold);
    border-radius: 0 !important; padding: 0 1.1rem 0 .6rem; font-size: 1.05rem;
}
.search-wael .btn-gold:hover { background: transparent; color: var(--gold-2); transform: none; }
.search-results { border-radius: 14px; margin-top: 8px; box-shadow: 0 18px 44px rgba(0,0,0,.25); overflow: hidden; }
@media (max-width: 991.98px){ .search-wael { max-width: 100%; } }

/* ============================================================
   HEADER CLARO  ·  navbar crema + logo TEAL grande y legible
   ============================================================ */
.navbar-wael { background: #ffffff; box-shadow: 0 1px 0 rgba(26,31,30,.05), 0 8px 24px rgba(19,33,31,.06); border-bottom: 1px solid rgba(21,127,112,.18); }
/* Logo grande, protagonista (ya recortado, llena su caja) */
.navbar-logo { height: 56px; width: auto; }
.footer-logo { height: 84px; width: auto; }
.navbar-wael .navbar-brand { margin-right: 1.25rem !important; }
/* Links espresso sobre claro */
.navbar-wael .nav-link { color: var(--text) !important; }
.navbar-wael .nav-link:hover { color: var(--gold) !important; }
.navbar-wael .nav-art { color: var(--gold) !important; }
.navbar-icon { color: var(--text) !important; }
.navbar-icon:hover { color: var(--gold) !important; }
.navbar-wael .navbar-toggler { color: var(--text) !important; }
/* Buscador sobre fondo claro */
.search-wael .input-group { background: var(--bg); border-color: rgba(21,127,112,.32); }
.search-wael .form-control { color: var(--text) !important; }
.search-wael .form-control::placeholder { color: var(--muted) !important; }
.search-wael .btn-gold { color: var(--gold); }
.search-wael .btn-gold:hover { color: var(--gold-2); }
/* Cart count: teal con texto blanco */
.cart-count { background: var(--gold); color: #fff; }
@media (max-width: 575.98px){ .navbar-logo { height: 44px; } .footer-logo { height: 66px; } }

/* ============================================================
   ADMIN  ·  sidebar oscuro + tarjetas con definición (más contraste)
   ============================================================ */
.admin-sidebar { background: var(--dark); border-right: 1px solid rgba(21,127,112,.20); }
.admin-sidebar a { color: rgba(244,239,231,.74); border-radius: 10px; }
.admin-sidebar a:hover { background: rgba(255,255,255,.06); color: #fff; }
.admin-sidebar a.active { background: rgba(21,127,112,.20); color: #ffffff; border-left: 3px solid var(--gold); }
.admin-sidebar .divider { background: rgba(255,255,255,.10); }
/* Marca del sidebar: logo + etiqueta Admin */
.admin-brand { display: flex; align-items: center; gap: 10px; }
.admin-logo { height: 40px; width: auto; }
.admin-brand-tag { font-family: 'Cormorant', Georgia, serif; font-size: 1.5rem; font-weight: 700; color: var(--gold); line-height: 1; }
/* Topbar móvil del admin: igual que tienda (claro) -> ya cubierto por navbar-wael */
.navbar-wael .brand-logo, .offcanvas .brand-logo { color: var(--text); }
.offcanvas.admin-sidebar .brand-logo { color: #f4efe7; }

/* Tarjetas admin: borde y sombra definidos sobre el crema */
.admin-card { background: #fff; border: 1px solid rgba(26,31,30,.12); box-shadow: 0 1px 2px rgba(19,33,31,.05), 0 8px 22px rgba(19,33,31,.07); }
/* Stat cards: acento teal arriba + número serif grande */
.stat-card { position: relative; border-top: 3px solid var(--gold); }
.stat-card .value { font-family: 'Cormorant', Georgia, serif; font-weight: 700; font-size: 2.4rem; letter-spacing: 0; }
/* Cabeceras de panel (Pedidos recientes / Bajo stock) más marcadas */
.admin-card .card-header, .admin-card > .p-3:first-child h2, .admin-card h2 { color: var(--text); }
/* Badge de stock 0 más legible */
.admin-card .badge.bg-secondary, .nav-badge { background: var(--err) !important; color: #fff !important; }

/* ============================================================
   MODALES  ·  pulido luxury (marco, header serif, X visible, footer)
   ============================================================ */
.modal-content.bg-surface {
    border-radius: 18px; border: 1px solid var(--border);
    box-shadow: 0 30px 90px rgba(19,33,31,.32); overflow: hidden; position: relative;
}
/* franja teal superior */
.modal-content.bg-surface::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: var(--gold); z-index: 5;
}
.modal-header {
    padding: 1.15rem 1.45rem .95rem; border-bottom: 1px solid var(--border);
    align-items: center;
}
.modal-title {
    font-family: 'Cormorant', Georgia, serif; font-size: 1.7rem; font-weight: 700;
    letter-spacing: 0; text-transform: none; color: var(--text);
}
/* Botón cerrar VISIBLE sobre modal claro (corrige btn-close-white invisible) */
.modal-content.bg-surface .btn-close { filter: none !important; opacity: .5; transition: opacity .2s; }
.modal-content.bg-surface .btn-close:hover { opacity: 1; }
.modal-body { padding: 1.4rem 1.45rem; }
/* respiro entre campos */
.modal-body .row + .row, .modal-body .mb-3 { margin-bottom: 1.05rem !important; }
.modal-body .form-label { margin-bottom: .35rem; }
/* Footer separado y prolijo */
.modal-footer {
    padding: .95rem 1.45rem; border-top: 1px solid var(--border);
    background: var(--bg); gap: .6rem;
}
.modal-footer .btn { min-height: 44px; }
.modal-footer .btn-ghost, .modal-footer .btn-sm { padding: .55rem 1.3rem; font-size: .8rem; }
/* Input de archivo más sobrio */
.modal-body input[type=file] { padding: .5rem .7rem; }
.modal-body input[type=file]::file-selector-button {
    background: var(--surface-2); border: 1px solid var(--border); color: var(--text);
    border-radius: 8px; padding: .35rem .8rem; margin-right: .8rem; font-weight: 600; cursor: pointer;
    font-family: 'Montserrat', sans-serif; transition: border-color .2s, color .2s;
}
.modal-body input[type=file]::file-selector-button:hover { border-color: var(--gold); color: var(--gold); }

/* Stock: auto-save por fila */
.stock-edit { display: flex; align-items: center; gap: 8px; }
.stock-status { min-width: 16px; font-size: .95rem; line-height: 1; transition: color .2s; }
.stock-status.ok { color: var(--ok); }
.stock-status.err { color: var(--err); }
.stock-status.saving { color: var(--muted); }
.stock-input { transition: border-color .2s, box-shadow .2s; }
.stock-input:focus { border-color: var(--gold); box-shadow: 0 0 0 .15rem rgba(21,127,112,.18); }

/* Texto secundario legible: el gris de Bootstrap también al muted oscuro */
.text-muted, .text-body-secondary { color: var(--muted) !important; }
/* En zonas oscuras (footer/hero) se mantiene claro con sus propias reglas */
.footer-wael .text-muted, .footer-wael .text-body-secondary,
.hero-slide .text-muted, .hero-slide .text-body-secondary { color: rgba(255,255,255,.6) !important; }

/* FOOTER legible sobre fondo oscuro (el --muted oscuro no aplica aquí) */
.footer-wael { color: rgba(255,255,255,.8); }
.footer-wael .text-muted-2 { color: rgba(255,255,255,.74) !important; }
.footer-wael a { color: rgba(255,255,255,.8); }
.footer-wael a:hover { color: var(--gold); }
.footer-brand { color: rgba(255,255,255,.6) !important; opacity: 1; }
.footer-brand:hover { color: var(--gold) !important; }
.footer-bottom .text-muted-2, .footer-bottom a { color: rgba(255,255,255,.68) !important; }
.footer-bottom a:hover { color: var(--gold) !important; }
.footer-wael .form-control::placeholder { color: rgba(255,255,255,.55); }

/* ---------- Reseñas: tarjetas + selector de estrellas ---------- */
.resena-card { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 16px; box-shadow: var(--shadow-sm); }
.resena-stars { color: var(--gold); }
.resena-form-card { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 22px; box-shadow: var(--shadow-sm); position: sticky; top: 90px; }
/* Selector de estrellas (fila invertida para que el hover ilumine de izq→der) */
.star-rating { display: inline-flex; flex-direction: row-reverse; justify-content: flex-end; gap: 4px; font-size: 1.6rem; }
.star-rating input { position: absolute; opacity: 0; width: 0; height: 0; }
.star-rating label { color: #d9d2c6; cursor: pointer; transition: color .15s, transform .15s; line-height: 1; }
.star-rating label:hover, .star-rating label:hover ~ label,
.star-rating input:checked ~ label { color: var(--gold); }
.star-rating label:hover { transform: scale(1.12); }
.star-rating input:focus-visible + label { outline: 2px solid var(--gold); outline-offset: 2px; border-radius: 4px; }
@media (max-width: 991.98px){ .resena-form-card { position: static; } }
