:root {
    --editorial-ink: #12382d;
    --editorial-forest: #0b2e24;
    --editorial-gold: #c9a55a;
    --editorial-sand: #f4ecde;
    --editorial-paper: #fcfaf5;
    --editorial-line: rgba(18, 56, 45, 0.12);
    --editorial-shadow: 0 24px 70px rgba(10, 36, 28, 0.14);
}

.editorial-page {
    background: linear-gradient(180deg, #f9f4ea 0%, #f4ecde 100%);
    color: var(--editorial-ink);
}

.editorial-page main,
.editorial-page .wrapper {
    background: transparent;
}

.page-contact .wrapper.bg-white {
    background: transparent !important;
}

.page-about .our-story,
.page-about .meet-founder,
.page-about .statement,
.page-about .vision,
.page-why .why-choose,
.page-why .what-apart,
.page-why .build-today,
.page-why .invest,
.page-why .see-difference,
.page-why .book-visit,
.page-contact .contact-details,
.page-contact .contact-location {
    margin: 0;
    text-align: left;
}

.page-about .heading.editorial-heading,
.page-why .heading.editorial-heading,
.page-contact .editorial-heading {
    padding: 0 !important;
    margin: 0 0 2rem !important;
    text-align: left !important;
}

.page-about .editorial-heading,
.page-why .editorial-heading,
.page-contact .editorial-heading {
    max-width: none;
    width: 100%;
}

.page-about .statement .row,
.page-about .vision .row,
.page-why .contact-location .row,
.page-contact .contact-location .row {
    margin-left: 0;
    margin-right: 0;
    display: block;
}

.page-about .statement .row > *,
.page-about .vision .row > *,
.page-contact .contact-location .row > * {
    width: 100%;
    max-width: 100%;
}

.editorial-hero {
    position: relative;
    display: flex;
    align-items: end;
    min-height: calc(100svh - 86px);
    padding: 8.5rem 0 3.5rem;
    color: #fff;
    overflow: clip;
}

.editorial-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(7, 27, 21, 0.88) 0%, rgba(7, 27, 21, 0.68) 42%, rgba(7, 27, 21, 0.3) 68%, rgba(7, 27, 21, 0.16) 100%),
        linear-gradient(180deg, rgba(7, 27, 21, 0.1), rgba(7, 27, 21, 0.5));
}

.editorial-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 180px;
    background: linear-gradient(180deg, rgba(249, 244, 234, 0) 0%, rgba(249, 244, 234, 0.96) 100%);
}

.editorial-hero > .container {
    position: relative;
    z-index: 2;
}

.editorial-hero-about {
    background: url("../images/banner/about/about-top.webp") center center / cover no-repeat;
}

.editorial-hero-why {
    background:
        linear-gradient(0deg, rgba(11, 46, 36, 0.14), rgba(11, 46, 36, 0.14)),
        url("../images/card/why/card01.png") center center / cover no-repeat;
}

.editorial-hero-contact {
    background:
        linear-gradient(0deg, rgba(11, 46, 36, 0.18), rgba(11, 46, 36, 0.18)),
        url("../images/banner/contact.png") center center / cover no-repeat;
}

.editorial-hero-content {
    max-width: 44rem;
}

.editorial-hero-content > * {
    opacity: 0;
    transform: translateY(22px);
    animation: editorial-fade-up 0.8s ease forwards;
}

.editorial-hero-content > *:nth-child(2) {
    animation-delay: 0.08s;
}

.editorial-hero-content > *:nth-child(3) {
    animation-delay: 0.16s;
}

.editorial-hero-content > *:nth-child(4) {
    animation-delay: 0.24s;
}

.editorial-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    margin-bottom: 1rem;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.76rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.editorial-eyebrow::before {
    content: "";
    width: 42px;
    height: 1px;
    background: currentColor;
}

.editorial-title {
    margin-bottom: 1rem;
    font-size: clamp(2.5rem, 4.2vw, 5.1rem);
    line-height: 0.94;
    color: #fff;
}

