/* =========================================
   11. PERSONAL BRAND SECTION (PIXEL PERFECT)
========================================= */
.personal-brand-section {
    background-color: var(--bg-light);
    /* Stacked background: Wave SVG + Radial Glow */
   background-image: url("../image/Group 355.svg"); /* fixed path + name */
    background-size: cover;
    background-position: center;
    padding: 0px 0;
    overflow: hidden;
    padding-top: 100px;
}

.brand-heading {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(3rem, 4.8vw, 5rem);
    line-height: 1;
    letter-spacing: -2px;
    color: var(--text-dark);
    margin-bottom: 30px;
}

.brand-description {
    font-family: var(--font-nav);
    font-size: 1.1rem;
    line-height: 1.6;
    color: #444;
    max-width: 518px;
    margin-bottom: 40px;
}

/* --- BUTTONS --- */
.brand-cta-group {
    display: flex;
    align-items: center;
    gap: 30px;
}

.btn-orange-solid {
    background-color: var(--brand-orange);
    color: #FFFFFF;
    font-family: var(--font-nav);
    font-weight: 700;
    font-size: 15px;
    padding: 18px 35px;
    border-radius: 0; /* Sharp edges as per Figma */
    text-decoration: none;
    transition: 0.3s ease;
}
.brand-heading .text-orange{
    color: var(--brand-orange);
}
.btn-orange-solid:hover {
    background-color: #000;
    color: #fff;
}

.link-strategy {
    font-family: var(--font-nav);
    font-weight: 800;
    font-size: 15px;
    color: #000;
    text-decoration: none;
    border-bottom: 2px solid #000;
    padding-bottom: 2px;
}

/* --- IMAGE --- */
.central-portrait {
    position: relative;
    z-index: 5;
    max-height: 750px;
    filter: drop-shadow(0 20px 50px rgba(0,0,0,0.1));
}

/* --- GLASS CARDS --- */
.glass-feature-card {
    background: #E6E6E6;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.6);
    padding: 13px 10px;
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.03);
    width: 100%;
}

.feature-list-minimal {
    list-style: none;
    padding: 0;
    margin: 0;
}

.feature-list-minimal li {
    font-family: var(--font-nav);
    font-weight: 500;
    font-size: 15px;
    color: #000;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.feature-list-minimal li:last-child { margin-bottom: 0; }
.sub-target-heading .text-orange {
    color: var(--brand-orange);
}
.feature-list-minimal svg {
    width: 6px;
    height: 10px;
    flex-shrink: 0;
}

/* --- BOTTOM RIGHT TEXT --- */
.corner-target-text .sub-target-heading {
    font-size: 3.3rem;
    margin-bottom: 15px;
    font-weight: 500;
    font-family: var(--font-logo);
}

.sub-target-text-small {
    font-family: var(--font-nav);
    font-size: 0.9rem;
    line-height: 1.6;
    color: #666;
    /* max-width: 320px; */
    font-weight: 700;
}
/* =========================================
   --- RESPONSIVENESS & BACKGROUND FIXES ---
========================================= */

/* Laptops & Medium Screens */
@media (max-width: 1300px) {
    .personal-brand-section { 
        padding: 80px 0; 
        background-position: top center;
        background-size: 130% auto; /* Prevents vertical stretching */
    }
}

/* Tablets (Portrait View) */
@media (max-width: 991px) {
    .personal-brand-section { 
        padding: 60px 0; 
        text-align: center; 
        background-position: top center;
        background-size: 160% auto; /* Prevents the lines from becoming pixelated */
        background-repeat: no-repeat;
    }

    /* Column Alignments */
    .brand-description { 
        margin: 0 auto 30px auto; 
    }

    /* Stack buttons neatly */
    .brand-cta-group { 
        justify-content: center; 
        flex-direction: column; 
        gap: 15px; 
    }

    .btn-orange-solid { 
        width: 100%; 
        max-width: 320px; 
        text-align: center;
    }

    .link-strategy {
        display: inline-block;
        margin-top: 5px;
    }

    /* Central Portrait Scaling */
    .central-portrait { 
        margin: 40px auto; 
        max-height: 450px; 
        width: auto;
    }

    /* Glass Cards Restyling for Tablet */
    .glass-feature-card {
        max-width: 480px;
        margin-left: auto;
        margin-right: auto;
        padding: 15px 20px;
    }

    /* Corner Target Text Styling */
    .corner-target-text { 
        text-align: center; 
        margin-top: 40px !important;
        padding-top: 0 !important;
    }

    .corner-target-text .sub-target-heading {
        font-size: 2.8rem;
    }

    .sub-target-text-small { 
        margin: 0 auto; 
        max-width: 500px;
    }
}

/* Mobile Screens */
@media (max-width: 767px) {
    .personal-brand-section {
        padding: 50px 0;
        background-size: 240% auto; /* Stretches waves wide enough to remain visible on phones */
    }

    .brand-heading {
        font-size: 2.5rem; /* Scales heading down for readability */
        line-height: 1.1;
    }

    .central-portrait { 
        max-height: 350px; /* Keeps the central portrait well-proportioned */
        margin: 30px auto;
    }

    .corner-target-text .sub-target-heading {
        font-size: 2.3rem;
    }

    .glass-feature-card {
        padding: 12px 15px;
    }

    .feature-list-minimal li {
        font-size: 14px;
    }
}

/* =========================================
   12. INVISIBLE SECTION (PROBLEM GRID)
========================================= */
.invisible-section {
    padding: 160px 0;
    background-color: #FFFFFF;
}

.section-main-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.5rem, 4vw, 3.8rem);
    letter-spacing: -1.5px;
    color: var(--text-dark);
}

.problem-card {
    background-color: var(--bg-light); /* #F6F5F3 */
    padding: 60px;
    height: 100%;
    border: 1px solid rgba(0,0,0,0.05);
    transition: transform 0.3s ease;
}

/* The Highlighted Orange Card */
.problem-card.highlighted {
    background-color: var(--brand-orange);
    border: none;
}

/* The Premium Layered Icon Box */
.icon-layer-box {
    width: 45px;
    height: 45px;
    background-color: #000000;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin-bottom: 40px;
}

/* The Gold Offset Shadow */
.icon-layer-box::before {
    content: '';
    position: absolute;
    top: 5px;
    left: 5px;
    width: 100%;
    height: 100%;
    background-color: var(--brand-gold);
    z-index: -1;
}

.problem-title {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #000;
    margin-bottom: 20px;
}

.problem-text {
    font-family: var(--font-nav);
    font-size: 1rem;
    line-height: 1.7;
    color: #444;
    margin: 0;
    max-width: 90%;
}
.problem-textv {
    font-family: var(--font-nav);
    font-size: 1rem;
    line-height: 1.7;
    color: #fff;
    margin: 0;
    max-width: 90%;
}
/* Mobile Adjustments */
@media (max-width: 991px) {
    .problem-card {
        padding: 40px;
    }
}

@media (max-width: 767px) {
    .invisible-section { padding: 60px 0; }
    .problem-text { max-width: 100%; }
}

/* =========================================
   REUSABLE CTA SECTION STYLES
========================================= */
  .cta-section {
    background-image: url('../image/Group 177.png'); /* update path */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 90px 0;
    width: 100%;
    position: relative;
}
.cta-section::before {
    content: "";
    position: absolute;
    inset: 0;

}

