/* ==========================================================================
   GLOBAL / COMMON STYLES
   ========================================================================== */
@keyframes borderPulse {
    0% {
        border-color: rgba(243, 112, 34, 1) !important;
        box-shadow: 0 0 0 0 rgba(243, 112, 34, 0.35);
    }

    50% {
        border-color: rgba(243, 112, 34, 0.4) !important;
        box-shadow: 0 0 0 8px rgba(243, 112, 34, 0);
    }

    100% {
        border-color: rgba(243, 112, 34, 1) !important;
        box-shadow: 0 0 0 0 rgba(243, 112, 34, 0.35);
    }
}

/* ==========================================================================
   SECTION 1: HERO SECTION
   ========================================================================== */
.palowise-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, #ebebeb 0%, #e6e6e6 100%);
    height: auto;
    min-height: 720px;
    padding-left: 0;
    display: block;
    background-color: #ebebeb;
    background-image: url('/static/lumos-in/palowise-bg.webp');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.palowise-hero::before,
.palowise-hero::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(20px);
}

.palowise-hero::before {
    width: 520px;
    height: 520px;
    right: -150px;
    top: -120px;
    background: radial-gradient(circle, rgba(243, 112, 34, .16), transparent 62%);
}

.palowise-hero::after {
    width: 380px;
    height: 380px;
    right: 6%;
    bottom: -180px;
    background: radial-gradient(circle, rgba(1, 35, 72, .10), transparent 65%);
}

.palowise-hero-inner {
    position: relative;
    z-index: 2;
    min-height: auto;
    padding: 110px 15px;
}

.palowise-hero-copy span {
    display: inline-block;
    font-family: "barlowcondensed-light";
    font-size: 32px;
    letter-spacing: .02em;
    color: #f37022;
}

.palowise-hero-copy h1 {
    margin: 12px 0 24px;
    color: #012348;
}

.palowise-hero-copy p {
    font-family: "figtree-light";
    color: #4c515a;
    font-size: 20px;
    max-width: 38ch;
    line-height: 1.5;
    margin-bottom: 35px;
}

.palowise-hero-actions {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
    margin-top: 10px;
}

.palowise-hero .button {
    display: inline-block;
    background: linear-gradient(45deg, #f37022, #fbaa4f) !important;
    color: #ffffff !important;
    padding: 10px 24px !important;
    border-radius: 25px !important;
    font-size: 18px !important;
    font-family: "barlow-regular" !important;
    text-transform: uppercase !important;
    box-shadow: 0 10px 24px rgba(243, 112, 34, .18) !important;
    border: 2px solid transparent !important;
    transition: transform .25s ease, box-shadow .25s ease, filter .25s ease !important;
}

.palowise-hero .button:hover {
    background: linear-gradient(45deg, #f37022, #fbaa4f) !important;
    color: #ffffff !important;
    border-color: transparent !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 14px 28px rgba(243, 112, 34, .25) !important;
    filter: saturate(1.05) !important;
    text-decoration: none !important;
}

.palowise-hero-globe-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
}

.globe-3d-shell {
    position: relative;
    width: 100%;
    max-width: 560px;
    aspect-ratio: 1/1;
    perspective: 1400px;
    margin: 0 auto;
}

#globe3d {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

#globe3d canvas {
    width: 100% !important;
    height: 100% !important;
    display: block;
}

.globe-caption {
    position: absolute;
    left: 50%;
    bottom: 8px;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    background: rgba(255, 255, 255, .78);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(1, 35, 72, .08);
    border-radius: 999px;
    padding: 10px 18px;
    box-shadow: 0 10px 28px rgba(1, 35, 72, .08);
    z-index: 2;
}

.globe-caption strong {
    font-family: "barlow-regular";
    font-size: 15px;
    color: #012348;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.globe-caption span {
    font-family: "figtree-light";
    font-size: 13px;
    color: #4c515a;
}


/* ==========================================================================
   SECTION 3: PARTNERSHIP SHOWCASE
   ========================================================================== */
.partnership-section {
    padding: 40px 0;
}

#partnership h2 {
    margin-bottom: 25px;
    font-size: 42px;
    line-height: 1.1;
    font-family: 'barlowcondensed-medium';
    text-transform: uppercase;
    color: #012348;
}

#partnership p {
    margin-bottom: 25px;
    font-family: "figtree-light";
    font-size: 20px;
    line-height: 1.6;
    color: #272a32;
}

