.no-wrap {
    flex-wrap: nowrap !important;
}

.shrink {
    flex-shrink: 1 !important;
}

/* ============================================================
   Banner Section — Skylight Tree Services
   ============================================================ */

/* Reset overrides for the banner section */
.banner {
    position: relative;

    background: #fff;
    padding: 0;
    overflow: hidden;
}

.banner .banner-main {
    position: relative;
    padding: 60px 20px 75px;
}

.banner-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0;
}

.banner-left {
    flex: 1 1 50%;
    max-width: 50%;
    padding-right: 25px;
}

.banner-right {
    flex: 1 1 50%;
    max-width: 50%;
    position: relative;
}

/* ---------- Heading ---------- */
.banner-heading {
    margin-bottom: 40px;
}

.banner .banner-heading h1 {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    color: #373737;
    font-size: 69px;
    line-height: 1.16;
    letter-spacing: 0;
    margin: 0;
    max-width: 675px;
}

/* Allow line-breaks inside the heading (main.css forces br display:none) */
.banner .banner-heading h1 br {
    display: inline !important;
}

.banner .banner-heading h1 .local-stroke {
    position: relative;
    display: inline-block;
    color: #fff;
    background: url('../images/strike.png') no-repeat center;
    background-size: 100% 100%;
    padding: 6px 22px 10px 26px;
    margin-left: -10px;
    z-index: 1;
}

/* Override main.css .banner h1 span global background (strike.png) on the Expert span */
.banner .banner-heading h1 .expert {
    color: #373737;
    background: none !important;
    padding: 0;
}

/* ---------- Tickets ---------- */
.banner-tickets {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: stretch;
    margin-top: 30px;
}

.ticket {
    position: relative;
    width: 211px;
    height: 283px;
    overflow: hidden;
    color: #fff;
    text-align: center;
    flex: 0 0 auto;
}

