/*
Theme Name: Historic Aviation Military
Theme URI: https://garylea.com
Description: Custom theme for Historic Aviation Military - WW2 aviation history. Blue background with white content card, Elementor compatible.
Version: 7.2
Author: Malcolm Webb
Author URI: https://historicaviationmilitary.com
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: historic-aviation-military
*/

/* Reset */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
    background-color: #5a6fd4 !important;
    font-family: Arial, Helvetica, sans-serif;
    margin: 0 !important;
    padding: 0 !important;
}

/* ============================
   NAVIGATION - HORIZONTAL
   ============================ */
.ham-nav {
    background: linear-gradient(90deg, #0d1f3c 0%, #1a2f55 20%, #2c4a8b 50%, #1a2f55 80%, #0d1f3c 100%) !important;
    border-top: 2px solid rgba(255,255,255,0.6);
    border-bottom: 2px solid rgba(255,255,255,0.6);
    padding: 8px 12px !important;
    text-align: center;
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 1000;
}

/* The UL - HORIZONTAL flex row */
.ham-nav ul,
.ham-nav ul.menu,
.ham-nav .ham-menu,
nav.ham-nav ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 4px !important;
}

/* Each LI - inline, not block */
.ham-nav li,
.ham-nav ul li,
.ham-nav .menu-item {
    display: inline-flex !important;
    margin: 0 !important;
    padding: 0 !important;
    position: relative;
    vertical-align: middle;
}

/* Nav links - pill buttons */
.ham-nav li a,
.ham-nav .menu-item a,
.ham-nav .menu-item > a span {
    display: inline-block !important;
    padding: 7px 14px !important;
    background: rgba(255,255,255,0.13) !important;
    color: white !important;
    text-decoration: none !important;
    border-radius: 30px !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    border: 1px solid rgba(255,255,255,0.8) !important;
    letter-spacing: 0.3px;
    transition: background 0.2s ease;
    cursor: pointer;
    line-height: 1.4 !important;
}

/* Hover effect */
.ham-nav li a:hover,
.ham-nav .menu-item a:hover {
    background: rgba(255,255,255,0.28) !important;
}

/* Items with children - the parent link */
.ham-nav li.menu-item-has-children > a,
.ham-nav .menu-item-has-children > a {
    cursor: pointer;
}

/* Sub-menu dropdown */
.ham-nav ul.sub-menu,
.ham-nav li ul.sub-menu,
.ham-nav .sub-menu {
    display: none !important;
    position: absolute !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    top: calc(100% + 4px) !important;
    min-width: 220px !important;
    max-width: min(90vw, 400px) !important;
    background: rgba(13,31,60,0.98) !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    border-radius: 14px !important;
    padding: 8px 6px !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.45) !important;
    z-index: 1100 !important;
    list-style: none !important;
    flex-direction: column !important;
    gap: 2px !important;
}

/* Show dropdown on hover */
.ham-nav li:hover > ul.sub-menu,
.ham-nav .menu-item-has-children:hover > .sub-menu {
    display: flex !important;
}

/* Sub-menu items */
.ham-nav ul.sub-menu li,
.ham-nav .sub-menu .menu-item {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Sub-menu links */
.ham-nav ul.sub-menu a,
.ham-nav .sub-menu a {
    display: block !important;
    padding: 7px 12px !important;
    border-radius: 10px !important;
    background: transparent !important;
    border: 1px solid transparent !important;
    color: rgba(255,255,255,0.92) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    white-space: normal !important;
    text-align: left !important;
}

.ham-nav ul.sub-menu a:hover,
.ham-nav .sub-menu a:hover {
    background: rgba(255,255,255,0.12) !important;
    border-color: rgba(255,255,255,0.18) !important;
}

/* ============================
   CONTENT CARD WRAPPER
   ============================ */
.ham-card-wrap {
    background: #5a6fd4;
    min-height: 50vh;
    padding: 40px 0 60px;
}

/* ============================
   FOOTER
   ============================ */
.ham-footer {
    background: linear-gradient(90deg, #0a1628 0%, #1a2f55 50%, #0a1628 100%);
    border-top: 2px solid rgba(255,255,255,0.5);
    padding: 20px 16px;
    text-align: center;
}
.ham-footer p { color: #aab4cc; font-family: Arial; font-size: 12px; margin: 4px 0; letter-spacing: 0.8px; }
.ham-footer a { color: #7a9acc !important; text-decoration: none !important; }
.ham-footer a:hover { color: white !important; }

/* ============================
   ELEMENTOR CONTENT STYLING
   ============================ */

/* Constrain outer container */
body .elementor-section,
body .e-con,
body .e-con-boxed,
body .e-con-full,
.ham-card-wrap .elementor-widget-wrap > .elementor-element {
    max-width: 980px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Headings - red, centred, max 800px */
.elementor-widget-heading {
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.elementor-widget-heading h1,
.elementor-widget-heading h2,
.elementor-widget-heading h3,
.elementor-widget-heading h4,
.elementor-widget-heading h5,
.elementor-widget-heading h6 {
    font-family: Tahoma, Arial, sans-serif !important;
    font-weight: 900 !important;
    color: #cc0000 !important;
    text-align: center !important;
    line-height: 1.35 !important;
}

/* Text editor - left aligned, max 800px */
.elementor-widget-text-editor {
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.elementor-widget-text-editor p {
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 16px !important;
    line-height: 1.7 !important;
    color: #000000 !important;
    text-align: left !important;
    margin: 0 auto 16px auto !important;
}

/* Images - centred, max 800px, blue border */
.elementor-widget-image {
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.elementor-widget-image img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
    margin: 0 auto !important;
    border: 3px solid #4a7ab5 !important;
    border-radius: 14px !important;
    box-shadow: none !important;
}

/* ============================
   MOBILE
   ============================ */
@media (max-width: 1100px) {
    body .elementor-section,
    body .e-con {
        max-width: 96% !important;
    }
}
@media (max-width: 768px) {
    .ham-nav li a,
    .ham-nav .menu-item a {
        font-size: 10px !important;
        padding: 5px 9px !important;
    }
    .ham-card-wrap { padding: 20px 0 36px; }
    .elementor-widget-heading,
    .elementor-widget-text-editor,
    .elementor-widget-image {
        max-width: 100% !important;
    }
    body .elementor-section,
    body .e-con {
        max-width: 98% !important;
    }
}