.cta-title {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: clamp(1.8rem, 3vw, 2.0rem);
    color: var(--text-dark);
    line-height: 1.3;
    letter-spacing: -0.5px;
    margin: 0;
}
.cta-titlea{
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: clamp(1.8rem, 3vw, 2.0rem);
    color: var(--text-dark);
    line-height: 1.3;
    letter-spacing: -0.5px;
    margin: 0;
}

.btn-cta-dark {
    background-color: #000000;
    color: #FFFFFF;
    font-family: var(--font-nav);
    font-weight: 700;
    font-size: 14px;
    padding: 18px 35px;
    border-radius: 0px; /* Sharp as per Figma */
    text-decoration: none;
    border: 2px solid #000000;
    transition: all 0.3s ease;
    display: inline-block;
}

.btn-cta-dark:hover {
    background-color: transparent;
    color: #000000;
}

/* Responsive adjustment */
@media (max-width: 991px) {
    .cta-section { text-align: center; padding: 60px 0; }
}


/* =========================================
   13. EVERYTHING YOU NEED (SYSTEM LIST)
========================================= */
.system-section {
    padding: 160px 0;
    background-color: var(--bg-light); /* #F6F5F3 */
}

.system-main-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2rem, 3.5vw, 3.2rem);
    letter-spacing: -1.5px;
    margin-bottom: 15px;
}

.system-main-subtitle {
    font-family: var(--font-nav);
    color: var(--text-muted);
    font-size: 1rem;
}

/* Individual Row Styling */
.system-row {
    border-bottom: 1px solid #D1D1D1;
    padding: 60px 0;
    position: relative;
}

.system-row:last-child {
    border-bottom: none;
}

.system-item-title {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.3rem;
    line-height: 1.3;
    margin-bottom: 15px;
    letter-spacing: -0.5px;
}

.system-item-desc {
    font-family: var(--font-nav);
    font-size: 0.9rem;
    color: #666;
    line-height: 1.5;
}

/* Middle Column Bullets */
.system-bullet-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.system-bullet-list li {
    font-family: var(--font-nav);
    font-size: 0.95rem;
    color: #444;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.system-bullet-list li::before {
    content: '';
    width: 4px;
    height: 4px;
    background-color: var(--brand-orange);
    display: inline-block;
    flex-shrink: 0;
}

/* The Gold Large Number */
.system-number {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 4.5rem;
    color: var(--brand-gold);
    line-height: 1;
    opacity: 0.8;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 991px) {
    .system-row { padding: 40px 0; }
    .system-number { font-size: 3rem; }
}

@media (max-width: 767px) {
    .system-section { padding: 80px 0; }
    .system-row { text-align: left; }
    
    .system-number {
        position: absolute;
        top: 20px;
        right: 0;
        font-size: 2.5rem;
    }
    
    .col-lg-6 { margin-top: 30px; }
}

/* =========================================
   14. DARK PRICING SECTION
========================================= */
.pricing-dark-section {
    background-color: #0D0D0B; /* Deep dark background from footer */
    padding: 160px 0;
    color: #FFFFFF;
}

.pricing-dark-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.5rem, 4vw, 3.5rem);
    letter-spacing: -1.5px;
    margin-bottom: 20px;
}

.pricing-dark-subtitle {
    font-family: var(--font-nav);
    color: #A0A0A0;
    font-size: 1.1rem;
}

.pricing-card-dark {
    background-color: transparent;
    border: 1px solid #FFFFFF;
    padding: 50px 40px;
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: all 0.3s ease;
}

.pricing-card-dark:hover {
    border-color: #FFFFFF;
    background-color: rgba(255, 255, 255, 0.02);
    transform: translateY(-5px);
}

/*.pricing-card-dark.highlighted {*/
/*    border-color: rgba(255, 255, 255, 0.4);*/
/*}*/

.plan-title-dark {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.4rem;
    margin-bottom: 10px;
}

.plan-target-dark {
    font-family: var(--font-nav);
    font-size: 0.95rem;
    color: #A0A0A0;
    margin-bottom: 35px;
}

.plan-price-dark {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(1.6rem, 2vw, 2.1rem);
    letter-spacing: -1px;
    margin-bottom: 8px;
}

.plan-billing-dark {
    font-family: var(--font-nav);
    font-size: 0.85rem;
    color: #888;
    margin-bottom: 0;
}

.plan-divider-dark {
    height: 1px;
    background-color: rgba(255, 255, 255, 0.1);
    margin: 40px 0;
}

.plan-list-dark {
    list-style: none;
    padding: 0;
    margin: 0 0 50px 0;
    flex-grow: 1; /* Pushes button to bottom */
}

.plan-list-dark li {
    font-family: var(--font-nav);
    font-size: 0.95rem;
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    gap: 12px;
    color: #E0E0E0;
}

.btn-pricing-outline {
    width: 100%;
    padding: 18px;
    border: 1px solid #FFFFFF;
    color: #FFFFFF;
    text-align: center;
    text-decoration: none;
    font-family: var(--font-nav);
    font-weight: 700;
    font-size: 14px;
    transition: all 0.3s ease;
}

.btn-pricing-outline:hover {
    background-color: #FFFFFF;
    color: #000000;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 991px) {
    .pricing-card-dark { padding: 40px 30px; }
}

@media (max-width: 767px) {
    .pricing-dark-section { padding: 80px 0; }
    .pricing-card-dark { margin-bottom: 20px; }
}
/* =========================================
   15. FINAL JOURNEY SECTION
========================================= */
.final-journey-section {
    background-color: var(--bg-light); /* #F6F5F3 */
    padding: 120px 0;
    width: 100%;
}

.journey-heading {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.5rem, 5vw, 4.5rem);
    line-height: 1.1;
    letter-spacing: -2.5px;
    color: var(--text-dark);
    margin-bottom: 40px;
}

.journey-subtext {
    font-family: var(--font-nav);
    font-size: 1.05rem;
    color: #666;
    margin: 0;
}

/* Button & Link Wrapper */
.journey-cta-wrapper {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 30px;
}

/* Reusing your btn-orange-solid style or adding specific tweaks */
.final-journey-section .btn-orange-solid {
    background-color: var(--brand-orange);
    color: #FFFFFF;
    font-family: var(--font-nav);
    font-weight: 700;
    font-size: 15px;
    padding: 18px 30px;
    border-radius: 0;
    text-decoration: none;
    transition: 0.3s ease;
    white-space: nowrap;
}

.final-journey-section .btn-orange-solid:hover {
    background-color: #000;
}

.link-explore-resources {
    font-family: var(--font-nav);
    font-weight: 800;
    font-size: 15px;
    color: #000;
    text-decoration: none;
    border-bottom: 2px solid var(--brand-orange); /* Matching Figma underline */
    padding-bottom: 3px;
    white-space: nowrap;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 991px) {
    .final-journey-section { padding: 80px 0; }
    
    .journey-cta-wrapper {
        justify-content: flex-start;
        margin-top: 40px;
    }
}

@media (max-width: 575px) {
    .journey-heading {
        letter-spacing: -1.5px;
    }

    .journey-cta-wrapper {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }

    .final-journey-section .btn-orange-solid {
        width: 100%;
        text-align: center;
    }
}