.editorial-lead {
    max-width: 38rem;
    margin-bottom: 0;
    color: rgba(255, 255, 255, 0.8);
    font-size: clamp(1rem, 1vw + 0.35rem, 1.18rem);
}

.editorial-section {
    position: relative;
    padding: 5.5rem 0;
}

.editorial-section-compact {
    padding: 4.5rem 0;
}

.editorial-section-dark {
    background: var(--editorial-forest);
    color: #fff;
}

.editorial-section-dark p,
.editorial-section-dark li {
    color: rgba(255, 255, 255, 0.76);
}

.editorial-heading {
    max-width: 44rem;
    margin-bottom: 2.5rem;
}

.editorial-heading h1,
.editorial-heading h2,
.editorial-heading h3,
.editorial-heading h4,
.editorial-heading h5 {
    color: inherit;
    margin-top: 0;
}

.editorial-heading p,
.editorial-heading h5 {
    color: rgba(18, 56, 45, 0.74);
}

.editorial-intro-row {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
    gap: 1.5rem 2rem;
    align-items: end;
}

.editorial-intro-row > * {
    margin-bottom: 0;
}

.editorial-intro-copy {
    max-width: 36rem;
    justify-self: end;
}

.editorial-stack-tight {
    position: relative;
    display: grid;
    gap: 2rem;
}

.page-about .statement .editorial-stack-tight {
    overflow: hidden;
    border-radius: 30px;
}

.editorial-body-note {
    max-width: 44rem;
    margin: 0 0 1.5rem;
}

.editorial-section-dark .editorial-heading p,
.editorial-section-dark .editorial-heading h5 {
    color: rgba(255, 255, 255, 0.72);
}

.editorial-grid-2 {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    gap: 2.5rem;
    align-items: stretch;
}

.editorial-grid-2.editorial-grid-balanced {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.editorial-copy {
    display: grid;
    gap: 1rem;
}

.editorial-copy p:last-child {
    margin-bottom: 0;
}

.editorial-image-frame,
.editorial-surface,
.editorial-founders article,
.editorial-contact-card,
.editorial-map-frame,
.editorial-video-frame {
    overflow: hidden;
    border-radius: 28px;
    box-shadow: var(--editorial-shadow);
}

.editorial-image-frame {
    min-height: 100%;
    background: var(--editorial-paper);
}

.editorial-image-frame img,
.editorial-map-frame iframe,
.editorial-video-frame iframe {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.editorial-surface {
    padding: 2rem;
    background: rgba(255, 255, 255, 0.66);
    border: 1px solid rgba(255, 255, 255, 0.45);
    backdrop-filter: blur(14px);
}

.editorial-surface-dark {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.08);
}

.editorial-inline-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--editorial-line);
}

.editorial-inline-metrics strong {
    display: block;
    margin-bottom: 0.2rem;
    font-size: 1.15rem;
    line-height: 1;
}

.editorial-inline-metrics span {
    color: rgba(18, 56, 45, 0.66);
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.editorial-section-dark .editorial-inline-metrics {
    border-top-color: rgba(255, 255, 255, 0.14);
}

.editorial-section-dark .editorial-inline-metrics span {
    color: rgba(255, 255, 255, 0.62);
}

.editorial-founders {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
}

.editorial-founders > *,
.editorial-reasons-grid > *,
.editorial-benefits-grid > * {
    height: 100%;
}

.editorial-founders article {
    height: 100%;
    padding: 0;
    background: #fff;
    border: 1px solid rgba(18, 56, 45, 0.08);
}

.editorial-founders img {
    width: 100%;
    aspect-ratio: 4 / 4.4;
    object-fit: cover;
}

.editorial-founder-copy {
    padding: 1.5rem;
}

.editorial-founders .founder-name {
    margin-bottom: 0.8rem;
}

.editorial-quote-band {
    padding: 3.5rem 0;
}

.editorial-quote-band .state-head,
.editorial-final-cta {
    position: relative;
    overflow: hidden;
    padding: 2.4rem;
    border-radius: 30px;
    background: linear-gradient(135deg, #0b2e24 0%, #134436 55%, #0b2e24 100%);
    color: #fff;
    box-shadow: var(--editorial-shadow);
}

.editorial-quote-band .state-head h3,
.editorial-quote-band .state-head h5,
.editorial-final-cta h3,
.editorial-final-cta p {
    position: relative;
    z-index: 1;
    color: #fff;
}

.editorial-quote-band .state-head h5 {
    max-width: 52rem;
    margin-bottom: 0;
    color: rgba(255, 255, 255, 0.82);
    line-height: 1.6;
}

.editorial-quote-band .gradient-green-bg,
.editorial-final-cta::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top right, rgba(201, 165, 90, 0.24), transparent 28%),
        linear-gradient(120deg, rgba(255, 255, 255, 0.05), transparent 48%);
}

