/* styles.css — CAFUNÉ | Cafetería de Autor */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,500;0,9..144,700;1,9..144,400;1,9..144,600&family=DM+Sans:wght@300;400;500&display=swap');

:root {
    --cafe: #3B1F0E;
    --espresso: #5C3317;
    --terra: #C4622D;
    --mango: #E8973A;
    --gold: #F2C14E;
    --verde: #2D6A4F;
    --verde-lt: #52B788;
    --crema: #FDF6EC;
    --crema-dk: #F2E8D5;
    --white: #FFFFFF;
    --mid: #7A6652;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'DM Sans', sans-serif;
    background: var(--crema);
    color: var(--cafe);
    -webkit-font-smoothing: antialiased;
}

.serif {
    font-family: 'Fraunces', serif;
}

/* ── Botones ── */
.btn-terra {
    background: var(--terra);
    color: var(--white);
    font-weight: 500;
    letter-spacing: 0.05em;
    transition: background 0.3s, transform 0.2s;
    display: inline-block;
}

.btn-terra:hover {
    background: var(--espresso);
    transform: translateY(-2px);
}

.btn-gold {
    background: var(--gold);
    color: var(--cafe);
    font-weight: 600;
    letter-spacing: 0.05em;
    transition: background 0.3s, transform 0.2s;
    display: inline-block;
}

.btn-gold:hover {
    background: var(--mango);
    transform: translateY(-2px);
}

.btn-outline-crema {
    border: 2px solid var(--crema);
    color: var(--crema);
    font-weight: 500;
    letter-spacing: 0.05em;
    transition: background 0.3s, color 0.3s;
    display: inline-block;
}

.btn-outline-crema:hover {
    background: var(--crema);
    color: var(--cafe);
}

/* ── Cards ── */
.menu-card {
    background: var(--white);
    transition: transform 0.3s, box-shadow 0.3s;
    border-radius: 16px;
    overflow: hidden;
}

.menu-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 50px rgba(59, 31, 14, 0.15);
}

/* ── Pattern tile ── */
.tile-pattern {
    background-image: repeating-linear-gradient(45deg,
            transparent, transparent 10px,
            rgba(196, 98, 45, 0.06) 10px, rgba(196, 98, 45, 0.06) 20px);
}

/* ── Badge ── */
.badge-verde {
    background: var(--verde);
    color: var(--white);
    font-size: 0.65rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    font-weight: 600;
    border-radius: 4px;
    padding: 3px 8px;
}

/* ── Zoom img ── */
.img-zoom {
    overflow: hidden;
}

.img-zoom img {
    transition: transform 0.7s ease;
}

.img-zoom:hover img {
    transform: scale(1.07);
}

/* ── Section label ── */
.sect-label {
    font-size: 0.7rem;
    letter-spacing: 0.35em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--terra);
}

/* ── Scrollbar ── */
::-webkit-scrollbar {
    width: 5px;
}

::-webkit-scrollbar-track {
    background: var(--crema);
}

::-webkit-scrollbar-thumb {
    background: var(--terra);
    border-radius: 3px;
}