/* Scalloped edges — white half-circles cut into the colored ticket */
.ticket::before,
.ticket::after {
    content: '';
    position: absolute;
    left: 0px;
    width: 100%;
    height: 20px;
    background-image: radial-gradient(circle at 13px 0, #fff 10px, transparent 6.5px);
    background-size: 26.3px 20px;
    background-repeat: repeat-x;
    z-index: 3;
    pointer-events: none;
}

.ticket::before {
    top: -3px;
}

.ticket::after {
    bottom: -3px;
    transform: scaleY(-1);
}

.ticket-online { background: #4dc88d; }
.ticket-removal { background: #00b05c; }
.ticket-stump { background: #161616; }

.ticket .ticket-top {
    position: relative;
    height: 125px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 18px 18px 12px;
}

.ticket .ticket-bottom {
    position: relative;
    height: calc(100% - 125px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 12px 16px 18px;
}

/* Ticket-online: top half darker green */
.ticket-online .ticket-top {
    background: #00b05c;
}

/* Ticket-removal: top half black */
.ticket-removal .ticket-top {
    background: #161616;
}

/* Ticket-stump: top half green */
.ticket-stump .ticket-top {
    background: #00b05c;
}

.ticket .t-percent {
    display: block;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    font-size: 51px;
    line-height: 1;
    color: #fff;
}

.ticket .t-off {
    display: block;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    font-size: 39px;
    line-height: 1;
    color: #fff;
    margin-top: 4px;
}

.ticket .t-free {
    display: block;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    font-size: 61px;
    line-height: 1;
    color: #fff;
}

.ticket .t-title {
    display: block;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    font-size: 35px;
    line-height: 1.05;
    color: #fff;
    text-transform: uppercase;
}

.ticket .t-script {
    display: block;
    font-family: 'Alex Brush', 'Brush Script MT', cursive;
    font-weight: 400;
    font-size: 30px;
    line-height: 1.1;
    color: #fff;
    margin-top: 8px;
}

.ticket .t-sub {
    display: block;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.1;
    color: #fff;
    margin-top: 10px;
}

/* ---------- Form ---------- */
.banner-form-wrap {
    background: #00b05c;
    padding: 40px 40px 36px;
    position: relative;
    z-index: 2;
}

.banner-form-wrap .form-title {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    font-size: 48px;
    line-height: 1;
    color: #fff;
    text-align: center;
    margin: 0 0 28px;
}

.banner-quote-form .qf-row {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
}

.banner-quote-form .qf-row-3 > .qf-field {
    flex: 1 1 0;
}

.banner-quote-form .qf-row-3 > .qf-field-postcode {
    flex: 0 0 22%;
    max-width: 22%;
}

.banner-quote-form .qf-row-2 > .qf-field {
    flex: 1 1 0;
}

.banner-quote-form .qf-field {
    position: relative;
}

.qf-field .form-input:focus{background:rgba(255,255,255,.45);color:#fff;border-bottom:2px solid #fff}

.banner-quote-form input[type="text"],
.banner-quote-form input[type="tel"],
.banner-quote-form input[type="email"],
.banner-quote-form select,
.banner-quote-form textarea {
    width: 100%;
    height: 53px;
    background: rgba(255, 255, 255, 0.3);
    border: none;
    outline: none;
    padding: 0 18px;
    color: #fff;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 500;
    font-size: 18px;
    line-height: 1;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0;
}

/* Message textarea — visually behaves like a single-row input above 768px */
.banner-quote-form textarea.qf-message {
    resize: none;
    line-height: 1.3;
    padding: 16px 18px;
    overflow: hidden;
}

.banner-quote-form input::placeholder,
.banner-quote-form textarea::placeholder {
    color: #fff;
    opacity: 1;
    font-weight: 500;
}
.banner-quote-form input:-ms-input-placeholder,
.banner-quote-form textarea:-ms-input-placeholder { color: #fff; }
.banner-quote-form input::-ms-input-placeholder,
.banner-quote-form textarea::-ms-input-placeholder { color: #fff; }

.banner-quote-form select {
    color: #fff;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 19 12'><path d='M1 1 L9.5 9.5 L18 1' stroke='white' stroke-width='3' fill='none'/></svg>");
    background-repeat: no-repeat;
    background-position: right 18px center;
    background-size: 14px;
    padding-right: 42px;
}

.banner-quote-form select option {
    color: #161616;
    background: #fff;
}

/* File upload */
.banner-quote-form .qf-file {
    position: relative;
}
.banner-quote-form .qf-file input[type="file"] {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
}
.banner-quote-form .qf-file label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 53px;
    background: rgba(255, 255, 255, 0.3);
    padding: 0 18px;
    margin: 0;
    cursor: pointer;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 500;
    font-size: 18px;
    color: #fff;
    overflow: hidden;
}
.banner-quote-form .qf-file-text {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    flex: 1 1 auto;
    padding-right: 10px;
}
.banner-quote-form .qf-file-icon, 
.form-control .qf-file-icon {
    width: 22px;
    height: 22px;
    background: url('../images/upload-icon.svg') no-repeat center;
    background-size: contain;
    flex-shrink: 0;
}

.banner-quote-form .qf-submit {
    width: 100%;
    height: 53px;
    background: #161616;
    color: #fff;
    border: none;
    outline: none;
    margin-top: 4px;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    font-size: 20px;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: background 0.25s ease;
}

.banner-quote-form .qf-submit:hover {
    background: #000;
}

/* ---------- Banner Image (tree man) ---------- */
.banner-image {
    position: absolute;
    right: 40px;
    bottom: -60px;
    text-align: center;
    z-index: 10;
}

.banner-image img {
    max-width: 90%;
    height: auto;
    display: inline-block;
}

/* ---------- Bottom features strip (Section 2) ---------- */
.banner-features {
    background: #00b05c;
    padding: 45px 60px;
    position: relative;
    overflow: visible;
}

.banner-features::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: -120px;
    width: 100%;
    height: 85%;
    background: url('../images/tree-men.png') no-repeat left bottom;
    background-size: contain;
    pointer-events: none;
    z-index: 0;
}

.banner-features-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    gap: 20px;
    max-width: 620px;
    margin-left: 20em;
}

.bf-item {
    display: flex;
    align-items: flex-start;
    gap: 22px;
    flex: 1 1 0;
    color: #fff;
}

.bf-icon {
    flex: 0 0 auto;
    width: 80px;
    text-align: center;
}

.bf-icon img {
    max-width: 100%;
    height: auto;
}

.bf-content h4 {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    font-size: 30px;
    line-height: 1.2;
    color: #fff;
    margin: 0 0 10px;
}

.bf-content p {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 500;
    font-size: 14.5px;
    line-height: 1.4;
    color: #fff;
    margin: 0;
}

.banner-image-mobile {
    display: block;
    margin: 0 auto;
}

.banner-right-mobile {
    background: #00b05c;
    z-index: 10;
}

/* ============================================================
   Responsive — Large Desktop down
   ============================================================ */

@media (max-width: 1599px) {
    .banner-heading h1 { font-size: 58px; }
    .banner-form-wrap .form-title { font-size: 40px; }
}

@media (min-width: 1440px) {
    .banner-right-mobile {
        display: none;
    }
    .banner-image-mobile {
        display: none;
    }
    .banner-features-inner {
        margin-left: clamp(0rem, -60rem + 66.6667vw, 20rem);
    }
}

@media (min-width: 1440px) and (max-width: 1680px) {
    .banner-features::before {
        opacity: .5;
    }
    .banner-image {
        right: 0;
    }
}

@media (min-width: 992px) {
    .tree-men-image {
        display: none;
    }
}

@media (max-width: 1439.98px) {
    .banner .banner-main {
        padding: 60px 20px 40px;
    }
    .banner-row {
        justify-content: center;
        align-items: center;
    }
    .banner-right {
        display: none;
    }
    .banner-left {
        max-width: 100%;
    }
    .banner-heading {
        text-align: center;
        justify-self: center;
    }
    .banner-heading h1 {
        max-width: 800px;
    }
    .banner-tickets {
        justify-content: center;
    }
    .banner-right-mobile {
        margin-top: -200px;
    }
    .banner-image {
        display: none;
    }
}

@media (max-width: 1399px) {
    .banner .banner-main { padding: 40px 20px 24px; }
    .banner-heading h1 { font-size: 52px; }
    .banner-heading { margin-bottom: 30px; }
    .ticket { width: 185px; height: 250px; }
    .ticket .ticket-top { height: 110px; }
    .ticket .t-percent { font-size: 44px; }
    .ticket .t-off { font-size: 34px; }
    .ticket .t-free { font-size: 52px; }
    .ticket .t-title { font-size: 30px; }
    .ticket .t-script { font-size: 25px; }
    .banner-form-wrap { padding: 30px 50px 30px; }
    .banner-form-wrap .form-title { font-size: 36px; margin-bottom: 22px; }
    .banner-quote-form input[type="text"],
    .banner-quote-form input[type="tel"],
    .banner-quote-form input[type="email"],
    .banner-quote-form select,
    .banner-quote-form textarea,
    .banner-quote-form .qf-file label { height: 48px; font-size: 16px; }
    .banner-quote-form textarea.qf-message { padding-top: 13px; padding-bottom: 13px; }
    .banner-quote-form .qf-submit { height: 50px; font-size: 18px; }
    .banner-features { padding: 35px 60px 20px; }
    .banner-features::before {
        left: -70px;
    }
    .bf-content h4 { font-size: 24px; }
}

@media (max-width: 1260px) {
    .top-text{display:none}
}
@media (min-width: 1260px) {
    .xl\:no-wrap {
        flex-wrap: nowrap !important;
    }
}

/* ============================================================
   Tablet
   ============================================================ */
@media (max-width: 1199px) {
    .banner .banner-main { padding: 40px 20px; }
    .banner-row { flex-direction: column; }
    .banner-left {
        flex: 1 1 100%;
        max-width: 100%;
        padding-right: 0;
    }
    .banner .banner-heading h1 { font-size: 48px; text-align: center; }
    .banner .banner-heading h1 .local-stroke { margin-left: 0; }
    .banner-tickets { justify-content: center; }
    /* On tablet/mobile, show tree image FIRST then the form (matches mobile MCP) */
    .banner-image { order: 1; margin-top: 0; max-width: 600px; margin-left: auto; margin-right: auto; }
    .banner-form-wrap { order: 2; margin-top: 30px; }
    .banner-features-inner { max-width: 100%; }
    .banner-features::before { left: -50px; }
}

/* ============================================================
   Mobile
   ============================================================ */
@media (max-width: 767px) {
    .banner .banner-main { padding: 30px 20px 20px; }
    .banner-heading { margin-bottom: 24px; text-align: center; }
    .banner .banner-heading h1 {
        font-size: 40px;
        line-height: 1.2;
        text-align: center;
    }
    .banner .banner-heading h1 .local-stroke {
        font-size: 45px;
        padding: 6px 18px 10px 22px;
        margin-left: 0;
    }
    .banner .banner-heading h1 .expert {
        display: inline;
    }

    /* Tickets stack vertically as horizontal cards */
    .banner-tickets {
        flex-direction: column;
        gap: 8px;
        align-items: stretch;
    }
    .ticket {
        width: 100%;
        height: 94px;
        max-width: 340px;
        margin: 0 auto;
        display: flex;
        flex-direction: row;
    }
    .ticket .ticket-top {
        height: 100%;
        width: 89px;
        flex: 0 0 94px;
        flex-direction: column;
        padding: 8px 6px;
        transform: rotate(-90deg);
    }
    .ticket .ticket-bottom {
        height: 100%;
        flex: 1;
        padding: 8px 12px;
    }
    /* Scalloped edges on top and bottom for horizontal tickets */
    .ticket::before,
    .ticket::after {
        top: 0;
        width: 12px;
        height: 100%;
        background-image: radial-gradient(circle at 0 11px, #fff 5px, transparent 6.5px);
        background-size: 12px 18px;
        background-repeat: repeat-y;
    }
    .ticket::before {
        left: 0;
        transform: none;
    }

    .ticket::after {
        right: 0;
        left: auto;
        transform: scaleX(-1);
    }

    .ticket .t-percent { font-size: 39px; }
    .ticket .t-off { font-size: 30px; margin-top: 0; }
    .ticket .t-free { font-size: 29px; }
    .ticket .t-title { font-size: 26px; line-height: 1.05; }
    .ticket .t-script { font-size: 28px; margin-top: 4px; }
    .ticket .t-sub { font-size: 14px; margin-top: 4px; }

    /* Form */
    .banner-right { margin-top: 30px; }
    .banner-form-wrap { padding: 28px 22px 24px; }
    .banner-form-wrap .form-title { font-size: 30px; margin-bottom: 18px; }
    .banner-quote-form .qf-row { flex-direction: column; gap: 6px; margin-bottom: 6px; }
    .banner-quote-form .qf-row-3 > .qf-field-postcode { flex: 1 1 100%; max-width: 100%; }
    .banner-quote-form input[type="text"],
    .banner-quote-form input[type="tel"],
    .banner-quote-form input[type="email"],
    .banner-quote-form select,
    .banner-quote-form .qf-file label { height: 40px; font-size: 14.4px; padding: 0 14px; }
    .banner-quote-form .qf-submit { height: 53px; font-size: 16px; margin-top: 6px; }

    .banner-image { margin-top: 24px; }
    .banner-right-mobile {
        margin-top: -120px;
    }

    /* Bottom features */
    .banner-features-inner {
        flex-direction: column;
        gap: 20px;
        align-items: stretch;
    }
    .bf-item { gap: 0; }
    .bf-content h4 { font-size: 24px; margin-bottom: 6px; }
    .bf-content p { font-size: 14.5px; }
    .banner-features::before {
        left: -50px;
        width: 220px;
        height: 150px;
        opacity: 0.3;
    }
}

@media (max-width: 480px) {
    .banner .banner-heading h1 { font-size: 34px; }
    .banner .banner-heading h1 .local-stroke { font-size: 38px; padding: 5px 14px 8px 18px; }
    .banner-form-wrap .form-title { font-size: 26px; }
    .ticket { height: 90px; }
    .ticket::before, .ticket::after { background-image: radial-gradient(circle at 0 9px, #fff 5px, transparent 6.5px); }
    .ticket .ticket-top { flex: 0 0 90px; }
    .ticket .t-percent { font-size: 34px; }
    .ticket .t-title { font-size: 22px; }
    .ticket .t-script { font-size: 24px; }
}

/* Box-sizing safety net (in case main.css resets are absent) */
.banner *,
.banner *::before,
.banner *::after {
    box-sizing: border-box;
}

/* ============================================================
   Message textarea — 1-row visual ≥768px, 3 rows ≤767.98px.
   The .quote-cta textarea inherits these via its `.banner-quote-form` class
   (its `.qf-message` class makes the selector match) — no fork needed.
   ============================================================ */
@media (max-width: 767.98px) {
    .banner-quote-form textarea.qf-message {
        height: auto;
        min-height: calc(1.3em * 3 + 20px);
        line-height: 1.3;
        padding-top: 10px;
        padding-bottom: 10px;
        overflow: auto;
        resize: vertical;
    }
}

/* ============================================================
   Quote CTA before footer (Section 4)
   Form-field styling is calibrated to match the .banner-right reference
   form exactly. Banner-form rules (.banner-quote-form …) are untouched.
   ============================================================ */
.quote-cta { position: relative; padding: 4rem 0; overflow: hidden; }
.quote-cta-container { position: relative; z-index: 2; }
.quote-cta .quote-title {
    font-size: 3rem;
    font-weight: 700;
    text-align: center;
    color: #fff;
    margin-bottom: 2rem;
    line-height: 1.1;
}

.quote-cta .quote-img {
    position: absolute;
    bottom: 0;
    z-index: 1;
    pointer-events: none;
    user-select: none;
}
.quote-cta .quote-img-left {
    left: 0;
    width: 50vw;
    height: 100%;
    max-width: 600px;
    -webkit-mask-image: linear-gradient(to right, #000 60%, transparent 100%);
            mask-image: linear-gradient(to right, #000 60%, transparent 100%);
}
.quote-cta .quote-img-right {
    right: 0;
    width: 50vw;
    max-width: 675px;
    height: 90%;
}
.max-w-\[735px\] { max-width: 735px; }

/* ---------- Form fields — match .banner-right form exactly ---------- */

/* `background-color` (not `background` shorthand) so we don't overwrite
   the SVG chevron set by `.banner-quote-form select`. */
.quote-cta .form-control {
    background-color: rgba(255, 255, 255, 0.3);
    color: #fff;
    border: none;
    padding: 0 18px;
    height: 53px;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 1;
    border-radius: 0;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    box-shadow: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
.quote-cta .form-control::placeholder { color: #fff; opacity: 1; font-weight: 500; font-style: normal; }
.quote-cta .form-control::-webkit-input-placeholder { color: #fff; }
.quote-cta .form-control:-ms-input-placeholder { color: #fff; }
.quote-cta .form-control::-moz-placeholder { color: #fff; opacity: 1; }

/* Focus: same subtle background lift as banner; kill Bootstrap's blue ring
   and the previous `border-bottom: 2px solid #fff` underline. */
.quote-cta .form-control:focus {
    background: rgba(255, 255, 255, .45);
    color: #fff;
    border-bottom: 2px solid #fff;
}

/* Select — mirror the banner form's SVG chevron + padding-right gap. */
.quote-cta select.form-control {
    cursor: pointer;
    color: #fff;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 19 12'><path d='M1 1 L9.5 9.5 L18 1' stroke='white' stroke-width='3' fill='none'/></svg>");
    background-repeat: no-repeat;
    background-position: right 18px center;
    background-size: 14px;
    padding-right: 42px;
}
.quote-cta select.form-control option { color: #161616; background: #fff; }

/* Hide the Font-Awesome chevron that `.selectdiv:after` rendered before —
   we now use the same SVG arrow as the banner form. */
.quote-cta .selectdiv { width: 100%; position: relative; display: block; }
.quote-cta .selectdiv::after { content: none; display: none; }

/* Rows — gap-based spacing matching banner's `.qf-row` (10px gap, 10px below). */
.quote-cta .quote-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 0 0 10px;
}
.quote-cta .quote-row > [class*="col-"] {
    flex: 1 1 0;
    min-width: 0;
    padding: 0;
    margin: 0;
}

/* Postcode column — proportional 22% to match banner's `.qf-field-postcode`. */
.quote-cta .postcode-col { flex: 0 0 22%; max-width: 22%; }

/* File-upload label — height/padding/typography mirror banner's `.qf-file label`. */
.quote-cta .file-upload {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    position: relative;
    background-color: rgba(255, 255, 255, 0.3);
    color: #fff;
    padding: 0 18px;
    width: 100%;
    height: 53px;
    border: none;
    border-radius: 0;
    overflow: hidden;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 500;
    font-size: 18px;
    line-height: 1;
}
.quote-cta .file-upload input[type="file"] {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}
.quote-cta .file-upload .file-label {
    color: #fff;
    font-weight: 500;
    flex: 1 1 auto;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    padding-right: 10px;
}
.quote-cta .file-upload i {
    color: #fff;
    font-size: 1.1rem;
    line-height: 1;
    position: relative;
    left: auto;
    top: auto;
    flex: 0 0 auto;
}

/* Submit — mirror banner's `.qf-submit` (font/size/letter-spacing/margin/hover). */
.quote-cta .submit-quote {
    display: block;
    background: #161616;
    color: #fff;
    height: 53px;
    width: 100%;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-weight: 700;
    letter-spacing: 0.5px;
    font-size: 20px;
    border: none;
    margin-top: 4px;
    border-radius: 0;
    min-width: 0;
    text-transform: uppercase;
    box-shadow: none;
    transition: background 0.25s ease;
}
.quote-cta .submit-quote:hover,
.quote-cta .submit-quote:focus {
    background: #000;
    border-radius: 0;
    box-shadow: none;
    outline: none;
}

@media (max-width:991.91px){
  .quote-cta{padding:2.5rem 0 0}
  .quote-cta .quote-img-right{display:none}
  .quote-cta .quote-img-left{display:none}
  .banner-features::before { display: none; }
  .banner-features-inner {
      max-width: unset;
      margin-left: 0;
      margin-bottom: 30px;
  }
  .tree-men-image {
      margin: 0 auto;
      display: block;
  }
.banner-features { padding: 30px 22px 0px; }
}
@media (min-width:992px){
  .quote-img-mobile {
    display: none;
  }
}

/* ===== Form responsive — section title only.
   Form-field sizing for .quote-cta is handled by the banner-aligned
   media queries below (1399px / 767px) so the CTA form scales identically
   to .banner-right at every viewport.
   `.quote-form` legacy selectors are preserved in case they're used elsewhere. ===== */
@media (max-width: 991.91px) {
    .quote-form { padding: 2rem 0 2.5rem; }
    .quote-form .quote-title,
    .quote-cta .quote-title { font-size: 2.25rem; }
    .quote-form .form-control { height: 44px; font-size: .95rem; padding: 0 1rem; }
    .quote-form .submit-quote { height: 48px; font-size: 1.1rem; }
    .quote-form .selectdiv:after { top: .95rem; }
}
@media (max-width: 767.98px) {
    .quote-form .postcode-col,
    .quote-cta .postcode-col { flex: 0 0 100%; max-width: 100%; }
}
@media (max-width: 575.98px) {
    .quote-form .quote-title,
    .quote-cta .quote-title { font-size: 1.875rem; }
    .quote-form .form-control { height: 40px; font-size: .9rem; }
    .quote-form .selectdiv:after { top: .75rem; }
}

/* ===== Banner-aligned responsive rules for .quote-cta form fields.
   These mirror the breakpoint values in the .banner-quote-form blocks at
   the same widths (1399px and 767px) so both forms scale identically. ===== */
@media (max-width: 1399px) {
    .quote-cta .form-control,
    .quote-cta .file-upload { height: 48px; font-size: 16px; }
    .quote-cta .submit-quote { height: 50px; font-size: 18px; }
}

@media (max-width: 767px) {
    .quote-cta .quote-row { flex-direction: column; gap: 6px; margin-bottom: 6px; }
    .quote-cta .form-control,
    .quote-cta .file-upload { height: 40px; font-size: 14.4px; padding: 0 14px; }
    .quote-cta .submit-quote { height: 53px; font-size: 16px; margin-top: 6px; }
}

/* ============================================================
   Mobile Fixed Bottom Call Bar (Section 5) - visible <600px only
   ============================================================ */
.mobile-call-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:76px;background:#111;box-shadow:0 -10px 13.2px 0 rgba(0,0,0,.25);align-items:center;justify-content:center;gap:2rem;padding:0 1rem;padding-bottom:env(safe-area-inset-bottom,0px);z-index:1000}
.mobile-call-text{color:#fff;font-weight:700;font-size:2.4rem;text-shadow:.73px .73px 3.65px #000;padding-left:.75rem;line-height:1}
.mobile-call-btn{background:#00b05c;color:#111;font-weight:600;font-size:1.45rem;padding:.75rem 1.25rem;border-radius:8px;text-decoration:none;letter-spacing:-.5px;white-space:nowrap}
.mobile-call-btn:hover{background:#009950;color:#111;text-decoration:none}
@media (max-width:599.98px){
  .mobile-call-bar{display:flex}
  body{padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))}
  #back-top.active{bottom:calc(76px + 1rem)}
}
@media (max-width:380px){
  .mobile-call-text{font-size:2rem;padding-left:.5rem}
  .mobile-call-btn{font-size:1.2rem;padding:.6rem 1rem}
}