.editorial-reasons-grid,
.editorial-benefits-grid {
    display: grid;
    gap: 1.2rem;
}

.editorial-reasons-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.editorial-benefits-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.editorial-reason-card,
.editorial-benefit {
    height: 100%;
    padding: 1.4rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(18, 56, 45, 0.08);
    box-shadow: var(--editorial-shadow);
}

.editorial-reason-card img,
.editorial-benefit img {
    width: 56px;
    height: 56px;
    object-fit: contain;
    margin-bottom: 1rem;
}

.editorial-reason-card p,
.editorial-benefit p {
    margin-bottom: 0;
}

.page-why .what-apart article.editorial-reason-card {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding: 1.4rem;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(18, 56, 45, 0.08);
    box-shadow: var(--editorial-shadow);
}

.page-why .what-apart article.editorial-reason-card:hover {
    transform: translateY(-4px);
    background: #fff;
}

.page-why .what-apart article.editorial-reason-card p,
.page-why .invest .editorial-benefit p {
    color: var(--editorial-ink);
}

.page-why .what-apart article.editorial-reason-card img,
.page-why .invest .editorial-benefit img {
    width: 56px;
    height: 56px;
    object-fit: contain;
    margin-bottom: 1rem;
}

.page-why .invest .editorial-benefit {
    text-align: left;
}

.page-why .what-apart .main-button {
    width: auto;
}

.page-why .what-apart > .container > p,
.page-why .invest .down {
    padding: 0;
}

.page-why .invest {
    text-align: left;
}

.page-why .invest .editorial-benefits-grid {
    align-items: stretch;
}

.page-why .invest .down {
    max-width: 48rem;
    margin-top: 1.5rem;
}

.page-why .what-apart > .container > p {
    max-width: 44rem;
    margin: 0 0 1.5rem;
    text-align: left !important;
}

.page-why .what-apart .d-flex,
.page-why .invest .d-flex {
    justify-content: flex-start !important;
}

.page-why .why-section-intro {
    margin-bottom: 2.25rem !important;
}

.page-why .why-section-intro h3 {
    max-width: 12ch;
    font-size: clamp(2.15rem, 3.1vw, 3.5rem);
    line-height: 0.98;
    color: var(--editorial-forest);
}

.page-why .why-section-intro p {
    max-width: 34rem;
    font-size: 1.02rem;
    line-height: 1.65;
}

.page-why .why-proof-grid,
.page-why .why-invest-grid {
    gap: 1.35rem;
    margin-bottom: 1.6rem;
}

.page-why .why-proof-card,
.page-why .why-invest-card {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    min-height: 220px;
    padding: 1.55rem 1.6rem;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(18, 56, 45, 0.08);
    box-shadow: 0 18px 44px rgba(10, 36, 28, 0.08);
}

.page-why .why-proof-card {
    justify-content: center;
    align-items: center;
    text-align: center;
    min-height: 180px;
}

.page-why .why-proof-card img {
    width: 54px;
    height: 54px;
    margin-bottom: 0.9rem;
}

.page-why .why-proof-card p,
.page-why .why-invest-card p {
    margin: 0;
    color: var(--editorial-ink);
    font-size: 1rem;
    line-height: 1.45;
}

