/* =========================
   ABENG365 BLOCK THEME
========================= */

:root {
    --space-xs: 0.5rem;
    --space-sm: 1rem;
    --space-md: 2rem;
    --space-lg: 3rem;
    --space-xl: 5rem;

    --max-width: 1180px;

    --color-bg: #fbfaf7;
    --color-surface: #ffffff;
    --color-text: #111111;
    --color-muted: #555555;
    --color-subtle: #777777;

    --color-green: #103f22;
    --color-green-dark: #0b2f18;
    --color-green-soft: #edf3e6;

    --color-gold: #c7a008;
    --color-maroon: #9b111e;
    --color-maroon-dark: #7f0e18;

    --color-border: rgba(0,0,0,0.09);
}

/* =========================
   BASE
========================= */

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    background: var(--color-bg);
    color: var(--color-text);
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.6;
}

img {
    max-width: 100%;
    height: auto;
}

a {
    color: inherit;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
}

a:hover {
    color: var(--color-green);
}

h1,
h2,
h3 {
    line-height: 1.12;
}

h1,
h2 {
    letter-spacing: -0.035em;
}

h2 {
    color: var(--color-green);
}

/* =========================
   HEADER: WHITE TOP BANNER
========================= */

.abeng-site-header {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: 100%;
    z-index: 20;
    background: #ffffff !important;
    color: #111111 !important;
    border-bottom: 1px solid rgba(0,0,0,0.08) !important;
    padding: 1rem 2rem;
    box-sizing: border-box;
}

.abeng-header-inner {
    max-width: none;
    width: 100%;
    margin: 0;
    gap: 2rem;
}

.abeng-brand {
    margin: 0;
    padding: 0;
}

.abeng-site-title {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -0.055em;
}

.abeng-site-title a {
    color: #111111 !important;
    text-decoration: none;
}

.abeng-site-title a::after {
    content: "365";
    color: #86a92e;
}

.abeng-tagline {
    margin: 0.25rem 0 0;
    color: #555 !important;
    font-size: 0.9rem;
    line-height: 1.1;
}

.abeng-main-nav {
    font-size: 0.95rem;
    font-weight: 500;
}

.abeng-main-nav a,
.abeng-site-header .wp-block-navigation a,
.abeng-site-header .wp-block-site-title a {
    color: #111111 !important;
    text-decoration: none;
}

.abeng-main-nav a:hover,
.abeng-site-header .wp-block-navigation a:hover {
    color: var(--color-maroon) !important;
}

.abeng-site-header .current-menu-item > a,
.abeng-site-header .wp-block-navigation-item.current-menu-item > a,
.abeng-site-header .wp-block-navigation-item__content[aria-current="page"] {
    color: #ffffff !important;
    background: var(--color-maroon);
    padding: 0.45rem 0.75rem;
    border-radius: 4px;
}

.abeng-site-header .wp-block-navigation__responsive-container-open {
    color: #111111;
}

/* =========================
   PAGE STRUCTURE
========================= */

.abeng-main,
.abeng-front-page {
    padding-top: 0 !important;
}

.wp-block-group.alignwide,
.wp-block-columns.alignwide {
    max-width: var(--max-width);
    margin-left: auto;
    margin-right: auto;
}

.wp-block-group.alignfull {
    padding-left: 0;
    padding-right: 0;
}

/* =========================
   JOIN PAGE
========================= */

.abeng-join-page {
    background: var(--color-bg);
}

/* Full-width hero below normal header */

.abeng-join-hero {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top: 0;
    min-height: 88vh !important;
}

.abeng-join-hero .wp-block-cover__image-background {
    object-position: center center;
}

.abeng-join-hero .wp-block-cover__inner-container {
    height: 100%;
    display: flex;
    align-items: flex-end;
}

.abeng-join-hero-inner {
    width: 100%;
    max-width: var(--max-width);
    margin-left: auto;
    margin-right: auto;
    padding: 0 1.5rem 5rem;
}

.abeng-join-title {
    color: #ffffff;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(3.4rem, 7vw, 6.2rem);
    font-weight: 700;
    line-height: 0.95;
    letter-spacing: -0.055em;
    max-width: 720px;
    margin: 0 0 1rem;
    text-align: left;
    text-shadow: 0 3px 16px rgba(0,0,0,0.32);
}