/* =========================================
   16. ZERO TO AUTHORITY SECTION
========================================= */
.zero-authority-section {
    padding: 120px 0;
    background-color: var(--bg-light);
    /* Continuity of the wave pattern and radial glow */
    background-image: url("../image/Group 355.svg"); /* fixed path + name */
    background-size: cover;
    width: 100%;
}

.zero-main-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.5rem, 5vw, 4.8rem);
    line-height: 1.1;
    letter-spacing: -2px;
    color: var(--text-dark);
}
.zero-main-title .text-orange{
    color: var(--brand-orange);
}
.brand-launch-image-wrapper {
    width: 100%;
    overflow: hidden;
    /* Keeps the image looking like the Figma crop */
    box-shadow: 0 30px 60px rgba(0,0,0,0.05);
}

.brand-launch-img {
    width: 100%;
    height: 450px;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.brand-launch-image-wrapper:hover .brand-launch-img {
    transform: scale(1.03);
}

.brand-launch-content-flex {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 40px;
}

.brand-launch-desc {
    font-family: var(--font-nav);
    font-size: 1.1rem;
    line-height: 1.7;
    color: #555;
    margin-bottom: 40px;
    max-width: 400px;
}

.btn-orange-solid-cta {
    background-color: var(--brand-orange);
    color: #FFFFFF;
    font-family: var(--font-nav);
    font-weight: 700;
    font-size: 15px;
    padding: 18px 35px;
    border-radius: 0; /* Sharp corners */
    text-decoration: none;
    display: inline-block;
    transition: 0.3s ease;
    border: 2px solid var(--brand-orange);
}

.btn-orange-solid-cta:hover {
    background-color: transparent;
    color: var(--brand-orange);
}

.decorative-arrow-wrapper {
    padding-top: 10px;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 991px) {
    .zero-authority-section { padding: 80px 0; }
    .brand-launch-img { height: 350px; }
    .brand-launch-content-flex { gap: 20px; }
}

@media (max-width: 767px) {
    .zero-main-title { font-size: 2.2rem; }
    .brand-launch-content-flex { 
        flex-direction: column; 
        align-items: center; 
        text-align: center;
    }
    .brand-launch-desc { max-width: 100%; }
    .decorative-arrow-wrapper {
        margin-top: 30px;
        transform: rotate(0deg); /* Keeps it pointing down */
    }
}
/* =========================================
   17. WHAT YOU PROVIDE SECTION
========================================= */
.provide-section {
    padding: 180px 0;
    background-color: #FFFFFF;
    width: 100%;
}

.provide-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.5rem, 4vw, 3.0rem);
    color: var(--text-dark);
    letter-spacing: -1.5px;
    margin-bottom: 15px;
}

.provide-subtitle {
    font-family: var(--font-nav);
    font-size: 1.1rem;
    color: var(--text-muted);
    margin-bottom: 40px;
    font-weight: 400;
}

/* Custom Bullet List */
.provide-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.provide-list li {
    font-family: var(--font-nav);
    font-weight: 500;
    font-size: 1.05rem;
    color: #444;
    margin-bottom: 20px;
    display: flex;
    align-items: flex-start;
    gap: 15px;
    line-height: 1.4;
}

.chevron-list-icon {
    width: 6px;
    height: 10px;
    flex-shrink: 0;
    margin-top: 7px; /* Perfect optical alignment with text */
}

/* Image Wrapper and Floating Icon */
.provide-image-wrapper {
    position: relative;
    width: 100%;
    border: 1px solid rgba(0,0,0,0.05); /* Subtle frame */
}

.provide-bracket {
    position: absolute;
    top: 25px;
    left: 25px;
    width: 40px;
    height: 40px;
    z-index: 10;
    /* Optional shadow to make it pop off the image */
    filter: drop-shadow(0 2px 10px rgba(0,0,0,0.2));
}

.provide-img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

/* =========================================
   WHAT YOU PROVIDE RESPONSIVE
========================================= */

/* Large Laptop */
@media (max-width: 1199px) {

    .provide-section {
        padding: 100px 0;
    }

    .provide-title {
        font-size: clamp(2.2rem, 4vw, 3rem);
    }
}


/* Tablet */
@media (max-width: 991px) {

    .provide-section {
        padding: 80px 0;
    }

    .provide-title {
        text-align: center;
        font-size: 2.5rem;
        line-height: 1.15;
        margin-bottom: 15px;
    }

    .provide-subtitle {
        text-align: left;
        margin-bottom: 35px;
        font-size: 1rem;
    }

    .provide-list {
        max-width: 650px;
        margin: 0 auto;
    }

    .provide-list li {
        font-size: 1rem;
    }

    .provide-image-wrapper {
        margin-top: 40px;
    }

    .provide-img {
        width: 100%;
        height: 350px;
        object-fit: cover;
    }
}


/* Mobile */
@media (max-width: 767px) {

    .provide-section {
        padding: 60px 0;
    }

    .provide-title {
        font-size: 2rem;
        line-height: 1.15;
        text-align: center;
    }

    .provide-subtitle {
        font-size: 0.95rem;
        text-align: left;
        margin-bottom: 25px;
    }

    .provide-list {
        max-width: 100%;
    }

    .provide-list li {
        font-size: 0.95rem;
        line-height: 1.6;
        margin-bottom: 15px;
        gap: 12px;
    }

    .chevron-list-icon {
        margin-top: 6px;
    }

    .provide-image-wrapper {
        margin-top: 30px;
    }

    .provide-img {
        width: 100%;
        height: 250px;
        object-fit: cover;
    }

    .provide-bracket {
        width: 30px;
        height: 30px;
        top: 15px;
        left: 15px;
    }
}


/* Small Mobile */
@media (max-width: 480px) {

    .provide-section {
        padding: 50px 0;
    }

    .provide-title {
        font-size: 1.7rem;
    }

    .provide-subtitle {
        font-size: 0.9rem;
    }

    .provide-list li {
        font-size: 0.9rem;
    }

    .provide-img {
        height: 220px;
    }

    .provide-bracket {
        width: 25px;
        height: 25px;
        top: 12px;
        left: 12px;
    }
}
/* =========================================
   19. YOUR BRAND FULLY BUILT SECTION
========================================= */
.fully-built-section {
    padding: 160px 0;
    background-color: var(--bg-light); /* #F6F5F3 */
    width: 100%;
}

.built-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.2rem, 3.5vw, 3.0rem);
    letter-spacing: -1.5px;
    margin-bottom: 10px;
    color: var(--text-dark);
}

.built-subtitle {
    font-family: var(--font-nav);
    font-size: 1rem;
    color: var(--text-muted);
    text-transform: capitalize;
}

/* Individual Row Item */
.built-item-row {
    border-bottom: 1px solid #D1D1D1;
    padding: 45px 0;
    transition: background-color 0.3s ease;
}

.built-item-row:hover {
    background-color: rgba(0,0,0,0.01);
}

/* Three Column Grid Logic */
.built-grid {
    display: grid;
    grid-template-columns: 4fr 5fr 1fr; /* Title | Detail | Number */
    align-items: center;
}

.built-item-name {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.25rem;
    margin: 0;
    color: #000;
    line-height: 1.3;
}

.built-item-detail {
    font-family: var(--font-nav);
    font-size: 0.95rem;
    color: #777;
    margin: 0;
    text-align: left;
}