#partnership ul {
    padding-left: 0;
    margin-bottom: 30px;
    list-style: none;
}

#partnership li {
    font-family: "figtree-light";
    font-size: 18px;
    margin-bottom: 15px;
    color: #4c515a;
    display: flex;
    align-items: flex-start;
    line-height: 1.6;
}

#partnership li i {
    color: #f37022;
    margin-right: 12px;
    margin-top: 5px;
    font-size: 16px;
    flex-shrink: 0;
}

.partnership-cta {
    text-align: left;
    margin-right: 0;
}

.partnership-cta .button {
    display: inline-block;
    background: linear-gradient(45deg, #f37022, #fbaa4f) !important;
    color: #ffffff !important;
    padding: 10px 24px !important;
    border-radius: 25px !important;
    font-size: 18px !important;
    font-family: "barlow-regular" !important;
    text-transform: uppercase !important;
    box-shadow: 0 10px 24px rgba(243, 112, 34, .18) !important;
    border: 2px solid transparent !important;
    transition: transform .25s ease, box-shadow .25s ease, filter .25s ease !important;
}

.partnership-cta .button:hover {
    background: linear-gradient(45deg, #f37022, #fbaa4f) !important;
    color: #ffffff !important;
    border-color: transparent !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 14px 28px rgba(243, 112, 34, .25) !important;
    filter: saturate(1.05) !important;
    text-decoration: none !important;
}

.partnership-img {
    margin-top: 0;
}

.partnership-img img {
    border-radius: 15px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}


/* ==========================================================================
   SECTION 4: BRAND INTELLIGENCE
   ========================================================================== */
.brand-intelligence-section {
    background-color: #012348;
    padding: 60px 0;
}

/* Stacked header: centered */
.intelligence-header {
    margin-bottom: 40px;
    text-align: center;
}

#business-intelligence .intelligence-header h2 {
    color: #ffffff;
    font-family: 'barlowcondensed-medium';
    line-height: 1.0;
    text-transform: uppercase;
    margin: 0 0 20px 0;
}

#business-intelligence .intelligence-header p {
    color: #ccd6f6;
    font-family: "figtree-light";
    font-size: 18px;
    text-align: center;
    line-height: 1.5;
    margin: 0;
}

/* BI Cards */
#business-intelligence .bi-card {
    background: rgba(255, 255, 255, 0.05);
    padding: 35px 30px;
    border-radius: 15px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    height: 100%;
    transition: background 0.25s ease, border-color 0.25s ease;
}

#business-intelligence .bi-card:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(243, 112, 34, 0.25);
}

#business-intelligence .bi-card h3 {
    color: #f37022;
    font-size: 16px;
    letter-spacing: 0.06em;
    margin-bottom: 16px;
    font-family: 'barlow-regular';
    text-transform: uppercase;
}

#business-intelligence .bi-card p {
    font-family: "figtree-light";
    font-size: 16px;
    color: #ccd6f6;
    line-height: 1.7;
    margin: 0;
}

/* ==========================================================================
   SECTION 5: CAPABILITIES
   ========================================================================== */
.capabilities-section {
    background-color: #ebebeb;
    padding: 60px 0;
}

#capabilities h2 {
    color: #012348;
    font-size: 45px;
}

#capabilities p {
    max-width: 800px;
    margin: 20px auto 0 auto;
    color: #4c515a;
    font-size: 20px;
}

#capabilities .capability-card {
    background: #fff;
    padding: 25px;
    border-radius: 15px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.02);
    height: 100%;
}

#capabilities .capability-card h3 {
    color: #012348;
    text-transform: uppercase;
    font-size: 18px;
    margin-bottom: 10px;
    font-family: 'barlow-regular';
}

#capabilities .capability-card p {
    font-size: 15px;
    color: #4c515a;
}


/* ==========================================================================
   SECTION 6: TARGET SEGMENTS
   ========================================================================== */
#target-segments {
    background: #fff;
    padding: 80px 0;
    margin: 0;
}

#target-segments h2 {
    margin-bottom: 20px;
    font-size: 42px;
    line-height: 1.1;
    font-family: 'barlowcondensed-medium';
    text-transform: uppercase;
    color: #012348;
}

#target-segments p.section-desc {
    max-width: 800px;
    margin: 0 auto 15px auto;
    font-family: "figtree-light";
    font-size: 21px;
    line-height: 1.5;
    color: #4c515a;
}