.page-why .why-invest-card {
    position: relative;
    padding-top: 4.6rem;
    min-height: 190px;
}

.page-why .why-invest-card img {
    position: absolute;
    top: 1.2rem;
    left: 1.6rem;
    width: 52px;
    height: 52px;
    margin: 0;
}

.page-why .why-invest-card .flexi-icon {
    width: 52px;
    height: 52px;
    padding: 0.75rem;
    border-radius: 999px;
    background: var(--editorial-forest);
    display: inline-flex;
    justify-content: center;
    align-items: center;
    margin: 0;
}

.page-why .why-invest-card .flexi-icon:hover {
    transform: none;
    box-shadow: none;
}

.page-why .why-section-note {
    max-width: 48rem;
    margin: 0 0 1.25rem;
    font-size: clamp(1.15rem, 1.4vw, 1.45rem);
    line-height: 1.4;
    color: var(--editorial-forest);
}

.page-why .why-section-actions {
    display: flex;
    justify-content: flex-start;
}

.page-why .why-section-actions .main-button {
    min-width: 0;
}

.page-about .our-story .editorial-grid-2,
.page-about .vision .row,
.page-contact .contact-location .row {
    align-items: stretch;
}

.page-about .statement .state-head,
.page-about .vision .editorial-final-cta,
.page-contact .editorial-map-frame {
    width: 100%;
}

.page-contact .contact-location h4 {
    text-align: left !important;
    padding-bottom: 0.75rem;
}

.page-why .build-today .hori-icon,
.page-why .invest .invest-icon {
    padding: 0;
}

.page-why .build-today .hori-icon img,
.page-why .invest .invest-icon img {
    flex: 0 0 auto;
}

.editorial-list {
    display: grid;
    gap: 0.9rem;
}

.editorial-list-item {
    display: flex;
    align-items: start;
    gap: 0.9rem;
    padding-bottom: 0.9rem;
    border-bottom: 1px solid var(--editorial-line);
}

.editorial-list-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.editorial-list-item img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    margin-top: 0.15rem;
}

.editorial-list-item p {
    margin: 0;
}

.editorial-video-frame,
.editorial-map-frame {
    background: #fff;
}

.editorial-video-frame iframe,
.editorial-map-frame iframe {
    min-height: 420px;
    border: 0;
}

.editorial-final-cta {
    text-align: center;
    padding: 3rem 2rem;
}

.editorial-final-cta p {
    max-width: 42rem;
    margin: 0.8rem auto 1.5rem;
    color: rgba(255, 255, 255, 0.74);
}

.editorial-cta-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.85rem;
}

.editorial-link-button,
.editorial-link-button:hover {
    text-decoration: none;
}

.editorial-contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(360px, 1.05fr);
    gap: 2rem;
    align-items: stretch;
}

.editorial-office-stack {
    display: grid;
    gap: 1.25rem;
}

.editorial-office-card {
    padding: 1.5rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(18, 56, 45, 0.08);
    box-shadow: var(--editorial-shadow);
}

.editorial-office-card h5 {
    margin-bottom: 1rem;
    color: var(--editorial-forest);
}