.built-num {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 4rem;
    color: var(--brand-gold);
    line-height: 1;
    display: block;
    text-align: right;
    opacity: 0.9;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 1100px) {
    .built-grid { grid-template-columns: 1fr 1fr 100px; }
    .built-item-detail { text-align: left; padding-left: 20px; }
}

@media (max-width: 767px) {
    .fully-built-section { padding: 80px 0; }
    
    .built-grid {
        grid-template-columns: 1fr 80px; /* Number stays right, text stacks left */
    }

    .built-col-left { grid-column: 1 / 2; }
    .built-col-center { 
        grid-column: 1 / 2; 
        margin-top: 10px;
    }
    .built-item-detail { text-align: left; padding-left: 0; }
    
    .built-col-right {
        grid-column: 2 / 3;
        grid-row: 1 / 3;
        display: flex;
        align-items: center;
        justify-content: flex-end;
    }
    
    .built-num { font-size: 2.8rem; }
    .built-item-name { font-size: 1.1rem; }
}

/* =========================================
   20. FOUR STEPS PROCESS SECTION
========================================= */
.four-steps-section {
    padding: 160px 0;
    background-color: #FFFFFF;
    width: 100%;
}

.process-image-frame {
    width: 100%;
    height: 100%;
    min-height: 550px;
    overflow: hidden;
}

.process-main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.process-main-title {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: clamp(2rem, 3.5vw, 2.8rem);
    color: var(--text-dark);
    margin: 0;
    letter-spacing: -1px;
}

.btn-black-solid-small {
    background-color: #0d0d0b;
    color: #fff;
    padding: 12px 40px;
    font-family: var(--font-nav);
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    border-radius: 0;
    transition: 0.3s ease;
}

.btn-black-solid-small:hover {
    background-color: var(--brand-orange);
}

/* Individual Step Rows */
.process-step-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 35px 0;
    border-bottom: 1px solid #EAEAEA;
    cursor: pointer;
    transition: all 0.3s ease;
}

.process-step-row:first-child {
    border-top: 1px solid #EAEAEA;
}

.step-text-content {
    padding-right: 30px;
}

.step-heading {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.4rem;
    color: #000;
    margin-bottom: 10px;
    letter-spacing: -0.5px;
}

.step-description {
    font-family: var(--font-nav);
    font-size: 0.95rem;
    color: #666;
    line-height: 1.6;
    margin: 0;
    max-width: 500px;
}

/* Orange Arrow Circle */
.step-icon-circle {
    width: 56px;
    height: 56px;
    background-color: var(--brand-orange);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.step-icon-circle svg {
    width: 24px;
    height: 24px;
}

/* PRO HOVER INTERACTION */
.process-step-row:hover .step-icon-circle {
    transform: translateX(8px) scale(1.05);
    background-color: #000; /* Subtle color change on hover */
}

.process-step-row:hover .step-heading {
    color: var(--brand-orange);
}

/* --- RESPONSIVENESS --- */
@media (max-width: 991px) {
    .four-steps-section { padding: 80px 0; }
    .process-image-frame { min-height: 400px; margin-bottom: 40px; }
    .process-header-flex { flex-direction: column; align-items: flex-start !important; gap: 20px; }
}

@media (max-width: 767px) {
    .step-heading { font-size: 1.2rem; }
    .step-icon-circle { width: 45px; height: 45px; }
    .step-icon-circle svg { width: 18px; height: 18px; }
}

/* =========================================
   21. YOUR TRANSFORMATION SECTION
========================================= */
.global-containera {
    width: 100%;
    padding-right: 5%;
}
.global-containeraa{

    width: 90%;
    padding-left: 9%;
    padding-right: 0%;

}
.global-containeraar{

    width: 90%;
    padding-left: 17%;
    padding-right: 0%;

}
.global-containern {
    width: 75%;
    padding-left: 23%;
    padding-right: 0%;
}
.transformation-section {
    padding: 160px 0;
    background-color: #F6F5F3;
    width: 100%;
}

.transformation-main-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.2rem, 3.5vw, 3.2rem);
    color: var(--text-dark);
    letter-spacing: -1px;
}

.transform-card {
    background-color: var(--bg-light); /* #F6F5F3 */
    border: 1px solid #000000;
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.transform-card-content {
    padding: 50px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.transform-card-title {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.5rem;
    text-transform: uppercase;
    color: #000;
    letter-spacing: -0.5px;
    margin: 0;
}

.transform-img-box {
    width: 100%;
    height: 250px; /* Precise height for landscape crop */
    overflow: hidden;
}

.transform-img-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}

.transform-card:hover .transform-img-box img {
    transform: scale(1.05);
}

.transform-bracket {
    width: 32px;
    height: 32px;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 991px) {
    .transformation-section { padding: 80px 0; }
    .transform-card-content { padding: 35px; }
    .transform-img-box { height: 200px; }
}

@media (max-width: 767px) {
    .transform-card-title { font-size: 1.2rem; }
    /* Stacked cards on mobile */
    .mt-auto { margin-top: 25px !important; }
}

/* =========================================
   22. SINGLE PRICING SECTION
========================================= */
.single-pricing-section {
    padding: 120px 0;
    background-color: #FFFFFF;
    width: 100%;
}

.pricing-main-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(3rem, 5vw, 4.5rem);
    color: var(--text-dark);
    margin-bottom: 25px;
    letter-spacing: -2px;
}

.pricing-main-desc {
    font-family: var(--font-nav);
    font-size: 1.05rem;
    line-height: 1.7;
    color: #555;
    max-width: 450px;
}

/* Pricing Card Styling */
.pricing-action-card {
    border: 1px solid #D1D1D1;
    padding: 80px;
    position: relative;
    background-color: #FFFFFF;
    transition: box-shadow 0.4s ease;
}
.pricing-action-cardtp {
    border: 1px solid #D1D1D1;
    padding: 80px;
    position: relative;
    background-color: var(--bg-light);
    transition: box-shadow 0.4s ease;
}
.pricing-action-card:hover {
    box-shadow: 0 20px 50px rgba(0,0,0,0.04);
}

.pricing-card-bracket {
    position: absolute;
    top: 40px;
    left: 40px;
    width: 32px;
    height: 32px;
}

.pricing-card-body {
    position: relative;
    z-index: 2;
}

.price-value {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.2rem, 4vw, 3.8rem);
    color: #000;
    margin-bottom: 15px;
    letter-spacing: -1.5px;
}

.price-details {
    font-family: var(--font-nav);
    font-size: 1rem;
    color: #777;
    font-weight: 400;
    margin: 0;
}

/* Reusing your btn-orange-solid but ensuring sharp corners */
.single-pricing-section .btn-orange-solid-cta {
    background-color: var(--brand-orange);
    color: #FFFFFF;
    font-family: var(--font-nav);
    font-weight: 700;
    font-size: 15px;
    padding: 20px 45px;
    border-radius: 0;
    text-decoration: none;
    display: inline-block;
    transition: 0.3s ease;
    border: 2px solid var(--brand-orange);
}

.single-pricing-section .btn-orange-solid-cta:hover {
    background-color: #000;
    border-color: #000;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 1200px) {
    .pricing-action-card { padding: 60px; }
}

