.elementor-12 .elementor-element.elementor-element-f10948e{--display:flex;}.elementor-12 .elementor-element.elementor-element-2071097{margin:2px 0px calc(var(--kit-widget-spacing, 0px) + 45px) 0px;}.elementor-12 .elementor-element.elementor-element-1f8668c{--display:flex;}.elementor-12 .elementor-element.elementor-element-ee1323d{margin:-61px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-12 .elementor-element.elementor-element-d9d9bce{--display:flex;}.elementor-12 .elementor-element.elementor-element-b81ece3{margin:-100px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-12 .elementor-element.elementor-element-1d3ca27{--display:flex;}.elementor-12 .elementor-element.elementor-element-c2d5504{margin:-86px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-12 .elementor-element.elementor-element-a58bcdf{--display:flex;}.elementor-12 .elementor-element.elementor-element-4bd228d{margin:-44px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-12 .elementor-element.elementor-element-b55d60a{--display:flex;}.elementor-12 .elementor-element.elementor-element-430e7c8{margin:-76px 0px calc(var(--kit-widget-spacing, 0px) + -84px) 0px;}:root{--page-title-display:none;}@media(max-width:767px){.elementor-12 .elementor-element.elementor-element-ee1323d{margin:-78px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-12 .elementor-element.elementor-element-c2d5504{margin:-86px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}}/* Start custom CSS for html, class: .elementor-element-2071097 *//* 1. CRITICAL: Remove default browser gaps */
.body {
    margin: 0;
    padding: 0;
    width: 100%;
    overflow-x: hidden;
}

.mgt-hero-bright {
    position: relative;
    width: 100%;
    /* Ensure it takes at least the full screen, even on short phones */
    min-height: 100dvh; 
    display: flex;
    align-items: center;
    justify-content: center; 
    padding: 40px 20px;
    box-sizing: border-box; /* Includes padding in the height calculation */
    background-color: #111111;
    overflow: hidden;
}

/* 2. THE BACKGROUND - This forces it to ignore everything and fill the area */
.mgt-hero-bg-wrapper {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 100% !important;
}

.mgt-hero-bg-img {
    width: 100vw !important;
    height: 100vh !important;
    object-fit: cover !important;
    object-position: center !important;
    position: absolute;
    top: 0;
    left: 0;
}

/* 3. THE OVERLAY - Adds depth and makes text pop */
.mgt-hero-bg-wrapper::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0.5), rgba(0,0,0,0.3), rgba(0,0,0,0.6));
    z-index: 2;
}

/* 4. THE CONTENT */
.mgt-hero-content-container {
    position: relative;
    z-index: 10; /* Put it way above the background */
    width: 100%;
    max-width: 800px;
    margin: auto;
}

.mgt-solid-text-box {
    text-align: center;
    width: 100%;
}

/* Titles and Labels */
.mgt-label-black {
    color: #CC6B14 !important;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 3px;
    display: block;
    margin-bottom: 15px;
}

.mgt-h1-massive {
    font-size: clamp(2.2rem, 10vw, 4.5rem); 
    color: #ffffff;
    line-height: 1.1;
    font-weight: 900;
    margin: 0 0 20px 0;
    text-transform: uppercase;
}

.mgt-accent-line-thick {
    width: 60px;
    height: 4px;
    background-color: #CC6B14; 
    margin: 0 auto 30px auto;
}

/* The Description Box */
.mgt-hero-p-black {
    font-size: 1.1rem;
    color: #ffffff;
    line-height: 1.6;
    margin: 0 auto 35px auto;
    padding: 20px;
    max-width: 550px;
     /* Darker for better phone readability */

}

/* 5. BUTTONS */
.mgt-hero-btn-group {
    display: flex;
    justify-content: center;
    gap: 15px;
    width: 100%;
}

.mgt-btn-massive-black {
    background: #000;
    color: #fff;
    padding: 18px 30px;
    text-decoration: none;
    font-weight: 900;
    border: 3px solid #000;
    text-transform: uppercase;
}

.mgt-btn-outline-bold {
    background: transparent;
    color: #fff !important;
    padding: 18px 30px;
    text-decoration: none;
    font-weight: 900;
    border: 3px solid #CC6B14;
    text-transform: uppercase;
}

/* =========================================
   MOBILE CLEANUP
   ========================================= */
@media (max-width: 768px) {
    .mgt-hero-bright {
        /* This ensures that on small screens, the content doesn't get squeezed */
        height: auto;
        min-height: 100dvh;
        padding: 60px 20px;
    }

    .mgt-hero-btn-group {
        flex-direction: column;
        align-items: center;
    }

    .mgt-btn-massive-black, 
    .mgt-btn-outline-bold {
        width: 100%;
        max-width: 300px;
        text-align: center;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ee1323d *//* HOME SECTION 2: INTRODUCTION - HIGH VISIBILITY */

.mgt-home-intro-section {
    padding: 120px 5%;
    background-color: #FAF6F0; /* Soft Alabaster background */
    border-bottom: 4px solid #000000; /* Thick section divider */
}

.mgt-home-intro-flex {
    display: flex;
    align-items: center;
    gap: 80px;
    max-width: 1400px;
    margin: 0 auto;
}

.mgt-home-intro-text {
    flex: 1.2;
}

/* Typography reusing our bold rules */
.mgt-p-black-large {
    font-family: var(--font-body);
    font-size: 1.3rem; /* Very large and readable */
    color: #000000; /* Pure black */
    font-weight: 700;
    line-height: 1.7;
    margin-bottom: 25px;
}

.mgt-text-link-bold {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 1.2rem;
    font-weight: 900;
    color: #000000;
    text-transform: uppercase;
    letter-spacing: 2px;
    text-decoration: none;
    border-bottom: 4px solid #CC6B14; /* Thick orange underline */
    padding-bottom: 5px;
    margin-top: 20px;
    transition: color 0.3s;
}

.mgt-text-link-bold:hover {
    color: #CC6B14;
}

/* The Image Frame */
.mgt-home-intro-visual {
    flex: 1;
    position: relative;
}

.mgt-image-frame-bold {
    position: relative;
    border: 6px solid #000000; /* MASSIVE BLACK FRAME */
    background: #ffffff;
    padding: 15px; /* Creates a white "mat" around the photo like a museum frame */
    box-shadow: 20px 20px 0px #CC6B14; /* Bold Orange offset */
}

.mgt-image-frame-bold img {
    width: 100%;
    height: 500px;
    object-fit: cover;
    display: block;
    border: 2px solid #000000; /* Inner border for the photo itself */
}

/* High Contrast Floating Badge */
.mgt-badge-bold {
    position: absolute;
    bottom: -30px;
    left: -30px;
    background: #000000;
    color: #ffffff;
    width: 120px;
    height: 120px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border: 4px solid #CC6B14; /* Orange edge */
    text-transform: uppercase;
}

.mgt-badge-bold span {
    font-family: var(--font-heading);
    font-size: 2.5rem;
    font-weight: 900;
    line-height: 1;
}

.mgt-badge-bold small {
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 900;
    letter-spacing: 2px;
    margin-top: 5px;
}

/* Mobile Adjustments */
@media (max-width: 991px) {
    .mgt-home-intro-flex {
        flex-direction: column;
        gap: 60px;
    }
    .mgt-home-intro-text, .mgt-home-intro-visual {
        width: 100%;
    }
    .mgt-image-frame-bold img {
        height: 400px;
    }
    .mgt-badge-bold {
        bottom: -20px;
        left: -10px;
        width: 100px;
        height: 100px;
    }
    .mgt-badge-bold span { font-size: 2rem; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-b81ece3 *//* =========================================
   SIGNATURE JOURNEYS GRID (CSS)
   ========================================= */
:root {
    --mgt-orange: #CC6B14; /* Change this ONE value */
}

/* Then use it like this throughout your CSS: */
.mgt-text-orange { color: var(--mgt-orange); }
.mgt-btn-orange-massive { background-color: var(--mgt-orange); }
.mgt-special-tours {
    padding: 100px 5%;
    background-color: #ffffff;
}

/* --- The Grid System --- */
.mgt-tours-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto;
}

/* --- Tour Card Styles --- */
.mgt-tour-card {
    background: #ffffff;
    border: 3px solid #000000;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    position: relative;
    display: flex;
    flex-direction: column;
}

.mgt-tour-card:hover {
    transform: translateY(-10px);
    box-shadow: 12px 12px 0px #CC6B14;
}

/* Card Image Area */
.mgt-tour-card-img {
    height: 250px;
    background-size: cover;
    background-position: center;
    position: relative;
    border-bottom: 3px solid #000000;
}

.mgt-badge-featured {
    position: absolute;
    top: 15px;
    left: 15px;
    background-color: #CC6B14;
    color: #ffffff;
    padding: 6px 15px;
    font-family: var(--font-body);
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Card Text Content */
.mgt-tour-card-content {
    padding: 30px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    text-align: center;
}

.mgt-tour-meta {
    font-family: var(--font-body);
    font-size: 0.85rem;
    font-weight: 800;
    color: #CC6B14;
    text-transform: uppercase;
    margin-bottom: 10px;
    letter-spacing: 1px;
}

.mgt-tour-card-title {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    font-weight: 900;
    color: #000000;
    margin: 0 0 15px 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.mgt-tour-card-desc {
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.6;
    color: #444;
    margin-bottom: 25px;
}

/* Card Button */
.mgt-btn-card {
    margin-top: auto; /* Pushes button to bottom if text lengths differ */
    text-decoration: none;
    font-family: var(--font-body);
    font-weight: 900;
    color: #000000;
    text-transform: uppercase;
    font-size: 0.9rem;
    letter-spacing: 1px;
    transition: all 0.3s ease;
    display: inline-block;
}

.mgt-btn-card:hover {
    color: #CC6B14;
    padding-left: 5px;
}

/* --- Mobile Adjustments --- */
@media (max-width: 768px) {
    .mgt-special-tours {
        padding: 60px 5%;
    }
    
    .mgt-tours-grid {
        grid-template-columns: 1fr; /* Stack on mobile */
    }

    .mgt-tour-card:hover {
        transform: none; /* Disable hover movement on touch for better UX */
        box-shadow: 8px 8px 0px #CC6B14;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-c2d5504 *//* HOME SECTION 3: GATEWAYS - HIGH VISIBILITY */

.mgt-gateways-section {
    padding: 120px 5%;
    background-color: #ffffff; /* Pure white background to make the black borders pop */
}

.mgt-grid-header-center {
    text-align: center;
    margin-bottom: 70px;
}

.mgt-gateway-grid-bold {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    margin-bottom: 60px;
}

/* The Jumbo Card */
.mgt-gateway-card {
    display: block;
    text-decoration: none;
    position: relative;
    border: 5px solid #000000; /* THICK BLACK FRAME */
    background: #000000;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.mgt-gateway-card:hover {
    transform: translateY(-10px);
    box-shadow: 15px 15px 0px #CC6B14; /* Bold Orange Shadow appears on hover */
}

.mgt-gateway-image {
    height: 350px;
    width: 100%;
    overflow: hidden;
    border-bottom: 5px solid #000000; /* Line separating image from text box */
}

.mgt-gateway-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.mgt-gateway-card:hover .mgt-gateway-image img {
    transform: scale(1.05); /* Slight zoom so they know it's clickable */
}

/* The Solid Label Box */
.mgt-gateway-label-box {
    background-color: #ffffff; /* Pure white box */
    padding: 25px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.mgt-gateway-name {
    font-family: var(--font-heading);
    font-size: 2.2rem;
    color: #000000; /* Pure Black text */
    font-weight: 900;
    margin: 0;
    text-transform: uppercase;
}

.mgt-gateway-arrow {
    font-size: 2rem;
    color: #CC6B14; /* Orange arrow */
    font-weight: 900;
}

/* Mobile Adjustments */
@media (max-width: 1024px) {
    .mgt-gateway-grid-bold {
        grid-template-columns: repeat(2, 1fr); /* 2 columns on tablets */
    }
}

@media (max-width: 768px) {
    .mgt-gateway-grid-bold {
        grid-template-columns: 1fr; /* 1 column on phones */
    }
    .mgt-gateway-name {
        font-size: 1.8rem;
    }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-1d3ca27 *//* --- RESPONSIVE BUTTON WRAPPER --- */

.mgt-center-btn-wrapper {
    display: flex;
    justify-content: center; /* Centers horizontally on desktop */
    align-items: center;
    padding: 60px 20px;      /* Gives the button breathing room top and bottom */
    width: 100%;
    box-sizing: border-box;
}

.mgt-btn-outline-bold {
    display: inline-block;
    padding: 20px 45px;
    font-family: var(--font-body);
    font-weight: 900;
    font-size: 1.1rem;
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 2px;
    color: #000000;
    border: 4px solid #000000; /* Matches the heavy-duty brand look */
    background-color: transparent;
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
    text-align: center;
}

/* The "Glamour" Hover State */
.mgt-btn-outline-bold:hover {
    background-color: #000000;
    color: #ffffff;
    box-shadow: 10px 10px 0px #CC6B14; /* Your signature orange shadow */
    transform: translate(-5px, -5px);
}

/* --- MOBILE ADJUSTMENTS (Phone & Tablet) --- */

@media (max-width: 768px) {
    .mgt-center-btn-wrapper {
        padding: 40px 10%; /* Tighter padding for mobile */
    }

    .mgt-btn-outline-bold {
        width: 100%;       /* Full-width button on mobile for better UX */
        font-size: 1rem;   /* Slightly smaller text for small screens */
        padding: 18px 20px;
        box-sizing: border-box;
    }
}

@media (max-width: 480px) {
    .mgt-btn-outline-bold {
        letter-spacing: 1px; /* Prevents text from overflowing on very narrow phones */
        border-width: 3px;   /* Slightly thinner border for a cleaner look on small screens */
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-4bd228d *//* =========================================
   WHY CHOOSE US - EDITORIAL LIST
   ========================================= */

.mgt-why-section {
    padding: 100px 5%;
    background-color: #FAF6F0; /* Alabaster background */
}

.mgt-why-wrapper {
    max-width: 1100px;
    margin: 0 auto;
    border-top: 4px solid #000000;
}

/* Individual Rows */
.mgt-why-row {
    display: flex;
    align-items: center;
    padding: 40px 30px;
    border-bottom: 4px solid #000000;
    background-color: transparent;
    transition: all 0.4s cubic-bezier(0.25, 0.8, 0.25, 1); /* Smooth snap */
    cursor: default;
}

/* Hover Effect: Dark Mode + Slide */
.mgt-why-row:hover {
    background-color: #000000;
    transform: translateX(15px); /* Slides slightly to the right */
    border-bottom-color: #CC6B14;
    box-shadow: -10px 10px 0px #CC6B14;
}

/* The Massive Outline Numbers */
.mgt-why-number {
    font-family: var(--font-heading);
    font-size: 5.5rem;
    font-weight: 900;
    color: transparent; /* Makes the inside of the text invisible */
    -webkit-text-stroke: 2px #CC6B14; /* Orange Outline */
    width: 150px;
    flex-shrink: 0;
    transition: all 0.4s ease;
    line-height: 1;
}

.mgt-why-row:hover .mgt-why-number {
    color: #CC6B14; /* Fills in the number on hover */
}

/* Text Content */
.mgt-why-content {
    flex: 1;
}

.mgt-why-title {
    font-family: var(--font-heading);
    font-size: 1.8rem;
    font-weight: 900;
    text-transform: uppercase;
    color: #000000;
    margin: 0 0 15px 0;
    transition: color 0.4s ease;
}

.mgt-why-desc {
    font-family: var(--font-body);
    font-size: 1.15rem;
    line-height: 1.6;
    color: #333333;
    font-weight: 700;
    margin: 0;
    transition: color 0.4s ease;
}

/* Hover Colors for Text */
.mgt-why-row:hover .mgt-why-title {
    color: #ffffff;
}

.mgt-why-row:hover .mgt-why-desc {
    color: #e0e0e0;
}

/* --- MOBILE RESPONSIVE --- */
@media (max-width: 768px) {
    .mgt-why-row {
        flex-direction: column;
        align-items: flex-start;
        padding: 30px 20px;
    }
    
    .mgt-why-number {
        font-size: 4rem;
        margin-bottom: 15px;
        -webkit-text-stroke: 1.5px #CC6B14;
    }

    .mgt-why-row:hover {
        transform: translateY(-10px); /* Slides UP instead of RIGHT on mobile */
        box-shadow: 10px 10px 0px #CC6B14;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-430e7c8 *//* FIXED TESTIMONIALS - HIGH VISIBILITY */

.mgt-testimonials-fixed {
    padding: 100px 5%;
    background-color: #FAF6F0; /* Clean Alabaster */
}

.mgt-header-bold {
    text-align: center;
    margin-bottom: 60px;
}

.mgt-label-black {
    color: #000000;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 3px;
    display: block;
    margin-bottom: 10px;
}

.mgt-heading-black {
    font-family: var(--font-heading);
    font-size: 3rem;
    color: #000000;
    margin: 0;
}

.mgt-divider-thick {
    width: 80px;
    height: 6px;
    background-color: #CC6B14; /* Deep Orange */
    margin: 20px auto;
}

/* Grid for better layout than the slider */
.mgt-testimonial-grid-fixed {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}

/* The "Bold" Card - Fixed for your vision */
.mgt-card-bold {
    background: #ffffff;
    border: 4px solid #000000; /* THICK BLACK BORDER */
    padding: 40px;
    box-shadow: 10px 10px 0px #000000; /* SOLID SHADOW YOU CAN SEE */
}

.mgt-stars-bold {
    color: #CC6B14;
    font-size: 1.5rem;
    margin-bottom: 20px;
}

.mgt-quote-black {
    font-family: var(--font-heading);
    font-size: 1.4rem;
    color: #000000; /* PURE BLACK */
    line-height: 1.4;
    font-style: italic;
    font-weight: 700;
    margin-bottom: 30px;
}

.mgt-author-box {
    border-top: 2px solid #000000;
    padding-top: 20px;
    font-family: var(--font-body);
    color: #000000;
}

.mgt-author-box strong {
    font-size: 1.1rem;
    text-transform: uppercase;
}

/* Mobile Adjustments */
@media (max-width: 768px) {
    .mgt-testimonial-grid-fixed {
        grid-template-columns: 1fr;
    }
    .mgt-heading-black {
        font-size: 2.2rem;
    }
}/* End custom CSS */