.abeng-join-tagline {
    color: #ffffff;
    font-size: clamp(1.25rem, 2.5vw, 2rem);
    line-height: 1.25;
    max-width: 700px;
    margin: 0;
    text-align: left;
    text-shadow: 0 2px 10px rgba(0,0,0,0.32);
}

.abeng-breadcrumb {
    margin-top: 1rem;
    color: #ffffff;
    font-size: 0.9rem;
}

.abeng-breadcrumb a {
    color: #ffffff;
    text-decoration: none;
}

.abeng-breadcrumb a:hover {
    color: #d8b431;
}

/* Content slightly indented below hero */

.abeng-join-content {
    max-width: var(--max-width);
    margin-left: auto;
    margin-right: auto;
    gap: clamp(2rem, 5vw, 5rem);
    align-items: flex-start;
    padding: var(--space-xl) 1.5rem;
}

.abeng-join-intro {
    font-size: 1.02rem;
}

.abeng-join-intro h2,
.abeng-join-form-wrap h2 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2rem, 3vw, 3rem);
    color: var(--color-green);
    margin-top: 0;
}

.abeng-join-intro h3 {
    color: var(--color-green);
    margin-top: 2rem;
}

.abeng-join-intro p {
    max-width: 38ch;
}

.abeng-join-intro ul {
    padding-left: 1.2rem;
}

.abeng-join-intro li {
    margin-bottom: 0.9rem;
}

.abeng-join-intro .wp-block-separator {
    margin: 2rem 0;
    border-color: #7c9f3a;
}

.abeng-join-note {
    background: var(--color-green-soft);
    border-radius: 8px;
    padding: 1.25rem;
    margin-top: 2rem;
}

.abeng-join-note p {
    margin-top: 0;
}

.abeng-join-form-wrap {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: clamp(1.5rem, 3vw, 2.5rem);
    box-shadow: 0 14px 34px rgba(0,0,0,0.06);
}

/* =========================
   FORMS
========================= */

.acf-form {
    margin-top: 1.25rem;
}

.acf-form .acf-fields {
    border: none;
    background: transparent;
}

.acf-form .acf-field {
    padding: 0;
    margin-bottom: 1.25rem;
    border: 0;
}

.acf-form .acf-label label {
    font-weight: 700;
    color: #111111;
}

.acf-form .description {
    color: var(--color-muted);
    font-size: 0.9rem;
}

.acf-form input[type="text"],
.acf-form input[type="email"],
.acf-form input[type="url"],
.acf-form input[type="number"],
.acf-form textarea,
.acf-form select {
    width: 100%;
    max-width: 100%;
    border: 1px solid #d9d9d9;
    border-radius: 5px;
    padding: 0.75rem 0.85rem;
    font-size: 1rem;
    box-sizing: border-box;
    background: #ffffff;
}

.acf-form textarea {
    min-height: 160px;
}

.acf-form input[type="submit"],
.acf-button {
    background: var(--color-green);
    color: #ffffff;
    border: none;
    border-radius: 5px;
    padding: 0.8rem 1.4rem;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
}

.acf-form input[type="submit"]:hover,
.acf-button:hover {
    background: var(--color-green-dark);
    color: #ffffff;
}

.abeng-join-form-wrap .acf-form input[type="submit"] {
    width: 100%;
    background: var(--color-maroon);
    color: #ffffff;
    border: none;
    border-radius: 5px;
    padding: 1rem 1.25rem;
    font-size: 1.05rem;
    font-weight: 700;
}

.abeng-join-form-wrap .acf-form input[type="submit"]:hover {
    background: var(--color-maroon-dark);
    color: #ffffff;
}

/* =========================
   BUTTONS
========================= */

.wp-block-button__link {
    background: var(--color-green);
    color: #ffffff;
    border: none;
    border-radius: 5px;
    padding: 0.8rem 1.4rem;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
}

.wp-block-button__link:hover {
    background: var(--color-green-dark);
    color: #ffffff;
}

/* =========================
   CARDS / SHARED SYSTEM
========================= */

.abeng-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 10px 24px rgba(0,0,0,0.06);
}

.abeng-card-body {
    padding: 1rem;
}