@media (max-width: 991px) {
    .single-pricing-section { padding: 80px 0; }
    .pricing-main-title { text-align: center; }
    .pricing-main-desc { text-align: center; margin: 0 auto; }
    .pricing-action-card { margin-top: 40px; text-align: center; }
    .pricing-card-bracket { left: 50%; transform: translateX(-50%); top: 20px; }
}

@media (max-width: 575px) {
    .pricing-action-card { padding: 40px 20px; }
    .price-value { font-size: 1.8rem; }
    .pricing-main-title { font-size: 2.5rem; }
}


/* =========================================
   23. EXPERTISE SECTION (ONGOING GROWTH)
========================================= */
.expertise-section {
    padding: 120px 0;
    background-color: var(--bg-light);
    /* Continuity of the wave pattern and radial glow */
     background-image: url(../image/Group 355.svg);
    background-size: cover;
    width: 100%;
    background-position: center;
    overflow: hidden;
}

.expertise-sectiontg {
    background-color: var(--bg-light);
    /* Stacked background: Wave SVG + Radial Glow */
   background-image: url("../image/Group 208.svg"); /* fixed path + name */
    background-size: cover;
    background-position: center;
    /*padding: 100px 0;*/
    overflow: hidden;
    padding-top: 120px;
}
.expertise-title .text-orange{
    color: var(--brand-orange);
}
.global-containertg {
    width: 100%;
   
    padding-right: 5%;
}
.expertise-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.5rem, 4.5vw, 4.9rem);
    line-height: 1.1;
    letter-spacing: -2px;
    color: var(--text-dark);
    /*margin-bottom: 50px;*/
}
.btn-orange-solid-ctagg {
    background-color: var(--brand-orange);
    color: #FFFFFF;
    font-family: var(--font-nav);
    font-weight: 700; 
    font-size: 15px;
    padding: 18px 35px;
    border-radius: 0;
    text-decoration: none;
    display: inline-block;
    transition: 0.3s ease;
    border: 2px solid var(--brand-orange);
    margin-bottom: 73px;
}
.outcome-cardcy {
    background: #F6F5F3;
    padding: 50px 30px;
    height: 100%;
    border: 1px solid rgba(0, 0, 0, 0.03);
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.authority-innerwy {
    max-width: 1500px;
    margin: 0 auto;
    padding: 0 20px;
}
.provide-titlege {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.5rem, 4vw, 3.0rem);
    color: var(--text-dark);
    letter-spacing: -1.5px;
    margin-bottom: 15px;
}
.problem-card.highlightedmr {
    background-color: #DFBB6F;
    border: none;
}
.expertise-image-wrapper {
    width: 100%;
    overflow: hidden;
    box-shadow: 0 30px 60px rgba(0,0,0,0.05);
}

.expertise-img {
    width: 100%;
    height: 504px; /* Matching the previous section's height */
    object-fit: cover;
    display: block;
}

.expertise-bottom-flex {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 30px;
}

.expertise-desc {
    font-family: var(--font-nav);
    font-size: 1.2rem;
    line-height: 1.7;
    color: #555;
    margin-bottom: 21px;
    max-width: 820px;
}

/* Arrow Animation */
.expertise-arrow-box svg {
    animation: bounceDown 3s infinite;
}

@keyframes bounceDown {
    0%, 20%, 50%, 80%, 100% {transform: translateY(0);}
    40% {transform: translateY(-10px);}
    60% {transform: translateY(-5px);}
}

/* --- RESPONSIVENESS --- */
/* =========================================
   --- RESPONSIVENESS (EXPERTISE SECTION) ---
========================================= */

/* Tablets & Medium Screens */
@media (max-width: 991px) {
    .expertise-sectiontg { 
        padding: 80px 0; 
        padding-top: 80px;
        background-position: top center;
        background-size: 160% auto; 
        background-repeat: no-repeat;
    }

    .global-containertg {
        padding-left: 20px;
        padding-right: 20px;
    }

    /* Target the image which is now at the bottom */
    .expertise-img { 
        height: 350px; 
        margin-top: 20px; /* Space above image now that text sits on top */
    }

    .expertise-title { 
        font-size: 2.8rem;
        margin-bottom: 25px; 
        text-align: center;
    }

    .expertise-content-wrapper {
        text-align: center;
    }

    .expertise-desc {
        margin-left: auto;
        margin-right: auto;
    }

    .btn-orange-solid-ctagg {
        margin-bottom: 30px; 
    }
}

/* Mobile Screens */
@media (max-width: 767px) {
    .expertise-sectiontg {
        padding: 50px 0;
        padding-top: 60px;
        background-size: 260% auto; 
    }

    .expertise-title { 
        font-size: 2.1rem; 
    }

    .expertise-img {
        height: 260px;
        margin-top: 15px;
    }

    .expertise-bottom-flex { 
        flex-direction: column; 
        align-items: center; 
        text-align: center;
        gap: 15px;
    }

    .expertise-desc { 
        max-width: 100%; 
        font-size: 1.05rem;
    }

    .btn-orange-solid-ctagg {
        width: 100%;
        max-width: 320px;
        text-align: center;
        margin-bottom: 10px; 
    }

    .expertise-arrow-box { 
        margin-top: 10px; 
    }

    .expertise-arrow-box svg {
        width: 45px;
        height: auto;
    }
}
/* =========================================
   24. ONGOING SYSTEM SECTION
========================================= */
.ongoing-system-section {
    padding: 160px 0;
    background-color: var(--bg-light); /* #F6F5F3 */
    width: 100%;
}

.ongoing-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.2rem, 4vw, 3.0rem);
    letter-spacing: -1.5px;
    margin-bottom: 15px;
}

.ongoing-subtitle {
    font-family: var(--font-nav);
    color: var(--text-muted);
    font-size: 1.1rem;
}

.ongoing-card {
    padding: 50px;
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* Card Themes */
.dark-card {
    background-color: #0D0D0B;
    color: #FFFFFF;
}

.light-card {
    background-color: #FFFFFF;
    border: 1px solid #000000;
    color: #000000;
}

.ongoing-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px rgba(0,0,0,0.1);
}

.period-label {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.6rem;
    letter-spacing: 0.5px;
    margin-bottom: 25px;
}

.card-divider {
    height: 1px;
    background-color: rgba(255, 255, 255, 0.1);
    margin-bottom: 40px;
}

.light-card .card-divider {
    background-color: rgba(0, 0, 0, 0.1);
}

.ongoing-list {
    list-style: none;
    padding: 0;
    margin: 0 0 50px 0;
}

.ongoing-list li {
    font-family: var(--font-nav);
    font-size: 1rem;
    margin-bottom: 20px;
    display: flex;
    align-items: flex-start;
    gap: 15px;
    line-height: 1.5;
    color: #E0E0E0;
}

.ongoing-list.dark-text li {
    color: #444;
}

.ongoing-list .list-arrow {
    width: 8px;
    height: auto;
    margin-top: 7px;
    flex-shrink: 0;
}

/* --- RESPONSIVENESS --- */
/* =========================================
   --- RESPONSIVENESS (ONGOING SYSTEM) ---
========================================= */

@media (max-width: 991px) {
    .ongoing-system-section { 
        padding: 80px 0; 
    }
    
    .ongoing-card { 
        padding: 40px 30px; 
    }
}

