/* ============================================================ */
/* sabores.css — Estilos exclusivos da página Sabores           */
/* Depende de: variables.css, reset.css, components.css         */
/* ============================================================ */

/* Override: hero com cores de gastronomia */
.hero { background: linear-gradient(135deg, #8B4513 0%, #D2691E 100%); }

/* Override: main-content mais largo */
.main-content { max-width: 1400px; }

/* Section Title */
.section-header { text-align: center; margin-bottom: 3rem; }
.section-header h2 { font-family: var(--font-display); font-size: 2.5rem; color: var(--forest-deep); margin-bottom: 0.5rem; }
.section-header p { color: #666; font-size: 1.1rem; }

/* Pratos Típicos */
.dishes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 2rem;
    margin-bottom: 4rem;
}

.dish-card { background: white; border-radius: 20px; overflow: hidden; box-shadow: 0 10px 40px rgba(0,0,0,0.08); transition: transform 0.3s; }
.dish-card:hover { transform: translateY(-5px); }
.dish-card-image { height: 200px; background-size: cover; background-position: center; position: relative; }
.dish-card-image .origin-badge { position: absolute; top: 1rem; right: 1rem; background: var(--polish-red); color: white; padding: 0.4rem 0.8rem; border-radius: 15px; font-size: 0.75rem; font-weight: 600; }
.dish-card-content { padding: 1.5rem; }
.dish-card h3 { font-family: var(--font-display); font-size: 1.4rem; color: var(--forest-deep); margin-bottom: 0.25rem; }
.dish-card .polish-name { color: var(--gold-polish); font-style: italic; font-size: 0.9rem; margin-bottom: 0.75rem; }
.dish-card p { color: #666; font-size: 0.9rem; }
.dish-card .where-to-find { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid #eee; font-size: 0.85rem; color: #888; }
.dish-card .where-to-find strong { color: var(--forest-deep); }

/* Feiras Section */
.fairs-section { background: white; border-radius: 20px; padding: 2.5rem; margin-bottom: 3rem; box-shadow: 0 10px 40px rgba(0,0,0,0.08); }
.fairs-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; margin-top: 2rem; }
.fair-card { background: var(--cream-light); border-radius: 15px; padding: 1.5rem; border-left: 4px solid var(--gold-polish); }
.fair-card h4 { font-family: var(--font-display); font-size: 1.3rem; color: var(--forest-deep); margin-bottom: 0.5rem; display: flex; align-items: center; gap: 0.5rem; }
.fair-card .schedule { display: flex; flex-direction: column; gap: 0.25rem; font-size: 0.9rem; color: #666; margin-bottom: 0.75rem; }
.fair-card .schedule span { display: flex; align-items: center; gap: 0.5rem; }
.fair-card p { font-size: 0.85rem; color: #888; }

/* Restaurantes */
.restaurants-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(350px, 1fr)); gap: 1.5rem; }
.restaurant-card { background: white; border-radius: 15px; padding: 1.5rem; box-shadow: 0 5px 25px rgba(0,0,0,0.06); display: flex; gap: 1rem; align-items: start; }
.restaurant-icon { width: 60px; height: 60px; background: linear-gradient(135deg, var(--forest-deep), #0a5d3e); border-radius: 15px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; flex-shrink: 0; }
.restaurant-info h4 { font-family: var(--font-display); font-size: 1.2rem; color: var(--forest-deep); margin-bottom: 0.25rem; }
.restaurant-info .cuisine { color: var(--gold-polish); font-size: 0.85rem; font-weight: 600; margin-bottom: 0.5rem; }
.restaurant-info .contact { font-size: 0.85rem; color: #666; }
.restaurant-info .contact span { display: block; margin-bottom: 0.25rem; }

/* Produtores */
.producers-section { background: linear-gradient(135deg, var(--forest-deep), #0a5d3e); border-radius: 20px; padding: 2.5rem; margin-top: 3rem; color: white; }
.producers-section h3 { font-family: var(--font-display); font-size: 2rem; margin-bottom: 1rem; }
.producers-section > p { opacity: 0.9; margin-bottom: 2rem; max-width: 600px; }
.producers-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; }
.producer-card { background: rgba(255,255,255,0.1); border-radius: 15px; padding: 1.25rem; text-align: center; backdrop-filter: blur(10px); }
.producer-card .icon { font-size: 2.5rem; margin-bottom: 0.75rem; }
.producer-card h4 { font-size: 1rem; margin-bottom: 0.25rem; }
.producer-card p { font-size: 0.8rem; opacity: 0.8; }

/* Produtor Interativo */
.produtor-section { padding: 4rem 2rem; background: linear-gradient(135deg, #f0ebe3 0%, #e8e2d8 100%); }
.produtor-container { max-width: 1200px; margin: 0 auto; background: linear-gradient(145deg, #0a3d2e 0%, #0d4a38 100%) !important; border-radius: 30px; padding: 3rem; box-shadow: 0 20px 60px rgba(10,61,46,0.3); }
.produtor-header { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.produtor-header span { font-size: 2rem; }
.produtor-header h2 { color: #fff !important; font-family: var(--font-display); font-size: 2rem; }
.produtor-intro { color: rgba(255,255,255,0.85) !important; margin-bottom: 2rem; font-size: 1.1rem; }
.produtor-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 1rem; }
.produtor-item { background: rgba(255,255,255,0.1) !important; border: 1px solid rgba(255,255,255,0.15); border-radius: 16px; padding: 1.5rem; text-align: center; cursor: pointer; transition: all 0.3s ease; }
.produtor-item:hover { background: rgba(255,255,255,0.2) !important; transform: translateY(-5px); }
.produtor-item.active { background: #d4a574 !important; border-color: #d4a574; }
.produtor-item.active .produtor-item-name, .produtor-item.active .produtor-item-desc { color: #0a3d2e !important; }
.produtor-item-icon { font-size: 2.5rem; margin-bottom: 0.75rem; }
.produtor-item-name { font-weight: 600; color: #fff !important; font-size: 1.1rem; margin-bottom: 0.25rem; }
.produtor-item-desc { font-size: 0.85rem; color: rgba(255,255,255,0.7) !important; }
.produtor-details { display: none; margin-top: 2rem; background: rgba(255,255,255,0.08); border-radius: 16px; padding: 2rem; }
.produtor-details.active { display: block; }
.produtor-details h3 { color: #d4a574; font-family: var(--font-display); font-size: 1.6rem; margin-bottom: 1.5rem; }
.produtor-locais { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1rem; }
.local-card { background: rgba(255,255,255,0.1); border-radius: 12px; padding: 1.25rem; display: flex; gap: 1rem; align-items: start; }
.local-icon { font-size: 2rem; }
.local-info h4 { color: #fff; margin-bottom: 0.5rem; }
.local-info p { color: rgba(255,255,255,0.75); font-size: 0.85rem; margin-bottom: 0.3rem; }
.local-actions { display: flex; gap: 0.5rem; margin-top: 0.75rem; flex-wrap: wrap; }
.local-btn { padding: 0.4rem 0.9rem; border-radius: 20px; font-size: 0.8rem; cursor: pointer; font-family: inherit; border: none; background: rgba(255,255,255,0.2); color: #fff; text-decoration: none; transition: background 0.2s; }
.local-btn:hover { background: #d4a574; color: #0a3d2e; }

/* Responsive */
@media (max-width: 768px) {
    .dishes-grid,
    .restaurants-grid { grid-template-columns: 1fr; }
    .restaurant-card { flex-direction: column; text-align: center; }
    .restaurant-icon { margin: 0 auto; }
}

@media (max-width: 480px) {
    .produtor-container { padding: 1.5rem 1rem; }
    .produtor-header h2 { font-size: 1.5rem; }
    .produtor-grid { grid-template-columns: repeat(2, 1fr); }
    .produtor-item { padding: 1rem; }
    .produtor-item-icon { font-size: 2rem; }
    .produtor-item-name { font-size: 0.95rem; }
    .produtor-section { padding: 2rem 1rem; }
}
