/*
Theme Name: AmberOven Theme
Theme URI: https://amberoven.com
Author: Antigravity AI
Author URI: https://amberoven.com
Description: A clean, modern, grid-based custom recipe theme for AmberOven, inspired by major cooking networks.
Version: 1.0.0
Text Domain: amberoven
*/

/* ==========================================================================
   Design Tokens - Allrecipes Inspired Theme
   ========================================================================== */
:root {
    --color-primary: #E63946; 
    --color-primary-hover: #C1121F;
    --color-secondary: #F1FAEE;
    
    --color-bg: #FFFFFF;
    --color-bg-alt: #F8F9FA;
    --color-border: #E0E0E0;
    
    --color-text-dark: #2B2D42;
    --color-text-muted: #6C757D;
    
    --font-sans: 'Roboto', 'Inter', -apple-system, sans-serif;
    
    --max-width: 1200px;
    --spacing-xs: 0.5rem;
    --spacing-sm: 1rem;
    --spacing-md: 1.5rem;
    --spacing-lg: 3rem;
    
    --color-star: #FFB703;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: var(--font-sans); color: var(--color-text-dark); background-color: var(--color-bg); line-height: 1.5; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; height: auto; display: block; }

.container { width: 92%; max-width: var(--max-width); margin: 0 auto; }

/* ==========================================================================
   Top Navigation
   ========================================================================== */
.site-header { border-bottom: 1px solid var(--color-border); background: #fff; position: sticky; top: 0; z-index: 100; }
.top-bar { display: flex; justify-content: space-between; align-items: center; padding: 1rem 0; }
.brand-logo { font-size: 1.8rem; font-weight: 800; color: var(--color-primary); letter-spacing: -0.5px; }
.search-container { flex: 1; max-width: 500px; margin: 0 2rem; position: relative; }
.search-bar { width: 100%; padding: 0.8rem 1rem 0.8rem 2.5rem; border: 1px solid var(--color-border); border-radius: 4px; font-size: 1rem; font-family: var(--font-sans); background-color: var(--color-bg-alt); transition: background-color 0.2s; }
.search-bar:focus { background-color: #fff; outline: 2px solid var(--color-primary); border-color: transparent; }
.search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--color-text-muted); }
.nav-menu { border-top: 1px solid var(--color-border); padding: 0.8rem 0; }
.nav-links { display: flex; gap: 2rem; list-style: none; font-weight: 600; font-size: 0.95rem; text-transform: uppercase; }
.nav-links a:hover { color: var(--color-primary); text-decoration: underline; }

/* ==========================================================================
   Hero Section
   ========================================================================== */
.hero { margin-top: var(--spacing-md); margin-bottom: var(--spacing-lg); }
.hero-card { display: grid; grid-template-columns: 2fr 1fr; background: var(--color-bg-alt); border-radius: 8px; overflow: hidden; }
.hero-img { width: 100%; height: 100%; object-fit: cover; min-height: 400px; }
.hero-content { padding: var(--spacing-lg) var(--spacing-md); display: flex; flex-direction: column; justify-content: center; }
.hero-tag { color: var(--color-primary); font-weight: 700; text-transform: uppercase; font-size: 0.85rem; margin-bottom: var(--spacing-xs); letter-spacing: 1px; }
.hero-content h1 { font-size: 2.5rem; line-height: 1.1; margin-bottom: var(--spacing-sm); }
.hero-content p { color: var(--color-text-muted); margin-bottom: var(--spacing-md); }
.btn { display: inline-block; background: var(--color-primary); color: #fff; padding: 0.8rem 1.5rem; border-radius: 4px; font-weight: 600; text-align: center; transition: background 0.2s; border: none; cursor: pointer; }
.btn:hover { background: var(--color-primary-hover); }

/* ==========================================================================
   Recipe Grid
   ========================================================================== */
.section-title { font-size: 1.8rem; font-weight: 700; margin-bottom: var(--spacing-md); padding-bottom: var(--spacing-xs); border-bottom: 2px solid var(--color-primary); display: inline-block; }
.recipe-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: var(--spacing-md); margin-bottom: var(--spacing-lg); }
.recipe-card { background: #fff; border: 1px solid var(--color-border); border-radius: 4px; overflow: hidden; transition: box-shadow 0.2s; cursor: pointer; }
.recipe-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.card-img-container { aspect-ratio: 1 / 1; overflow: hidden; }
.card-img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.recipe-card:hover .card-img { transform: scale(1.05); }
.card-content { padding: var(--spacing-sm); }
.card-rating { display: flex; align-items: center; gap: 4px; color: var(--color-star); font-size: 1.1rem; margin-bottom: var(--spacing-xs); }
.rating-count { color: var(--color-text-muted); font-size: 0.85rem; margin-left: 4px; }
.card-title { font-size: 1.1rem; font-weight: 700; margin-bottom: var(--spacing-xs); line-height: 1.3; }
.card-title a:hover { color: var(--color-primary); }
.card-author { font-size: 0.85rem; color: var(--color-text-muted); }

/* ==========================================================================
   Footer
   ========================================================================== */
footer { background: var(--color-bg-alt); padding: var(--spacing-lg) 0; border-top: 1px solid var(--color-border); }
.footer-content { display: flex; justify-content: space-between; align-items: center; }

@media (max-width: 768px) {
    .top-bar { flex-wrap: wrap; }
    .search-container { order: 3; max-width: 100%; margin: 1rem 0 0 0; }
    .nav-links { display: none; }
    .hero-card { grid-template-columns: 1fr; }
    .hero-img { min-height: 250px; }
}