@media (max-width: 767px) {
    .ongoing-system-section {
        padding: 60px 0;
    }

    /* Standardizes container width and padding for small phone screens */
    .global-containern {
        width: 100%;
        padding-left: 20px;
        padding-right: 20px;
        margin-left: auto;
        margin-right: auto;
    }

    .system-header {
        margin-bottom: 30px;
    }

    .ongoing-title { 
        font-size: 2.0rem; 
        line-height: 1.2;
        margin-bottom: 12px;
    }

    .ongoing-subtitle {
        font-size: 0.95rem;
        line-height: 1.5;
        padding: 0 10px;
    }

    /* Compresses card padding and visual elements for mobile touchpoints */
    .ongoing-card { 
        padding: 30px 20px; 
        margin-bottom: 10px; /* Space between stacked columns */
    }

    .period-label {
        font-size: 1.35rem;
        margin-bottom: 15px;
    }

    .card-divider {
        margin-bottom: 25px;
    }

    .ongoing-list {
        margin-bottom: 35px; /* Brings call-to-action button slightly closer */
    }

    .ongoing-list li {
        font-size: 0.95rem;
        margin-bottom: 16px;
        gap: 10px;
        line-height: 1.4;
    }

    /* Tones down hover translation on mobile to avoid quirky scrolling behaviors on tap */
    .ongoing-card:hover {
        transform: translateY(-4px);
    }
}
/* =========================================
   25. SECONDARY PRICING SECTION
========================================= */
.secondary-pricing-section {
    padding: 120px 0;
    background-color: var(--bg-light); /* #F6F5F3 */
    width: 100%;
}

.secondary-pricing-sectionyb {
    padding: 120px 0;
    background-color: #fff;
    width: 100%;
}
.secondary-pricing-sectionym {
    padding: 120px 0;
    background-color: var(--bg-light);
    width: 100%;
}
.secondary-pricing-sectiony {
    padding: 120px 0;
    background-color: var(--bg-light);
    width: 100%;
}

.pricing-secondary-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(3rem, 5vw, 4.5rem);
    color: var(--text-dark);
    margin-bottom: 25px;
    letter-spacing: -2px;
}

.pricing-secondary-desc {
    font-family: var(--font-nav);
    font-size: 1.05rem;
    line-height: 1.7;
    color: #555;
    max-width: 450px;
}

/* Pricing Card Box */
.pricing-card-box {
    border: 1px solid #D1D1D1;
    padding: 80px;
    position: relative;
    background-color: #fff;
    transition: all 0.4s ease;
}

.pricing-card-box:hover {
    background-color: #FFFFFF;
    box-shadow: 0 20px 50px rgba(0,0,0,0.05);
    border-color: #FFFFFF;
}

.pricing-box-bracket {
    position: absolute;
    top: 40px;
    left: 40px;
    width: 32px;
    height: 32px;
}

.price-range-text {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.2rem, 3vw, 3.8rem);
    color: #000;
    margin-bottom: 15px;
    letter-spacing: -1.5px;
}

.price-sub-details {
    font-family: var(--font-nav);
    font-size: 1rem;
    color: #777;
    font-weight: 400;
    margin: 0;
}

/* Specific button override - forces left alignment on desktop/laptop */
.secondary-pricing-sectiony .btn-orange-solid-cta {
    display: inline-block !important;
    margin: 0 !important; /* Resets global centered auto margins */
    text-align: left;
}
.secondary-pricing-section .btn-orange-solid-cta {
    display: inline-block !important;
    margin: 0 !important; /* Resets global centered auto margins */
    text-align: left;
}
/* Specific button override - forces left alignment on desktop/laptop */
.secondary-pricing-sectionym .btn-orange-solid-cta {
    display: inline-block !important;
    margin: 0 !important; /* Resets global centered auto margins */
    text-align: left;
}
.outcome-cardn {
    background: #F6F5F3;
    padding: 50px 30px;
    height: 100%;
    border: 1px solid rgba(0, 0, 0, 0.03);
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
/* --- RESPONSIVENESS --- */


@media (max-width: 1200px) {
    .pricing-card-box { padding: 60px; }
}

@media (max-width: 991px) {
    .secondary-pricing-sectiony { padding: 80px 0; }
    .secondary-pricing-sectiony .pricing-secondary-title { text-align: center; }
    .secondary-pricing-sectiony .pricing-secondary-desc { text-align: center; margin: 0 auto; }
    .secondary-pricing-sectiony .pricing-card-box { margin-top: 40px; text-align: center; }
    .secondary-pricing-sectiony .pricing-box-bracket { left: 50%; transform: translateX(-50%); top: 15px; }

    /* Centers the button on tablet screen widths */
    .secondary-pricing-sectiony .btn-orange-solid-cta {
        display: inline-block !important;
        margin: 0 auto !important;
    }
    
     .secondary-pricing-section { padding: 80px 0; }
    .secondary-pricing-section .pricing-secondary-title { text-align: center; }
    .secondary-pricing-section .pricing-secondary-desc { text-align: center; margin: 0 auto; }
    .secondary-pricing-section .pricing-card-box { margin-top: 40px; text-align: center; }
    .secondary-pricing-section .pricing-box-bracket { left: 50%; transform: translateX(-50%); top: 15px; }

    /* Centers the button on tablet screen widths */
    .secondary-pricing-section .btn-orange-solid-cta {
        display: inline-block !important;
        margin: 0 auto !important;
    }
}
@media (max-width: 575px) {
    .secondary-pricing-sectiony .pricing-card-box { padding: 40px 20px; }
    .secondary-pricing-sectiony .price-range-text { font-size: 1.6rem; margin-top: 20px; }
    .secondary-pricing-sectiony .pricing-secondary-title { font-size: 2.5rem; }

    /* Converts the button to block layout on mobile phone screens */
    .secondary-pricing-sectiony .btn-orange-solid-cta {
        display: block !important;
        width: 100% !important;
        max-width: 320px;
        margin: 0 auto !important;
        text-align: center;
        box-sizing: border-box;
        padding: 16px 20px;
    }
    
     .secondary-pricing-section .pricing-card-box { padding: 40px 20px; }
    .secondary-pricing-section .price-range-text { font-size: 1.6rem; margin-top: 20px; }
    .secondary-pricing-section .pricing-secondary-title { font-size: 2.5rem; }

    /* Converts the button to block layout on mobile phone screens */
    .secondary-pricing-section .btn-orange-solid-cta {
        display: block !important;
        width: 100% !important;
        max-width: 320px;
        margin: 0 auto !important;
        text-align: center;
        box-sizing: border-box;
        padding: 16px 20px;
    }
}
@media (max-width: 991px) {
    /* Fixed class selector typos by adding "ym" suffix */
    .secondary-pricing-sectionym { padding: 80px 0; }
    .pricing-secondary-title { text-align: center; }
    .pricing-secondary-desc { text-align: center; margin: 0 auto; }
    .pricing-card-box { margin-top: 40px; text-align: center; }
    .pricing-box-bracket { left: 50%; transform: translateX(-50%); top: 15px; }

    /* Centers the button on tablet screen widths */
    .secondary-pricing-sectionym .btn-orange-solid-cta {
        display: inline-block !important;
        margin: 0 auto !important;
    }
}

@media (max-width: 575px) {
    .pricing-card-box { padding: 40px 20px; }
    .price-range-text { font-size: 1.8rem; margin-top: 20px; }
    .pricing-secondary-title { font-size: 2.5rem; }

    /* Converts the button to block layout on mobile phone screens */
    .secondary-pricing-sectionym .btn-orange-solid-cta {
        display: block !important;
        width: 100% !important;
        max-width: 320px;
        margin: 0 auto !important;
        text-align: center;
        box-sizing: border-box;
        padding: 16px 20px;
    }
}

/* =========================================
   26. FIRM AUTHORITY SECTION
========================================= */
.firm-authority-section {
    position: relative;
     width: 100%;
    /*padding: 120px 0;*/
     background: var(--bg-light);
    background-image: url("../image/Group 208.svg"); /* fixed path + name */
      background-size: cover;
    background-position: center;
    overflow: hidden;
}
.firm-main-title .text-orange {
    color: var(--brand-orange);
}
.firm-main-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(3rem, 4vw, 4.8rem);
    line-height: 1;
    letter-spacing: -2.5px;
    color: var(--text-dark);
    margin-bottom: 30px;
}