.abeng-eyebrow,
.abeng-card-kicker {
    color: #7c9f3a;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.abeng-muted {
    color: var(--color-muted);
}

/* =========================
   FOOTER
========================= */

.abeng-site-footer {
    margin-top: 4rem;
    padding: 2rem;
    background: #ffffff;
    border-top: 1px solid var(--color-border);
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 900px) {
    .abeng-site-header {
        padding: 1rem;
    }

    .abeng-header-inner {
        gap: 1rem;
    }

    .abeng-join-content {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .abeng-join-form-wrap {
        padding: 1.25rem;
    }
}

@media (max-width: 700px) {
    .abeng-header-inner {
        flex-direction: column;
        align-items: flex-start;
    }

    .abeng-site-title {
        font-size: 2rem;
    }

    .abeng-tagline {
        display: none;
    }

    .abeng-join-hero {
        min-height: 72vh !important;
    }

    .abeng-join-hero-inner {
        padding-bottom: 3rem;
    }

    .abeng-join-title {
        font-size: 3rem;
    }

    .abeng-join-tagline {
        font-size: 1.25rem;
    }
}

/* HOME CSS WHERE IF GETS FUNKY*/
.abeng-home-hero {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    min-height: 88vh !important;
}

.abeng-home-hero .wp-block-cover__inner-container {
    height: 100%;
    display: flex;
    align-items: flex-end;
}

.abeng-home-hero-inner {
    width: 100%;
    max-width: var(--max-width);
    margin-left: auto;
    margin-right: auto;
    padding: 0 1.5rem 5rem;
}

.abeng-home-title {
    color: #fff;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(3.4rem, 7vw, 6.2rem);
    line-height: 0.95;
    margin: 0 0 1rem;
    text-shadow: 0 3px 16px rgba(0,0,0,0.32);
}

.abeng-home-tagline {
    color: #fff;
    font-size: clamp(1.4rem, 2.8vw, 2.3rem);
    margin: 0 0 1rem;
    text-shadow: 0 2px 10px rgba(0,0,0,0.32);
}

.abeng-home-summary {
    color: #fff;
    max-width: 720px;
    font-size: 1.1rem;
    text-shadow: 0 2px 10px rgba(0,0,0,0.32);
}

.abeng-home-content {
    max-width: var(--max-width);
    margin-left: auto;
    margin-right: auto;
    padding: var(--space-xl) 1.5rem;
}

.abeng-explainer-grid {
    gap: clamp(1.5rem, 4vw, 3rem);
    margin-bottom: var(--space-xl);
}

.abeng-explainer-grid .wp-block-column,
.abeng-home-live-callout,
.abeng-home-subscribe {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 1.5rem;
}

.abeng-home-featured {
    margin-bottom: var(--space-xl);
}

.abeng-home-live-callout {
    margin-bottom: var(--space-xl);
}

.abeng-home-subscribe {
    padding: var(--space-lg);
}
/* ===== HOMEPAGE VERTICAL RHYTHM ===== */

/* Minor links bar — keep tight under hero */
.abeng-home-minor-links {
    margin-top: 0;
    margin-bottom: 1.25rem;
}

/* Lead block — dominant but not floating */
.abeng-home-lead {
    margin-top: 0;
    margin-bottom: 1.75rem;
}

/* Lead image — remove any hidden extra spacing */
.abeng-home-lead img {
    display: block;
}

/* Featured section — visually attached to lead */
.abeng-featured {
    margin-top: 0;
    margin-bottom: 2.25rem;
}

/* Tighten spacing between cards inside featured */
.abeng-featured .abeng-card {
    margin-bottom: 0;
}

/* Article grid — give breathing room after featured */
.abeng-latest-grid {
    margin-top: 0;
    margin-bottom: 2.5rem;
}

/* Normalize Gutenberg block spacing */
.wp-block-group {
    margin-top: 0;
    margin-bottom: 0;
}

/* Remove accidental double spacing */
.abeng-home-lead + .abeng-featured {
    margin-top: 0;
}

/* Optional: subtle divider (editorial polish) */
.abeng-home-lead::after {
    content: "";
    display: block;
    height: 1px;
    background: rgba(0,0,0,0.06);
    margin-top: 1.5rem;
}