.editorial-office-card ul {
    display: grid;
    gap: 0.9rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.editorial-office-card li {
    display: flex;
    align-items: start;
    gap: 0.75rem;
    margin: 0;
    color: rgba(18, 56, 45, 0.82);
}

.editorial-office-card li img {
    width: 22px;
    height: 22px;
    object-fit: contain;
    margin-top: 0.15rem;
}

.editorial-contact-card {
    padding: 2rem;
    background: linear-gradient(180deg, rgba(11, 46, 36, 0.96), rgba(18, 68, 54, 0.94));
    color: #fff;
}

.page-contact .contact-form.editorial-contact-card {
    display: block;
    width: 100%;
    min-width: 0;
    visibility: visible;
}

.editorial-contact-card h3,
.editorial-contact-card p,
.editorial-contact-card label {
    color: #fff;
}

.page-contact .editorial-contact-card h3 {
    margin-bottom: 0.5rem;
}

.editorial-contact-card p {
    color: rgba(255, 255, 255, 0.74);
}

.page-contact .editorial-contact-card form {
    display: grid;
    gap: 0.55rem;
    margin-top: 0.75rem;
}

.page-contact .editorial-contact-card label {
    margin-left: 0;
    padding-bottom: 0;
}

.editorial-contact-card .form-control {
    min-height: 52px;
    width: 100% !important;
    padding: 0.85rem 1rem;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    box-shadow: none;
}

.editorial-contact-card .form-control::placeholder {
    color: rgba(255, 255, 255, 0.54);
}

.page-contact .editorial-contact-card .d-flex {
    justify-content: flex-start !important;
}

.editorial-contact-card .contact-btn {
    min-height: 50px;
    padding: 0.85rem 1.5rem;
    border-radius: 999px;
    background: var(--editorial-gold);
    color: #13231c;
}

.editorial-contact-card .contact-btn:hover {
    background: #d8b66d;
}

.page-contact .editorial-contact-card .contact-btn {
    margin-top: 0.5rem;
}

.editorial-contact-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin: 1rem 0 1.4rem;
}

.editorial-contact-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0.65rem 0.9rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.84);
    font-size: 0.84rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.page-contact #contact_swiper,
.page-contact #contact_swiper .swiper-slide {
    width: 100%;
}

.page-contact .editorial-map-frame {
    width: 100%;
}

@keyframes editorial-fade-up {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 1152px) {
    .editorial-hero {
        min-height: calc(92svh - 80px);
        padding: 7.5rem 0 3rem;
    }

    .editorial-title {
        font-size: clamp(2.1rem, 3.8vw, 4.25rem);
    }

    .editorial-section {
        padding: 4.75rem 0;
    }

    .editorial-grid-2,
    .editorial-contact-layout {
        gap: 1.5rem;
    }

    .editorial-reasons-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .editorial-intro-row {
        grid-template-columns: minmax(0, 1fr) minmax(240px, 0.9fr);
    }

    .page-why .why-proof-card,
    .page-why .why-invest-card {
        min-height: 170px;
    }
}

@media (max-width: 991px) {
    .editorial-hero {
        min-height: auto;
        padding: 7rem 0 2.5rem;
    }

    .editorial-grid-2,
    .editorial-grid-2.editorial-grid-balanced,
    .editorial-contact-layout,
    .editorial-founders,
    .editorial-benefits-grid {
        grid-template-columns: 1fr;
    }

    .editorial-inline-metrics {
        grid-template-columns: 1fr;
    }

    .editorial-intro-row {
        grid-template-columns: 1fr;
    }

    .editorial-intro-copy {
        justify-self: start;
    }

    .page-why .why-section-intro h3 {
        max-width: none;
    }

    .editorial-video-frame iframe,
    .editorial-map-frame iframe {
        min-height: 340px;
    }
}

@media (max-width: 767px) {
    .editorial-hero {
        padding: 6.5rem 0 2rem;
    }

    .editorial-title {
        font-size: clamp(1.75rem, 6.6vw, 2.9rem);
        line-height: 1;
    }

    .editorial-section,
    .editorial-section-compact,
    .editorial-quote-band {
        padding: 4rem 0;
    }

    .editorial-surface,
    .editorial-contact-card,
    .editorial-office-card,
    .editorial-founder-copy,
    .editorial-reason-card,
    .editorial-benefit,
    .editorial-final-cta,
    .editorial-quote-band .state-head {
        padding: 1.25rem;
    }

    .editorial-reasons-grid {
        grid-template-columns: 1fr;
    }

    .page-why .why-proof-card,
    .page-why .why-invest-card {
        min-height: auto;
    }

    .page-why .why-invest-card {
        padding-top: 4.1rem;
    }

    .editorial-video-frame iframe,
    .editorial-map-frame iframe {
        min-height: 280px;
    }

    .editorial-contact-meta span {
        width: 100%;
        justify-content: center;
    }
}