#target-segments .segment-card {
    border: 1px solid #d5d5d5;
    padding: 45px 30px;
    border-radius: 15px;
    background: #fafafa;
    height: 100%;
}

#target-segments .segment-card .card-icon {
    font-size: 32px;
    color: #f37022;
    margin-bottom: 20px;
}

#target-segments .segment-card h3 {
    color: #012348;
    font-size: 22px;
    font-family: 'barlow-regular';
    text-transform: uppercase;
}

#target-segments .segment-card p {
    font-family: "figtree-light";
    font-size: 16px;
    color: #4c515a;
    margin-top: 15px;
}


/* ==========================================================================
   SECTION 7: FAQ SECTION
   ========================================================================== */
#faq {
    background-color: #f5f5f6;
    padding: 80px 0;
}

#faq h2 {
    color: #012348;
    font-size: 42px;
}

#faq p {
    max-width: 700px;
    margin: 15px auto 0 auto;
    color: #4c515a;
    font-size: 19px;
}


/* ==========================================================================
   RESPONSIVE DESIGN Breakpoints
   ========================================================================== */

/* Large Tablets & Small Laptops (max-width: 1199px) */
@media (max-width: 1199px) {

    /* Section Paddings */
    .partnership-section {
        padding: 60px 0;
    }

    .brand-intelligence-section {
        padding: 60px 0;
    }

    .capabilities-section {
        padding: 60px 0;
    }

    #target-segments {
        padding: 60px 0;
    }

    #faq {
        padding: 60px 0;
    }

    /* Headings */
    #partnership h2,
    #target-segments h2,
    #faq h2 {
        font-size: 36px;
    }

    #capabilities h2 {
        font-size: 38px;
    }

    #business-intelligence .intelligence-header h2 {
        font-size: 46px;
    }

    /* Buttons */
    .palowise-hero .button,
    .partnership-cta .button {
        font-size: 16px !important;
        padding: 10px 22px !important;
    }
}

/* Medium Tablets & iPads (max-width: 991px) */
@media (max-width: 991px) {

    /* Hero */
    .palowise-hero-inner {
        padding: 60px 15px;
    }

    .palowise-hero-copy span {
        font-size: 22px;
    }

    .palowise-hero-copy h1 {
        font-size: 40px;
    }

    .palowise-hero-copy p {
        font-size: 16px;
        max-width: 100%;
    }

    /* Globe */
    .globe-3d-shell {
        max-width: 380px;
    }

    /* Section Paddings */
    .partnership-section {
        padding: 45px 0;
    }

    .brand-intelligence-section {
        padding: 45px 0;
    }

    .capabilities-section {
        padding: 40px 0;
    }

    #target-segments {
        padding: 45px 0;
    }

    #faq {
        padding: 45px 0;
    }

    /* Override Bootstrap mb-5 (48px) on header rows — kills extra space above cards */
    #capabilities .row.mb-5,
    #target-segments .row.mb-5,
    #faq .row.mb-5 {
        margin-bottom: 24px !important;
    }

    /* Headings */
    #partnership h2,
    #target-segments h2,
    #faq h2 {
        font-size: 30px;
    }

    #capabilities h2 {
        font-size: 30px;
    }

    #business-intelligence .intelligence-header h2 {
        font-size: 36px;
    }

    /* Paragraph text */
    #partnership p,
    #business-intelligence .intelligence-header p,
    #capabilities p,
    #target-segments p.section-desc,
    #faq p {
        font-size: 16px;
    }

    /* Partnership list */
    #partnership li {
        font-size: 16px;
    }

    /* Buttons */
    .palowise-hero .button,
    .partnership-cta .button {
        font-size: 14px !important;
        padding: 9px 18px !important;
    }

    /* Cards */
    #business-intelligence .bi-card {
        padding: 24px 20px;
    }

    #capabilities .capability-card {
        padding: 20px;
    }

    #target-segments .segment-card {
        padding: 30px 20px;
    }

    .intelligence-header {
        margin-bottom: 28px;
    }
}

