/**
Theme Name: Mackenzie
Author: Jeremiah Castillo
Author URI: https://www.kre8ivdesigns.com
Description: Astra is the fastest, fully customizable & beautiful theme suitable for blogs, personal portfolios and business websites. It is very lightweight (less than 50KB on frontend) and offers unparalleled speed. Built with SEO in mind, Astra comes with schema.org code integrated so search engines will love your site. Astra offers plenty of sidebar options and widget areas giving you a full control for customizations. Furthermore, we have included special features and templates so feel free to choose any of your favorite page builder plugin to create pages flexibly. Some of the other features: # WooCommerce Ready # Responsive # Compatible with major plugins # Translation Ready # Extendible with premium addons # Regularly updated # Designed, Developed, Maintained & Supported by Brainstorm Force. Looking for a perfect base theme? Look no further. Astra is fast, fully customizable and beautiful theme!
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mackenzie
Template: astra
*/

/* ============================================
   BLUEGRASS & GRACE — Brand Design Tokens
   ============================================ */
:root {
    --dark-green: #3B5B4E;
    --dark-green-hover: #2E4A3F;
    --dark-green-active: #243D33;
    --burgundy: #7B4B5A;
    --burgundy-hover: #6A3F4E;
    --olive: #8B7D5A;
    --cream: #F5EFE0;
    --black: #1A1A1A;
    --warm-gold: #B08D57;
    --white: #FFFFFF;
    --light-border: #D4CFC4;
    --font-display: 'Great Vibes', cursive;
    --font-body: 'Poppins', sans-serif;
    --shadow-rest: 0 2px 12px rgba(26, 26, 26, 0.06);
    --shadow-hover: 0 8px 24px rgba(26, 26, 26, 0.10);
    --radius-btn: 8px;
    --radius-card: 12px;
    --radius-pill: 20px;
}

/* ============================================
   GLOBAL STYLES
   ============================================ */
body {
    font-family: var(--font-body) !important;
    color: var(--black);
    background: var(--cream);
    line-height: 1.7;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-body) !important;
}

/* ============================================
   BUTTON SYSTEM
   ============================================ */
.btn,
.bg-btn {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 14px 32px;
    border-radius: var(--radius-btn);
    transition: all 0.3s ease;
    min-width: 160px;
    text-align: center;
    line-height: 1.4;
    text-decoration: none;
    cursor: pointer;
    border: none;
}

.btn--primary,
.bg-btn-primary {
    background: var(--dark-green);
    color: var(--white) !important;
    box-shadow: 0 2px 8px rgba(59, 91, 78, 0.20);
}
.btn--primary:hover,
.bg-btn-primary:hover {
    background: var(--dark-green-hover);
    transform: translateY(-1px);
    color: var(--white) !important;
}

.btn--secondary,
.bg-btn-secondary {
    background: transparent;
    color: var(--dark-green) !important;
    border: 2px solid var(--dark-green);
}
.btn--secondary:hover,
.bg-btn-secondary:hover {
    background: var(--dark-green);
    color: var(--white) !important;
}

.btn--cta,
.bg-btn-cta {
    background: var(--burgundy);
    color: var(--white) !important;
    font-size: 16px;
    letter-spacing: 2px;
    padding: 16px 40px;
    box-shadow: 0 4px 16px rgba(123, 75, 90, 0.25);
}
.btn--cta:hover,
.bg-btn-cta:hover {
    background: var(--burgundy-hover);
    transform: translateY(-1px);
    color: var(--white) !important;
}

.btn--ghost,
.bg-btn-ghost {
    background: none;
    color: var(--burgundy) !important;
    font-size: 14px;
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
    padding: 8px 0;
    min-width: auto;
    border-bottom: 1px solid var(--warm-gold);
    border-radius: 0;
}
.btn--ghost:hover,
.bg-btn-ghost:hover {
    color: var(--dark-green) !important;
    border-bottom-width: 2px;
}

/* ============================================
   UTILITY CLASSES
   ============================================ */
.bg-cream { background-color: var(--cream) !important; }
.bg-white { background-color: var(--white) !important; }
.bg-dark-green { background-color: var(--dark-green) !important; }
.bg-burgundy { background-color: var(--burgundy) !important; }

.text-dark-green { color: var(--dark-green) !important; }
.text-burgundy { color: var(--burgundy) !important; }
.text-olive { color: var(--olive) !important; }
.text-warm-gold { color: var(--warm-gold) !important; }
.text-white { color: var(--white) !important; }

.gold-divider {
    width: 80px;
    height: 1px;
    background: var(--warm-gold);
    margin: 0 auto 40px;
}

.eyebrow {
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 16px;
}

.section-title {
    font-family: var(--font-body);
    font-size: 30px;
    font-weight: 700;
    color: var(--dark-green);
    text-align: center;
    margin-bottom: 16px;
}

.display-font {
    font-family: var(--font-display) !important;
}

/* ============================================
   CARD STYLES
   ============================================ */
.bg-card {
    background: var(--white);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow-rest);
    overflow: hidden;
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}
.bg-card:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-4px);
}

.bg-card img {
    width: 100%;
    object-fit: cover;
}

.bg-card-body {
    padding: 24px;
}

.bg-card-tag {
    display: inline-block;
    background: var(--dark-green);
    color: var(--white);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: var(--radius-pill);
}

/* ============================================
   QUOTE CARD
   ============================================ */
