/* assets/css/style.css */
:root {
    --primary-green: #2C5F2D;
    --light-green: #97BC62;
    --bg-cream: #FDFBF7;
    --text-dark: #333333;
    --text-light: #666666;
    --border-color: #E5E5E5;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

/* FIX: Prevent horizontal scrolling globally */
html, body {
    overflow-x: hidden;
    width: 100%;
}

body {
    font-family: 'Lato', sans-serif;
    background-color: var(--bg-cream);
    color: var(--text-dark);
    line-height: 1.6;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    font-size: 16px; /* Standard base font size for desktop */
}

h1, h2, h3, .brand-logo { font-family: 'Playfair Display', serif; }
a { text-decoration: none; color: inherit; }

/* Top Bar & Header */
.top-bar {
    background-color: var(--primary-green);
    color: white;
    text-align: center;
    padding: 8px 15px;
    font-size: 0.85rem;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.site-header {
    background-color: white;
    border-bottom: 1px solid var(--border-color);
    position: sticky;
    top: 0;
    z-index: 1000;
}

.header-container {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 15px;
}

.brand-logo {
    font-size: 2rem;
    font-weight: 600;
    color: var(--primary-green);
    letter-spacing: 2px;
}
.brand-logo span {
    font-family: 'Lato', sans-serif;
    font-size: 1rem;
    font-weight: 300;
    letter-spacing: 4px;
    display: block;
    margin-top: -5px;
}

/* Navigation */
.main-nav > ul { list-style: none; display: flex; gap: 30px; }

/* Critical: Relative positioning so the dropdown attaches to the parent item */
.main-nav > ul > li { position: relative; padding: 10px 0; }

.main-nav a { font-size: 0.95rem; text-transform: uppercase; transition: color 0.3s ease; }
.main-nav > ul > li > a:hover { color: var(--light-green); }

/* Dropdown (Hidden by default) */
.main-nav .dropdown {
    display: none; 
    position: absolute;
    top: 100%;
    left: 0;
    background-color: white;
    min-width: 220px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    border: 1px solid var(--border-color);
    border-top: 3px solid var(--primary-green);
    padding: 10px 0;
    flex-direction: column;
    z-index: 999;
}

/* Trigger dropdown on hover for desktop */
.main-nav li:hover > .dropdown {
    display: flex;
    animation: fadeIn 0.3s ease;
}

.main-nav .dropdown li {
    list-style: none;
    padding: 0;
}

.main-nav .dropdown a {
    padding: 12px 20px;
    display: block;
    text-transform: none;
}

.main-nav .dropdown a:hover {
    background-color: var(--bg-cream);
    color: var(--primary-green);
    padding-left: 25px;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Header Icons */
.header-icons { display: flex; gap: 20px; }
.icon { cursor: pointer; font-size: 1.2rem; color: var(--primary-green); }

/* Main Content Area */
main { flex: 1; }

/* Site Footer */
.site-footer {
    background-color: var(--primary-green);
    color: white;
    text-align: center;
    padding: 20px;
    margin-top: auto;
}

/* ========================================================= */
/* 📱 ADVANCED MOBILE RESPONSIVENESS (HAMBURGER MENU) 📱 */
/* ========================================================= */

/* Eye-catching animation for the mobile menu toggle */
@keyframes menuPulse {
    0% { transform: scale(1); color: var(--primary-green); text-shadow: none; }
    50% { transform: scale(1.15); color: #C7511F; text-shadow: 0 0 10px rgba(199, 81, 31, 0.4); }
    100% { transform: scale(1); color: var(--primary-green); text-shadow: none; }
}

.mobile-toggle { 
    display: none; 
    font-size: 2rem; 
    cursor: pointer; 
    color: var(--primary-green); 
    user-select: none; 
    animation: menuPulse 2s infinite ease-in-out;
}

@media (max-width: 900px) {
    /* FIX: Increase global font size by ~1 point on mobile for better readability */
    html {
        font-size: 17.5px;
    }
    
    .header-container { flex-wrap: wrap; position: relative; padding: 15px 20px; }
    
    .mobile-toggle { display: block; }
    
    .brand-logo { font-size: 1.6rem; text-align: center; flex-grow: 1; margin-left: 10px;}
    .brand-logo span { font-size: 0.8rem; letter-spacing: 2px; }
    
    /* Convert Nav into a slide-down Mobile Menu */
    .main-nav {
        display: none; 
        width: 100%; 
        order: 3; 
        position: absolute; 
        top: 100%; 
        left: 0; 
        background: white; 
        border-top: 1px solid var(--border-color); 
        box-shadow: 0 10px 20px rgba(0,0,0,0.15); 
        max-height: 75vh; 
        overflow-y: auto;
    }
    .main-nav.active { display: block; }
    
    .main-nav > ul { flex-direction: column; gap: 0; width: 100%; }
    .main-nav > ul > li { padding: 0; width: 100%; border-bottom: 1px solid #f0f0f0; }
    .main-nav > ul > li > a { padding: 15px 20px; display: flex; justify-content: space-between; align-items: center; }
    
    /* Mobile Dropdown Indicator */
    .main-nav > ul > li.has-children > a::after { content: '▼'; font-size: 0.7rem; color: var(--primary-green); transition: 0.3s;}
    .main-nav > ul > li.open-mobile.has-children > a::after { transform: rotate(180deg); }

    /* Mobile Submenu Behavior */
    .main-nav .dropdown { position: static; display: none; box-shadow: none; border: none; background: #f9f9f9; padding: 0; width: 100%; }
    .main-nav li.open-mobile > .dropdown { display: flex; }
    .main-nav li:hover > .dropdown { display: none; } /* Disable hover popups on mobile touch screens */
    .main-nav li.open-mobile:hover > .dropdown { display: flex; }
    
    .main-nav .dropdown a { padding: 12px 30px; border-bottom: 1px solid #eee; }
}