/* Mobile Devices & Large Phones (max-width: 767px) */
@media (max-width: 767px) {

    /* Hero */
    .palowise-hero {
        min-height: auto;
    }

    .palowise-hero-inner {
        padding: 40px 15px;
    }

    .palowise-hero-copy span {
        font-size: 20px;
    }

    .palowise-hero-copy h1 {
        font-size: 28px;
        margin-top: 6px;
        margin-bottom: 12px;
    }

    .palowise-hero-copy p {
        font-size: 14px;
        margin-bottom: 18px;
    }

    /* Hero button */
    .palowise-hero-actions {
        flex-direction: column;
        align-items: flex-start;
    }

    .palowise-hero .button {
        font-size: 13px !important;
        padding: 9px 16px !important;
    }

    /* Globe */
    .globe-3d-shell {
        max-width: 300px;
    }

    .globe-caption {
        bottom: -2px;
        padding: 6px 11px;
    }

    .globe-caption strong {
        font-size: 12px;
    }

    /* Section Paddings */
    .partnership-section {
        padding: 35px 0;
    }

    .brand-intelligence-section {
        padding: 35px 0;
    }

    .capabilities-section {
        padding: 30px 0;
    }

    #target-segments {
        padding: 35px 0;
    }

    #faq {
        padding: 35px 0;
    }

    /* Override Bootstrap mb-5 (48px) on header rows — kills extra space above cards */
    #capabilities .row.mb-5,
    #target-segments .row.mb-5,
    #faq .row.mb-5 {
        margin-bottom: 16px !important;
    }

    /* Headings */
    #partnership h2,
    #capabilities h2,
    #target-segments h2,
    #faq h2 {
        font-size: 24px;
        margin-bottom: 10px;
    }

    #business-intelligence .intelligence-header h2 {
        font-size: 28px;
        margin-bottom: 10px;
    }

    /* Paragraph text */
    #partnership p,
    #business-intelligence .intelligence-header p,
    #capabilities p,
    #target-segments p.section-desc,
    #faq p {
        font-size: 14px;
    }

    /* Partnership list */
    #partnership li {
        font-size: 14px;
    }

    /* Partnership button */
    .partnership-cta .button {
        font-size: 12px !important;
        padding: 9px 14px !important;
        white-space: normal !important;
        text-align: center !important;
        display: inline-block !important;
        line-height: 1.4 !important;
    }

    /* Cards */
    #business-intelligence .bi-card {
        padding: 18px 14px;
    }

    #business-intelligence .bi-card h3 {
        font-size: 12px;
    }

    #capabilities .capability-card {
        padding: 16px;
    }

    #capabilities .capability-card h3 {
        font-size: 14px;
    }

    #target-segments .segment-card {
        padding: 24px 16px;
    }

    #target-segments .segment-card h3 {
        font-size: 17px;
    }

    .intelligence-header {
        margin-bottom: 20px;
    }
}

/* Small Mobile Devices (max-width: 575px) */
@media (max-width: 575px) {

    /* Hero */
    .palowise-hero-inner {
        padding: 20px 12px;
    }

    .palowise-hero-copy span {
        font-size: 16px;
    }

    .palowise-hero-copy h1 {
        font-size: 22px;
    }

    .palowise-hero-copy p {
        font-size: 13px;
    }

    .palowise-hero .button {
        font-size: 12px !important;
        padding: 8px 14px !important;
    }

    /* Globe */
    .globe-3d-shell {
        max-width: 260px;
    }

    /* Section Paddings */
    .partnership-section {
        padding: 25px 0;
    }

    .brand-intelligence-section {
        padding: 25px 0;
    }

    .capabilities-section {
        padding: 20px 0;
    }

    #target-segments {
        padding: 25px 0;
    }

    #faq {
        padding: 25px 0;
    }

    /* Override Bootstrap mb-5 (48px) on header rows — kills extra space above cards */
    #capabilities .row.mb-5,
    #target-segments .row.mb-5,
    #faq .row.mb-5 {
        margin-bottom: 12px !important;
    }

    /* Headings */
    #partnership h2,
    #capabilities h2,
    #target-segments h2,
    #faq h2 {
        font-size: 20px;
    }

    #business-intelligence .intelligence-header h2 {
        font-size: 22px;
    }

    /* Partnership button */
    .partnership-cta .button {
        font-size: 11px !important;
        padding: 8px 12px !important;
    }

    /* Cards */
    #business-intelligence .bi-card {
        padding: 14px 12px;
    }

    #capabilities .capability-card {
        padding: 14px;
    }

    #target-segments .segment-card {
        padding: 20px 14px;
    }

    #business-intelligence .bi-card h3,
    #capabilities .capability-card h3 {
        font-size: 12px;
    }

    #target-segments .segment-card h3 {
        font-size: 15px;
    }

    .intelligence-header {
        margin-bottom: 16px;
    }
}