.firm-main-desc {
    font-family: var(--font-nav);
    font-size: 1.1rem;
    line-height: 1.7;
    color: #444;
    max-width: 520px;
}

/* --- THE VISUAL COMPOSITION --- */
.firm-visual-composition {
    position: relative;
    padding: 40px;
}

.firm-base-card {
    background-color: #D6D6D4; /* Light gray base from Figma */
    border-radius: 30px;
    padding: 50px 30px 0 30px;
    position: relative;
    min-height: 550px;
    display: flex;
    flex-direction: column;
}

.firm-label {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: 2.2rem;
    margin-bottom: 40px;
    text-align: center;
}

.firm-team-img-wrapper {
    margin-top: auto;
    border-radius: 20px 20px 0 0;
    overflow: hidden;
    position: relative;
}

.firm-team-img {
    width: 90%;
    height: 82vh;
    /*object-fit: cover;*/
}

/* Overlays */
.firm-social-float {
    position: absolute;
    left: -20px;
    bottom: 50px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    z-index: 20;
}

.firm-social-float a {
    width: 45px;
    height: 45px;
    background-color: var(--brand-orange);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    transition: transform 0.3s ease;
}

.firm-social-float a:hover { transform: scale(1.1); }
.firm-social-float svg { width: 20px; height: 20px; }

.firm-legal-badge {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 50px;
    height: 50px;
    background-color: var(--brand-orange);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 20;
}

/* Glass Feature Cards */
.firm-glass-wrapper {
    position: absolute;
    right: -30px;
    top: 50%;
    transform: translateY(-50%);
    width: 280px;
    z-index: 30;
}

.firm-glass-card {
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.8);
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.minimal-bullets {
    list-style: none;
    padding: 0; margin: 0;
}

.minimal-bullets li {
    font-family: var(--font-nav);
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #333;
}

.minimal-bullets li:last-child { margin-bottom: 0; }
.minimal-bullets svg { width: 5px; height: 8px; flex-shrink: 0; }

/* --- RESPONSIVENESS --- */
@media (max-width: 1200px) {
    .firm-glass-wrapper { width: 220px; right: 0; }
}

@media (max-width: 991px) {
        .firm-authority-section {
        padding: 80px 0;
        text-align: center;
        background-size: 240% auto;
        background-position: top center;
        background-repeat: no-repeat;
    }
    .firm-main-desc { margin: 0 auto; }
    .firm-visual-composition { margin-top: 50px; padding: 0; }
    .firm-glass-wrapper { position: relative; width: 100%; right: 0; top: 0; transform: none; margin-top: 30px; }
}

@media (max-width: 767px) {
    .firm-main-title { font-size: 2.5rem; letter-spacing: -1.5px; }
    .firm-base-card { min-height: 400px; padding-top: 30px; }
    .firm-social-float { left: 10px; bottom: 10px; }
}

/* =========================================
   27. BUILT FOR AMBITIOUS FIRMS
========================================= */
.ambitious-firms-section {
    padding: 140px 0;
    background-color: #FFFFFF;
    width: 100%;
}

.ambitious-title {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: clamp(2rem, 3.5vw, 3rem);
    color: var(--text-dark);
    letter-spacing: -1.5px;
    margin-bottom: 50px;
}

.firms-tag-container {
    display: flex;
    flex-direction: column;
    gap: 15px; /* Spacing between rows */
    align-items: center;
}

.firms-tag-row {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 15px; /* Spacing between boxes */
}

.firm-orange-tag {
    background-color: var(--brand-orange);
    color: #FFFFFF;
    font-family: var(--font-nav);
    font-weight: 500;
    font-size: 15px;
    padding: 18px 35px;
    position: relative;
    border-radius: 0; /* Sharp corners per Figma */
    transition: all 0.3s ease;
    cursor: default;
    white-space: nowrap;
}

.firm-orange-tag:hover {
    background-color: #000000;
    transform: translateY(-3px);
}

/* White Bracket in top-left */
.tag-bracket-white {
    position: absolute;
    top: 10px;
    left: 10px;
    width: 12px;
    height: 12px;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 991px) {
    .ambitious-firms-section { padding: 70px 0; }
    .firm-orange-tag { padding: 15px 25px; font-size: 14px; }
}

@media (max-width: 767px) {
    .firms-tag-row {
        flex-direction: column;
        width: 100%;
        align-items: center;
    }
    .firm-orange-tag {
        width: 100%;
        max-width: 350px;
        text-align: center;
        white-space: normal; /* Allow wrap on mobile */
    }
}
/* =========================================
   28. ENGINES PRICING SECTION
========================================= */
.engines-pricing-section {
    padding: 160px 0;
    background-color: #0D0D0B; /* Deep dark background */
    color: #FFFFFF;
}

/* We reuse the typography styles from Step 14 (Dark Pricing) */
/* Adding specific spacing for this section */
.engines-pricing-section .pricing-card-dark {
    padding: 60px 45px;
}

.plan-divider-dark {
    height: 1px;
    background-color: rgba(255, 255, 255, 0.1);
    margin: 40px 0;
}

/* Ensuring alignment on the arrow icons */
.list-arrow {
    width: 8px;
    height: 8px;
    flex-shrink: 0;
    margin-top: 6px;
}

/* Responsiveness overrides */
@media (max-width: 1200px) {
    .engines-pricing-section .pricing-card-dark {
        padding: 40px 30px;
    }
}

@media (max-width: 991px) {
    .engines-pricing-section {
        padding: 80px 0;
    }
    /* Cards stack vertically, reset mt-auto button alignment */
    .engines-pricing-section .pricing-card-dark {
        margin-bottom: 20px;
    }
}
/* =========================================
   29. START FOCUSED, SCALE WIDE SECTION
========================================= */
.scale-wide-section {
    padding: 160px 0;
    background-color: #FFFFFF;
    width: 100%;
}

.scale-main-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.2rem, 3.5vw, 3.2rem);
    letter-spacing: -1.5px;
    color: var(--text-dark);
    margin-bottom: 60px;
}

/* Three Column Grid Logic */
.scale-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    width: 100%;
}

.scale-card {
    background-color: var(--bg-light); /* #F6F5F3 */
    padding: 60px 45px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    transition: transform 0.3s ease;
}

.scale-card:hover {
    transform: translateY(-10px);
}

