/* =============================================
   LUCKY FANTASY — Estilos principales
   Las variables CSS (:root) se inyectan desde PHP
   ============================================= */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body { font-family: var(--font-primary, 'Inter'), sans-serif; background: var(--crema); color: var(--oscuro); overflow-x: hidden; }

/* Gradient ONLY on big display text */
.gold-title {
    background: var(--gold-grad);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ============ NAV ============ */
nav {
    background: rgba(254,248,251,0.96); backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--borde); padding: 0 6%; height: 70px;
    display: flex; align-items: center; justify-content: space-between;
    position: sticky; top: 0; z-index: 99;
}
.logo-wrap { display: flex; align-items: center; gap: 6px; text-decoration: none; }
.logo-orn { font-size: 0.85rem; color: var(--gold-bright); }
.logo {
    font-family: var(--font-display, 'Dancing Script'), cursive; font-size: 1.95rem; line-height: 1;
    background: var(--gold-grad);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.nav-menu { display: flex; gap: 2rem; list-style: none; }
.nav-menu a { font-size: 0.8rem; letter-spacing: 0.07em; color: var(--medio); text-decoration: none; text-transform: uppercase; transition: color 0.2s; }
.nav-menu a:hover { color: var(--rosa); }
.nav-right { display: flex; align-items: center; gap: 1rem; }
.icon-btn { background: none; border: none; cursor: pointer; color: var(--medio); display: flex; transition: color 0.2s; }
.icon-btn:hover { color: var(--rosa); }
.whatsapp-nav {
    background: linear-gradient(135deg, var(--rosa), var(--lavanda)); color: #fff;
    border: none; border-radius: 30px; padding: 9px 20px;
    font-family: var(--font-primary, 'Inter'), sans-serif; font-size: 0.78rem; font-weight: 500;
    cursor: pointer; display: flex; align-items: center; gap: 7px;
    transition: opacity 0.2s; text-decoration: none;
}
.whatsapp-nav:hover { opacity: .88; }

/* Mobile menu button — removed */
.menu-toggle { display: none; }

/* ============ HERO ============ */
.hero {
    background: linear-gradient(135deg, #fce8f4 0%, #f0d8ee 50%, #e8d0f0 100%);
    padding: 80px 6%; display: grid; grid-template-columns: 1fr 1fr;
    gap: 60px; align-items: center; min-height: 88vh;
    position: relative; overflow: hidden;
}
.hero::before { content:''; position:absolute; width:500px; height:500px; border-radius:50%; background:radial-gradient(circle,rgba(184,126,200,0.12) 0%,transparent 70%); top:-100px; right:-100px; pointer-events:none; }
.hero::after  { content:''; position:absolute; width:350px; height:350px; border-radius:50%; background:radial-gradient(circle,rgba(201,105,142,0.1) 0%,transparent 70%); bottom:-80px; left:-80px; pointer-events:none; }
.hero-text { position: relative; z-index: 2; }
.hero-tag {
    font-size: 0.67rem; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--gold); margin-bottom: 12px;
    display: flex; align-items: center; gap: 8px;
}
.hero-tag::before, .hero-tag::after { content:''; display:block; flex:0 0 20px; height:1px; background: var(--gold-bright); opacity: 0.6; }
.hero-title { font-family: var(--font-display, 'Dancing Script'), cursive; font-size: clamp(3.2rem,6vw,5.5rem); line-height: 1.1; color: var(--oscuro); }
.hero-title .ht-gold {
    background: var(--gold-grad);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-tagline {
    font-family: var(--font-serif, 'Cormorant Garamond'), serif; font-style: italic;
    font-size: 1rem; color: var(--gold); margin-top: 10px;
    display: flex; align-items: center; gap: 6px;
}
.hero-tagline::before { content: '✦'; font-style: normal; font-size: 0.6rem; }
.hero-desc { margin-top: 18px; font-size: 0.95rem; color: var(--medio); line-height: 1.8; max-width: 400px; }
.hero-btns { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; }
.btn-primary { background: linear-gradient(135deg,var(--rosa),var(--lavanda)); color:#fff; padding:12px 26px; border-radius:30px; text-decoration:none; font-size:0.82rem; font-weight:500; transition:opacity 0.2s,transform 0.2s; }
.btn-primary:hover { opacity:.88; transform:translateY(-2px); }
.btn-secondary { background:#fff; color:var(--medio); border:1.5px solid var(--borde); padding:12px 26px; border-radius:30px; text-decoration:none; font-size:0.82rem; font-weight:500; transition:all 0.2s; }
.btn-secondary:hover { border-color:var(--rosa); color:var(--rosa); }

.hero-img { display:flex; align-items:center; justify-content:center; position:relative; z-index:2; }
.hero-circle { width:370px; height:370px; border-radius:50%; background:linear-gradient(145deg,rgba(255,255,255,0.5),rgba(255,255,255,0.2)); backdrop-filter:blur(4px); border:1.5px solid rgba(255,255,255,0.6); display:flex; align-items:center; justify-content:center; animation:float 6s ease-in-out infinite; box-shadow:0 20px 60px rgba(201,105,142,0.18); overflow:hidden; }
.hero-circle svg { width:160px; height:160px; }
.hero-circle img { width:100%; height:100%; object-fit:cover; }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
.hero-stat { position:absolute; background:rgba(255,255,255,0.94); border-radius:14px; padding:12px 18px; box-shadow:0 4px 20px rgba(201,105,142,0.12); border:1px solid var(--borde); }
.hero-stat strong { font-family: var(--font-display, 'Dancing Script'),cursive; font-size:1.5rem; background:var(--gold-grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; display:block; line-height:1; }
.hero-stat span { font-size:0.72rem; color:var(--medio); }
.hs-1{bottom:12%;left:-4%} .hs-2{top:12%;right:-4%}

/* ============ SECTION LABELS ============ */
.sec-label {
    font-size: 0.67rem; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--gold); margin-bottom: 4px;
    display: flex; align-items: center; gap: 7px;
}
.sec-label::before { content: '✦'; font-size: 0.48rem; }
.sec-title {
    font-family: var(--font-display, 'Dancing Script'), cursive;
    font-size: clamp(2rem,3.5vw,2.8rem);
    background: var(--gold-grad);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* ============ CATEGORÍAS ============ */
.cats-section { padding: 80px 6%; }
.cats-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:32px; }
.ver-mas { font-size:0.75rem; color:var(--medio); text-decoration:none; transition:color 0.2s; }
.ver-mas:hover { color:var(--rosa); }
.cats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.cat-card { border-radius:18px; overflow:hidden; cursor:pointer; position:relative; transition:transform 0.25s,box-shadow 0.25s; text-decoration:none; display:block; }
.cat-card:hover { transform:translateY(-6px); box-shadow:0 14px 40px rgba(201,105,142,0.16); }
.cat-img { aspect-ratio:3/4; display:flex; align-items:center; justify-content:center; }
.cat-img svg { width:65px; height:65px; }
.cat-img img { width:100%; height:100%; object-fit:contain; }
.cat-label { position:absolute; bottom:0; left:0; right:0; padding:44px 16px 16px; background:linear-gradient(to top,rgba(30,20,32,0.75),transparent); }
.cat-label h3 { font-family: var(--font-display, 'Dancing Script'),cursive; font-size:1.2rem; color:#fff; }
.cat-price { font-family: var(--font-serif, 'Cormorant Garamond'),serif; font-style:italic; font-size:0.82rem; color: #f0d898; display:block; margin-top:2px; opacity:0.9; }

/* ============ PRODUCTOS ============ */
.products-section { padding:0 6% 80px; }
.sec-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:28px; }
.prod-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.prod-card { background:#fff; border:1px solid var(--borde); border-radius:18px; overflow:hidden; transition:box-shadow 0.25s,transform 0.25s; }
.prod-card:hover { box-shadow:0 10px 35px rgba(201,105,142,0.13); transform:translateY(-5px); }
.prod-img { aspect-ratio:3/4; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; background:var(--blush); }
.prod-img svg { width:78px; height:78px; }
.prod-img img { width:100%; height:100%; object-fit:contain; }
.badge { position:absolute; top:12px; left:12px; background:linear-gradient(135deg,var(--rosa),var(--lavanda)); color:#fff; font-size:0.59rem; letter-spacing:0.12em; text-transform:uppercase; padding:3px 10px; border-radius:20px; }
.prod-body { padding:16px 18px 20px; }
.prod-cat { font-size:0.63rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--rosa); margin-bottom:4px; }
.prod-name {
    font-family: var(--font-display, 'Dancing Script'),cursive; font-size:1.3rem;
    background: var(--gold-grad);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.prod-desc { font-size:0.78rem; color:var(--medio); line-height:1.6; margin-top:5px; }
.prod-footer { display:flex; align-items:center; justify-content:space-between; margin-top:14px; }
.prod-price { font-family: var(--font-serif, 'Cormorant Garamond'),serif; font-size:1.2rem; font-style:italic; color: var(--gold); }
.add-btn { width:32px; height:32px; border-radius:50%; background:linear-gradient(135deg,var(--rosa),var(--lavanda)); color:#fff; border:none; font-size:1.1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:opacity 0.2s,transform 0.18s; text-decoration:none; line-height:1; }
.add-btn:hover { opacity:.82; transform:scale(1.1); }

/* ============ DESAYUNOS ============ */
.breakfast-section { background:linear-gradient(135deg,#fce8f4 0%,#ecddf5 100%); padding:80px 6%; }
.bf-grid { display:grid; grid-template-columns:1.4fr 1fr; gap:18px; margin-top:32px; }
.bf-main { background:var(--oscuro); border-radius:18px; overflow:hidden; display:flex; flex-direction:column; transition:transform 0.25s; }
.bf-main:hover { transform:translateY(-4px); }
.bf-main-img { flex:1; min-height:240px; background:linear-gradient(150deg,var(--rosa2),var(--lavanda)); display:flex; align-items:center; justify-content:center; }
.bf-main-img svg { width:110px; height:110px; }
.bf-main-img img { width:100%; height:100%; object-fit:cover; }
.bf-main-body { padding:24px 26px 28px; }
.bf-sub { font-size:0.63rem; letter-spacing:0.2em; text-transform:uppercase; color: var(--gold-bright); margin-bottom:6px; opacity:0.9; }
.bf-main-name { font-family: var(--font-display, 'Dancing Script'),cursive; font-size:1.6rem; background:var(--gold-grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.bf-main-desc { font-size:0.82rem; color:rgba(255,255,255,0.6); line-height:1.7; margin-top:8px; }
.bf-main-price { font-family: var(--font-serif, 'Cormorant Garamond'),serif; font-size:1.25rem; font-style:italic; color: var(--gold-bright); }
.bf-list { display:flex; flex-direction:column; gap:12px; }
.bf-item { background:rgba(255,255,255,0.88); border-radius:14px; border:1px solid var(--borde); display:flex; align-items:center; gap:14px; padding:14px 16px; transition:box-shadow 0.22s,transform 0.22s; }
.bf-item:hover { box-shadow:0 6px 20px rgba(201,105,142,0.1); transform:translateY(-3px); }
.bf-icon { width:60px; height:60px; border-radius:10px; flex-shrink:0; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.bf-icon svg { width:30px; height:30px; }
.bf-icon img { width:100%; height:100%; object-fit:cover; }
.bf-item-name { font-family: var(--font-display, 'Dancing Script'),cursive; font-size:1.05rem; background:var(--gold-grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.bf-item-cat { font-size:0.6rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--rosa); margin-bottom:2px; }
.bf-item-price { font-family: var(--font-serif, 'Cormorant Garamond'),serif; font-size:1rem; font-style:italic; color:var(--gold); display:block; margin-top:3px; }
.bf-item-desc { font-size:0.72rem; color:var(--medio); margin-top:1px; }

/* ============ PASOS ============ */
.steps-section { padding:80px 6%; }
.steps-section .sec-label { justify-content:center; }
.steps-section .sec-title { text-align:center; }
.steps-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:40px; }
.step-card { text-align:center; padding:28px 20px; background:#fff; border-radius:18px; border:1px solid var(--borde); transition:box-shadow 0.25s,transform 0.25s; }
.step-card:hover { box-shadow:0 8px 24px rgba(201,105,142,0.1); transform:translateY(-4px); }
.step-num-wrap { width:52px; height:52px; border-radius:50%; background:linear-gradient(135deg,var(--rosa-lt),var(--lav-lt)); display:flex; align-items:center; justify-content:center; margin:0 auto 14px; }
.step-num { font-family: var(--font-display, 'Dancing Script'),cursive; font-size:1.6rem; background:var(--gold-grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.step-card h4 { font-size:0.9rem; font-weight:500; color:var(--oscuro); margin-bottom:7px; }
.step-card p { font-size:0.78rem; color:var(--medio); line-height:1.65; }

/* ============ RESEÑAS ============ */
.reviews-section { background:linear-gradient(135deg,var(--blush),var(--lav-lt) 100%); padding:80px 6%; }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:30px; }
.rev-card { background:rgba(255,255,255,0.88); border-radius:16px; padding:24px; border:1px solid var(--borde); backdrop-filter:blur(6px); transition:transform 0.22s; }
.rev-card:hover { transform:translateY(-3px); }
.rev-stars { display:flex; gap:3px; margin-bottom:12px; }
.rev-stars svg { width:13px; height:13px; fill:var(--gold); }
.rev-text { font-size:0.84rem; color:var(--medio); line-height:1.75; font-style:italic; }
.rev-author { display:flex; align-items:center; gap:10px; margin-top:16px; }
.rev-av { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,var(--rosa-lt),var(--lav-lt)); display:flex; align-items:center; justify-content:center; }
.rev-av svg { width:16px; height:16px; fill:var(--rosa); }
.rev-name { font-size:0.82rem; font-weight:500; color:var(--oscuro); }
.rev-sub { font-size:0.7rem; color:var(--claro); }

/* ============ FOOTER ============ */
footer { background:var(--oscuro); padding:54px 6% 28px; }
.foot-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.foot-brand h3 { font-family: var(--font-display, 'Dancing Script'),cursive; font-size:2.1rem; background:var(--gold-grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:4px; }
.foot-tagline { font-family: var(--font-serif, 'Cormorant Garamond'),serif; font-style:italic; font-size:0.9rem; color:var(--gold-bright); margin-bottom:12px; display:flex; align-items:center; gap:6px; opacity:0.85; }
.foot-tagline::before { content:'✦'; font-style:normal; font-size:0.55rem; }
.foot-brand p { font-size:0.82rem; color:rgba(255,255,255,0.45); line-height:1.7; max-width:220px; }
.foot-contact { margin-top:18px; display:flex; flex-direction:column; gap:9px; }
.foot-contact a { font-size:0.82rem; color:rgba(255,255,255,0.55); text-decoration:none; display:flex; align-items:center; gap:8px; transition:color 0.2s; }
.foot-contact a svg { width:14px; height:14px; flex-shrink:0; }
.foot-contact a:hover { color:#fff; }
.foot-col h4 { font-family: var(--font-serif, 'Cormorant Garamond'),serif; font-style:italic; font-size:1.05rem; color:var(--gold-bright); margin-bottom:14px; }
.foot-col ul { list-style:none; display:flex; flex-direction:column; gap:9px; }
.foot-col a { font-size:0.82rem; color:rgba(255,255,255,0.45); text-decoration:none; transition:color 0.2s; }
.foot-col a:hover { color:#fff; }
.foot-bottom { border-top:1px solid rgba(255,255,255,0.08); padding-top:22px; display:flex; justify-content:space-between; align-items:center; }
.foot-bottom p { font-size:0.74rem; color:rgba(255,255,255,0.25); }

/* ============ WA FLOAT ============ */
.wa-float { position:fixed; bottom:26px; right:26px; z-index:999; width:56px; height:56px; border-radius:50%; background:#25d366; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,0.45); text-decoration:none; transition:transform 0.2s; }
.wa-float:hover { transform:scale(1.1); }
.wa-float svg { width:28px; height:28px; fill:#fff; }

/* ============ VER CATÁLOGO CARD (CATEGORÍAS) ============ */
.cat-card-catalogo .cat-img {
    position: relative;
}
.cat-card-catalogo .cat-img::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(160deg, rgba(255,255,255,0.08), rgba(255,255,255,0));
    pointer-events: none;
}
.cat-card-catalogo:hover .cat-img svg {
    transform: scale(1.12);
    transition: transform 0.35s ease;
}
.cat-card-catalogo .cat-img svg {
    transition: transform 0.35s ease;
}
@keyframes catalogPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(201,105,142,0.3); }
    50% { box-shadow: 0 0 20px 4px rgba(184,126,200,0.2); }
}
.cat-card-catalogo {
    animation: catalogPulse 3s ease-in-out infinite;
}

/* ============ RESPONSIVE ============ */
@media (max-width:900px) {
    .hero { grid-template-columns:1fr; min-height:auto; } .hero-img{display:none;}
    .cats-grid{grid-template-columns:1fr 1fr;} .prod-grid{grid-template-columns:1fr 1fr;}
    .bf-grid{grid-template-columns:1fr;} .steps-grid{grid-template-columns:1fr 1fr;}
    .reviews-grid{grid-template-columns:1fr 1fr;} .foot-grid{grid-template-columns:1fr 1fr;}
    nav { flex-wrap:wrap; height:auto; padding:12px 6%; gap:8px; }
    .nav-menu { 
        order:3; width:100%; gap:0; padding:8px 0 4px; margin:0;
        border-top:1px solid var(--borde);
        overflow-x:auto; -webkit-overflow-scrolling:touch;
        scrollbar-width:none;
    }
    .nav-menu::-webkit-scrollbar { display:none; }
    .nav-menu a { white-space:nowrap; font-size:0.72rem; padding:6px 12px; }
    .nav-right { margin-left:auto; }
    .whatsapp-nav span { display:none; }
}
@media (max-width:560px) {
    .prod-grid{grid-template-columns:1fr;} .reviews-grid{grid-template-columns:1fr;}
    .foot-grid{grid-template-columns:1fr;} .foot-bottom{flex-direction:column;gap:10px;text-align:center;}
    .cats-grid{grid-template-columns:1fr;}
    .steps-grid{grid-template-columns:1fr;}
}