.bg-quote-card {
    background: var(--cream);
    border-radius: var(--radius-card);
    padding: 32px;
    position: relative;
}
.bg-quote-mark {
    font-family: var(--font-display);
    font-size: 72px;
    color: var(--warm-gold);
    opacity: 0.3;
    position: absolute;
    top: 12px;
    left: 20px;
    line-height: 1;
}

/* ============================================
   FORM STYLES
   ============================================ */
.bg-form input[type="text"],
.bg-form input[type="email"],
.bg-form textarea {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--light-border);
    border-radius: var(--radius-btn);
    font-family: var(--font-body);
    font-size: 16px;
    color: var(--black);
    outline: none;
    background: var(--white);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.bg-form input:focus,
.bg-form textarea:focus {
    border: 2px solid var(--dark-green);
    box-shadow: 0 0 0 3px rgba(59, 91, 78, 0.12);
}

/* ============================================
   FILTER PILLS
   ============================================ */
.filter-pill {
    padding: 8px 18px;
    border: 1px solid var(--olive);
    border-radius: var(--radius-pill);
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--olive);
    background: transparent;
    cursor: pointer;
    transition: all 0.3s ease;
}
.filter-pill:hover {
    border-color: var(--dark-green);
    color: var(--dark-green);
}
.filter-pill.active {
    background: var(--dark-green);
    color: var(--white);
    border-color: var(--dark-green);
}

/* ============================================
   LIFESTYLE CARD
   ============================================ */
.bg-lifestyle-card {
    position: relative;
    border-radius: var(--radius-card);
    overflow: hidden;
    display: flex;
    align-items: flex-end;
}
.bg-lifestyle-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}
.bg-lifestyle-card:hover img {
    transform: scale(1.03);
}
.bg-lifestyle-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(26,26,26,0.60), rgba(26,26,26,0.05));
    transition: background 0.4s ease;
    pointer-events: none;
}
.bg-lifestyle-card:hover::after {
    background: linear-gradient(to top, rgba(26,26,26,0.72), rgba(26,26,26,0.10));
}
.bg-lifestyle-card-content {
    position: relative;
    z-index: 1;
    padding: 32px;
}

/* ============================================
   ELEMENTOR OVERRIDES
   ============================================ */
.elementor-widget-heading .elementor-heading-title {
    font-family: var(--font-body);
}

.elementor-section.bg-section-cream {
    background-color: var(--cream) !important;
}
.elementor-section.bg-section-white {
    background-color: var(--white) !important;
}
.elementor-section.bg-section-dark-green {
    background-color: var(--dark-green) !important;
}

/* ============================================
   SCROLL REVEAL
   ============================================ */
.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 767px) {
    .btn, .bg-btn {
        padding: 12px 24px;
        font-size: 13px;
    }
    .btn--cta, .bg-btn-cta {
        padding: 14px 28px;
        font-size: 14px;
    }
}


/* ============================================
   FULL-WIDTH LAYOUT + 1400px INNER CONTENT
   ============================================ */

/* Remove Astra boxed layout constraints */
.ast-separate-container .ast-article-single,
.ast-separate-container .ast-article-post,
.ast-separate-container .comment-respond {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.ast-separate-container #primary,
.ast-separate-container .ast-container {
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Plain container — full width, no padding */
.ast-plain-container .site-content > .ast-container {
    max-width: 100% !important;
    padding: 0 !important;
}

/* Make ALL Elementor sections stretch full-width (backgrounds edge-to-edge) */
.elementor .elementor-section {
    width: 100% !important;
    max-width: 100% !important;
}

/* Ensure Elementor wrapper itself is full width */
.elementor {
    width: 100% !important;
}

/* Inner container stays at 1400px centered */
.elementor-section.elementor-section-boxed > .elementor-container {
    max-width: 1400px !important;
    margin: 0 auto !important;
}

.elementor-section.elementor-section-full_width > .elementor-container {
    max-width: 100% !important;
}

.elementor-section.elementor-section-stretched,
.elementor-section-full_width {
    width: 100% !important;
    max-width: 100% !important;
}

/* Remove any site wrapper padding/margin */
#page,
.site {
    padding: 0 !important;
    margin: 0 auto !important;
    max-width: 100% !important;
    overflow-x: hidden;
}

#content,
.site-content {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    min-width: 100% !important;
    overflow: visible !important;
}

/* Prevent horizontal scrollbar from full-width sections */
#page,
.site {
    overflow-x: hidden !important;
}

/* Astra header — full width bg, 1400px inner */
.main-header-bar,
.ast-primary-header-bar {
    width: 100% !important;
}
.main-header-bar .ast-container,
.ast-primary-header-bar .ast-container {
    max-width: 1400px !important;
    margin: 0 auto;
}

/* Footer — full width bg, 1400px inner */
.site-footer,
.ast-small-footer {
    width: 100% !important;
}
.site-footer .ast-container,
.ast-small-footer .ast-container {
    max-width: 1400px !important;
    margin: 0 auto;
}

/* Elementor top-level — remove any Astra wrapper constraints */
.elementor-page .site-content > .ast-container,
.elementor-page #primary {
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

.elementor-page .ast-container {
    max-width: 100% !important;
    padding: 0 !important;
}

/* Blog archive / single post content — 1400px centered */
.ast-separate-container .ast-article-single .entry-content,
.ast-separate-container .ast-article-post .entry-content,
.blog .ast-container,
.single-post .ast-container {
    max-width: 1400px !important;
    margin: 0 auto;
}