.scale-bracket {
    width: 28px;
    height: 28px;
    margin-bottom: 30px;
    transform: scaleX(-1);
    transition: transform 0.4s ease;
}

.scale-card-title {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.4rem;
    color: #000;
    margin-bottom: 15px;
    letter-spacing: -0.5px;
}

.scale-card-desc {
    font-family: var(--font-nav);
    font-size: 0.9rem;
    color: #666;
    line-height: 1.6;
    margin-bottom: 25px;
}

.scale-card-price {
    font-family: var(--font-logo);
    font-weight: 800;
    font-size: 1.15rem;
    color: var(--brand-orange);
    margin: 0;
    letter-spacing: -0.5px;
}
.agency-diff-sectionn {
    background-color: #F6F5F3;
    padding: 160px 0;
}
.transformation-sectionn {
    padding: 160px 0;
    background-color: #fff;
    width: 100%;
}
/* --- RESPONSIVENESS --- */
@media (max-width: 991px) {
    .scale-wide-section { padding: 80px 0; }
    .scale-card { padding: 40px 30px; }
    .scale-grid { gap: 20px; }
}

@media (max-width: 767px) {
    .scale-grid {
        grid-template-columns: 1fr; /* Stack on mobile */
        gap: 25px;
    }
    .scale-main-title { font-size: 2rem; }
    .scale-card { align-items: center; text-align: center; }
}

/* =========================================
   30. NICHE AUTHORITY SECTION
========================================= */
.niche-authority-section {
    padding: 140px 0;
    background-color: var(--bg-light);
    background-image: url("data:image/svg+xml,%3Csvg width='1440' height='800' viewBox='0 0 1440 800' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M-100 400C100 300 300 500 500 400C700 300 900 500 1100 400C1300 300 1500 500 1700 400' stroke='%23000' stroke-opacity='0.02' stroke-width='1'/%3E%3C/svg%3E");
    background-size: cover;
    position: relative;
    overflow: hidden;
    width: 100%;
}

/* The Gray Semi-Circle Graphic */
.bg-decorative-circle {
    position: absolute;
    top: 50%;
    right: 5%;
    transform: translateY(-50%);
    width: 300px;
    height: 400px;
    background-color: #E0E0E0;
    opacity: 0.5;
    border-radius: 200px 0 0 200px; /* Creates the large semi-circle */
    z-index: 0;
}

/* Secondary shape for the double-circle effect */
.bg-decorative-circle::after {
    content: '';
    position: absolute;
    top: 0;
    right: -100px;
    width: 300px;
    height: 400px;
    background-color: #D1D1D1;
    border-radius: 200px 0 0 200px;
    z-index: -1;
}

.niche-content-wrapper {
    position: relative;
    z-index: 10;
    max-width: 1100px;
    margin: 0 auto;
}

.niche-main-title {
    font-family: var(--font-logo);
    font-weight: 900;
    font-size: clamp(2.8rem, 5.5vw, 5rem);
    line-height: 1.1;
    letter-spacing: -2.5px;
    color: var(--text-dark);
    margin-bottom: 35px;
}

.niche-sub-description {
    font-family: var(--font-nav);
    font-size: 1.1rem;
    color: #666;
    line-height: 1.7;
    max-width: 650px;
    margin: 0 auto 50px auto;
}

.niche-action-flex {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 80px; /* Space between button and arrow */
}

/* Reuse your existing orange button style or specific tweak */
.niche-authority-section .btn-orange-solid-cta {
    padding: 20px 45px;
    font-size: 16px;
}

.niche-arrow-box {
    margin-top: 10px;
}

/* --- RESPONSIVENESS --- */
@media (max-width: 1200px) {
    .bg-decorative-circle { width: 200px; height: 300px; }
}

@media (max-width: 991px) {
    .niche-authority-section { padding: 100px 0; }
    .bg-decorative-circle { display: none; } /* Clean up background for tablets */
}

@media (max-width: 767px) {
    .niche-main-title { font-size: 2.2rem; letter-spacing: -1.5px; }
    .niche-action-flex {
        flex-direction: column;
        align-items: center;
        gap: 40px;
    }
    .niche-sub-description { font-size: 1rem; }
}
/* =========================================
   31. IDENTITY SECTION (FIXED BUTTON ALIGNMENT)
========================================= */
.identity-section {
    padding: 160px 0;
    background-color: #FFFFFF;
    width: 100%;
}

.identity-image-wrapper {
    width: 100%;
    overflow: hidden;
    /* Creating the grayscale professional look from Figma */
    filter: grayscale(100%);
    transition: filter 0.4s ease;
    margin-left: -94px;
}

.identity-image-wrapper:hover {
    filter: grayscale(0%); /* Optional: reveal color on hover for pro feel */
}

.identity-img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.identity-main-title {
    font-family: var(--font-logo);
    font-weight: 800;
    /* Slightly smaller than hero headings but still very impactful */
    font-size: clamp(1.6rem, 2.5vw, 2.8rem); 
    line-height: 1.25;
    color: var(--text-dark);
    margin-bottom: 30px;
    letter-spacing: -1px;
}

.identity-paragraph {
    font-family: var(--font-nav);
    font-size: 1rem;
    line-height: 1.7;
    color: #666;
    max-width: 600px;
}

/* Specific button override - forces left alignment on desktop/laptop */
.identity-section .btn-orange-solid-cta {
    padding: 18px 45px;
    font-size: 15px;
    text-transform: none; /* Keeps it as per Figma casing */
    
    /* GUARANTEES LEFT ALIGN ON DESKTOP & OVERRIDES GLOBAL CENTER MARGINS */
    display: inline-block !important;
    margin: 0 !important;
    text-align: left;
}

/* =========================================
   --- RESPONSIVENESS (IDENTITY SECTION) ---
========================================= */

@media (max-width: 991px) {
    .identity-section { 
        padding: 60px 0; 
    }
    
    /* FIX THE OFF-SCREEN ALIGNMENT OVERFLOW */
    .identity-image-wrapper { 
        margin-left: 0; /* Reset desktop negative offset */
        margin-bottom: 35px; /* Creates clean separation between image and stacked text */
    }
    
    .identity-main-title { 
        font-size: 1.8rem; 
        text-align: center; 
        margin-bottom: 20px;
    }
    
    .identity-paragraph { 
        text-align: center; 
        margin: 0 auto 30px auto; 
    }
    
    .identity-content { 
        text-align: center; 
    }

    /* Centers the CTA button neatly on stacked views */
    .identity-section .btn-orange-solid-cta {
        display: inline-block !important;
        margin: 0 auto !important;
    }
}

@media (max-width: 575px) {
    .identity-section {
        padding: 50px 0;
    }
    
    .identity-image-wrapper {
        margin-bottom: 30px;
        margin-left: 0px;
    }
    
    .identity-main-title { 
        font-size: 1.45rem; 
        letter-spacing: -0.5px; 
        line-height: 1.3;
    }

    .identity-paragraph {
        font-size: 0.95rem;
        line-height: 1.6;
    }

    /* Converts the button to block layout on mobile phone screens */
    .identity-section .btn-orange-solid-cta {
        display: block !important;
        width: 100% !important;
        max-width: 320px;
        margin: 0 auto !important;
        text-align: center;
        box-sizing: border-box;
        padding: 16px 20px;
    }
}