/* ============================================================
   KW Platinum Michigan — Responsive / Mobile CSS
   Loads LAST — after all Kadence and child theme CSS
   Created: April 2026
   ============================================================ */

/* ----------------------------------------------------------
   GLOBAL — Remove white blob / box overflow on all screens
   site-main has padding:50px + border-radius + box-shadow
   which causes overflow on smaller screens
   ---------------------------------------------------------- */
.site-main {
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow-x: hidden !important;
}

@media (max-width: 1024px) {
    .site-main {
        padding: 24px !important;
        margin: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    .site-container {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }
}

@media (max-width: 480px) {
    .site-main {
        padding: 12px !important;
    }
    .site-container {
        padding-left: 4px !important;
        padding-right: 4px !important;
    }
}

/* ----------------------------------------------------------
   GLOBAL — Small screen heading fixes
   ---------------------------------------------------------- */
@media (max-width: 360px) {
    h1.entry-title,
    h5.wp-block-heading {
        text-align: center !important;
        padding-left: 0 !important;
        margin-left: 0 !important;
    }
}

/* ----------------------------------------------------------
   HOMEPAGE — Two-column CTA buttons
   ---------------------------------------------------------- */
@media (min-width: 641px) {
    .kw-home-cta {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 2rem !important;
        margin-top: 1.5rem !important;
        align-items: end !important;
    }
}

@media (max-width: 640px) {
    .kw-home-cta {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }
}

/* ----------------------------------------------------------
   HOMEPAGE — Button text sizing
   ---------------------------------------------------------- */
@media (max-width: 900px) {
    .find-agent-button,
    .cash-for-homes-button {
        font-size: 0.85rem !important;
        padding: 0.75rem 1rem !important;
        letter-spacing: 0 !important;
    }
}

@media (max-width: 640px) {
    .find-agent-button,
    .cash-for-homes-button {
        font-size: 0.82rem !important;
        padding: 0.75rem 1.25rem !important;
    }
}

/* ----------------------------------------------------------
   CASH FOR HOMES — Hero grid + house image
   ---------------------------------------------------------- */

.cfh-wrap .cfh-hero-grid {
    display: grid !important;
    grid-template-columns: 1fr 220px !important;
    gap: 2rem !important;
    align-items: start !important;
    margin-bottom: 2rem !important;
}

.cfh-wrap .cfh-hero-image {
    display: flex !important;
    justify-content: center !important;
    align-items: flex-start !important;
    margin-top: -20px !important;
}

.cfh-wrap .cfh-hero-image img {
    width: 100% !important;
    max-width: 220px !important;
    height: auto !important;
    box-shadow: none !important;
    border: none !important;
    border-radius: 0 !important;
}

.page-id-1919 .cfh-form-wrap h3 {
    font-size: 1rem !important;
    font-weight: 600 !important;
}

@media (max-width: 956px) {
    .cfh-wrap .cfh-hero-image {
        display: none !important;
    }
    .cfh-wrap .cfh-hero-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ----------------------------------------------------------
   OUR AGENTS — Center cards on mobile
   ---------------------------------------------------------- */
@media (max-width: 640px) {
    body.page-id-101 .kw-agent-grid {
        grid-template-columns: 1fr !important;
        justify-items: center !important;
    }
    body.page-id-101 .kw-agent-card {
        justify-self: center !important;
        margin: 0 auto !important;
        width: 100% !important;
        max-width: 320px !important;
    }
}

/* ----------------------------------------------------------
   NEWS — Facebook logo image + posts grid
   ---------------------------------------------------------- */
.page-id-103 .wp-block-image {
    max-width: 300px !important;
    margin: 0 auto !important;
}

.page-id-103 .wp-block-image img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: auto !important;
    object-fit: contain !important;
    box-sizing: border-box !important;
}

@media (max-width: 640px) {
    .kw-facebook-posts-grid {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
        padding: 0 !important;
        margin: 20px 0 !important;
    }
    .kw-facebook-posts-grid > article {
        width: 100% !important;
        box-sizing: border-box !important;
    }
    .kwfb-feed {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    .kwfb-item {
        width: 100% !important;
        box-sizing: border-box !important;
    }
}

/* ----------------------------------------------------------
   BLOG / CATEGORY ARCHIVES — Stack image on top on mobile
   ---------------------------------------------------------- */
@media (max-width: 640px) {
    .category .kadence-posts-list .entry-list-item > article,
    .blog .kadence-posts-list .entry-list-item > article,
    .archive .kadence-posts-list .entry-list-item > article {
        display: block !important;
        height: auto !important;
    }
    .category .kadence-posts-list .entry-list-item > article .post-thumbnail,
    .blog .kadence-posts-list .entry-list-item > article .post-thumbnail,
    .archive .kadence-posts-list .entry-list-item > article .post-thumbnail {
        float: none !important;
        width: 100% !important;
        max-width: none !important;
        margin: 0 0 12px 0 !important;
    }
    .category .kadence-posts-list .entry-list-item > article .post-thumbnail img,
    .blog .kadence-posts-list .entry-list-item > article .post-thumbnail img,
    .archive .kadence-posts-list .entry-list-item > article .post-thumbnail img {
        width: 100% !important;
        height: auto !important;
        object-fit: cover !important;
    }
}

/* ----------------------------------------------------------
   CAREERS — Maroon button for KW form link
   ---------------------------------------------------------- */
.page-id-2638 .entry-content a[href*="locations.kw.com"] {
    display: inline-block !important;
    background-color: #b40101 !important;
    color: #ffffff !important;
    padding: 0.85rem 2rem !important;
    border-radius: 40px !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    text-decoration: none !important;
    margin-top: 0.5rem !important;
    transition: background-color 0.2s ease, transform 0.2s ease !important;
    box-shadow: 0 4px 12px rgba(180,1,1,0.25) !important;
}

.page-id-2638 .entry-content a[href*="locations.kw.com"]:hover {
    background-color: #8a0000 !important;
    transform: translateY(-2px) !important;
}

/* ----------------------------------------------------------
   CASH FOR HOMES — Push house image to right edge
   ---------------------------------------------------------- */
.cfh-wrap .cfh-hero-image {
    justify-content: flex-end !important;
}

/* ----------------------------------------------------------
   CASH FOR HOMES — Float house image to right edge
   ---------------------------------------------------------- */
.cfh-wrap .cfh-hero-image,
.cfh-wrap .cfh-hero-image figure {
    float: right !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    display: block !important;
}

/* ----------------------------------------------------------
   NEWS — Constrain Facebook logo image size
   ---------------------------------------------------------- */
.page-id-103 .wp-block-image {
    max-width: 200px !important;
    float: right !important;
    margin: 0 0 16px 20px !important;
}

/* ----------------------------------------------------------
   CAREERS — Force correct button colors
   ---------------------------------------------------------- */
.page-id-2638 .entry-content a.find-agent-button,
.page-id-2638 .entry-content a.find-agent-button:visited {
    background-color: #800000 !important;
    color: #ffffff !important;
}

.page-id-2638 .entry-content a.find-agent-button:hover {
    background-color: #a00000 !important;
    color: #ffffff !important;
}

/* ----------------------------------------------------------
   OUR AGENTS — Center single column cards on mobile
   ---------------------------------------------------------- */
@media (max-width: 640px) {
    body.page-id-101 .kw-agent-grid {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }
    body.page-id-101 .kw-agent-card {
        width: 100% !important;
        max-width: 320px !important;
        margin: 0 auto !important;
    }
}

/* ----------------------------------------------------------
   OUR AGENTS — Force center cards via margin auto
   ---------------------------------------------------------- */
@media (max-width: 640px) {
    div.kw-agent-card {
        margin: auto !important;
    }
}
/* ----------------------------------------------------------
   BLOG / CATEGORY — Three-breakpoint layout
   Targets Kadence's actual HTML: a.post-thumbnail > div.post-thumbnail-inner > img
   ---------------------------------------------------------- */

/* 0-500px: image full width stacked on top */
@media (max-width: 500px) {
    .entry-list-item article {
        display: block !important;
        height: auto !important;
        min-height: 0 !important;
    }
    .entry-list-item article a.post-thumbnail {
        display: block !important;
        float: none !important;
        width: 100% !important;
        max-width: 100% !important;
        padding-top: 0 !important;
        height: auto !important;
        margin: 0 0 16px 0 !important;
    }
    .entry-list-item article a.post-thumbnail .post-thumbnail-inner {
        height: auto !important;
        position: static !important;
    }
    .entry-list-item article a.post-thumbnail img {
        width: 100% !important;
        height: auto !important;
        position: static !important;
        object-fit: cover !important;
    }
}

/* 501-1023px: image float left, text wraps */
@media (min-width: 501px) and (max-width: 1023px) {
    .entry-list-item article {
        display: block !important;
        height: auto !important;
        min-height: 0 !important;
        overflow: hidden !important;
    }
    .entry-list-item article a.post-thumbnail {
        float: left !important;
        display: block !important;
        width: 220px !important;
        max-width: 40% !important;
        margin: 0 20px 12px 0 !important;
        padding-top: 0 !important;
        height: auto !important;
    }
    .entry-list-item article a.post-thumbnail .post-thumbnail-inner {
        height: auto !important;
        position: static !important;
    }
    .entry-list-item article a.post-thumbnail img {
        width: 100% !important;
        height: auto !important;
        position: static !important;
        object-fit: cover !important;
    }
    .entry-list-item article::after {
        content: "" !important;
        display: block !important;
        clear: both !important;
    }
}

/* ----------------------------------------------------------
   BLOG / CATEGORY — Fix Kadence thumbnail ratio wrapper
   ---------------------------------------------------------- */

/* Kill the ratio padding trick on all screen sizes for list view */
.entry-list-item article a.post-thumbnail[class*="kadence-thumbnail-ratio"] {
    padding-top: 0 !important;
    height: auto !important;
    display: block !important;
}

.entry-list-item article a.post-thumbnail .post-thumbnail-inner {
    position: static !important;
    height: auto !important;
}

.entry-list-item article a.post-thumbnail img {
    position: static !important;
    width: 100% !important;
    height: auto !important;
    object-fit: cover !important;
}

/* 0-600px: stack image full width on top */
@media (max-width: 600px) {
    .entry-list-item article {
        display: block !important;
        height: auto !important;
    }
    .entry-list-item article a.post-thumbnail {
        float: none !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 16px 0 !important;
    }
}

/* 601-1023px: float image left, text wraps beside it */
@media (min-width: 601px) and (max-width: 1023px) {
    .entry-list-item article {
        display: block !important;
        height: auto !important;
        overflow: hidden !important;
    }
    .entry-list-item article a.post-thumbnail {
        float: left !important;
        width: 280px !important;
        max-width: 45% !important;
        margin: 0 24px 12px 0 !important;
    }
    .entry-list-item article .entry-content-wrap {
        overflow: hidden !important;
    }
    .entry-list-item article::after {
        content: "" !important;
        display: block !important;
        clear: both !important;
    }
}

/* ----------------------------------------------------------
   BLOG — Kill Kadence 2-3 ratio wrapper grey bar globally in list view
   ---------------------------------------------------------- */
.entry-list-item a.kadence-thumbnail-ratio-2-3,
.entry-list-item a[class*="kadence-thumbnail-ratio"] {
    padding-top: 0 !important;
    height: auto !important;
    aspect-ratio: auto !important;
}

.entry-list-item a[class*="kadence-thumbnail-ratio"]::before {
    display: none !important;
    padding-top: 0 !important;
}

.entry-list-item a[class*="kadence-thumbnail-ratio"] .post-thumbnail-inner {
    position: static !important;
    inset: auto !important;
    height: auto !important;
    width: auto !important;
}

.entry-list-item a[class*="kadence-thumbnail-ratio"] img {
    position: static !important;
    width: 100% !important;
    height: auto !important;
    max-height: 280px !important;
    object-fit: cover !important;
}

/* ----------------------------------------------------------
   BLOG — Kill Kadence ratio padding-bottom hack on list items
   ---------------------------------------------------------- */
.entry-list-item .wp-site-blocks .post-thumbnail,
.wp-site-blocks .entry-list-item a.post-thumbnail,
.wp-site-blocks .entry-list-item .post-thumbnail {
    height: auto !important;
    padding-bottom: 0 !important;
    overflow: visible !important;
}

.wp-site-blocks .entry-list-item .post-thumbnail-inner {
    position: static !important;
    height: auto !important;
}

.wp-site-blocks .entry-list-item .post-thumbnail img,
.wp-site-blocks .entry-list-item a.post-thumbnail img {
    position: static !important;
    width: 100% !important;
    height: auto !important;
    max-height: 260px !important;
    object-fit: cover !important;
}

/* ----------------------------------------------------------
   BLOG — Override Kadence grid layout at tablet, use float instead
   ---------------------------------------------------------- */
@media (min-width: 601px) and (max-width: 1023px) {
    .grid-lg-col-1.item-image-style-beside article.loop-entry.has-post-thumbnail {
        display: block !important;
        grid-template-columns: unset !important;
    }
    .entry-list-item article {
        display: block !important;
        height: auto !important;
        min-height: 0 !important;
        overflow: hidden !important;
    }
    .entry-list-item article a.post-thumbnail {
        float: left !important;
        display: block !important;
        width: 240px !important;
        max-width: 40% !important;
        margin: 0 20px 12px 0 !important;
        padding-bottom: 0 !important;
        height: auto !important;
    }
    .entry-list-item article::after {
        content: "" !important;
        display: block !important;
        clear: both !important;
    }
}

/* ----------------------------------------------------------
   BLOG — Control card grid columns at breakpoints
   item-image-style-above means image is above text in each card
   ---------------------------------------------------------- */

/* 0-600px: single column */
@media (max-width: 600px) {
    .kadence-posts-list.grid-sm-col-2,
    .kadence-posts-list.grid-lg-col-3 {
        grid-template-columns: 1fr !important;
    }
}

/* 601-1023px: two columns */
@media (min-width: 601px) and (max-width: 1023px) {
    .kadence-posts-list.grid-lg-col-3 {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* ----------------------------------------------------------
   BLOG — Force image ABOVE text inside cards at all sizes
   Cancel any float that was previously applied
   ---------------------------------------------------------- */
.entry-list-item article a.post-thumbnail {
    float: none !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 0 0 !important;
}

.entry-list-item article {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
}

/* ----------------------------------------------------------
   BLOG — Fix vertical text in cards, force block layout
   ---------------------------------------------------------- */
.entry-list-item article.loop-entry {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

.entry-list-item article.loop-entry .entry-content-wrap {
    display: block !important;
    width: 100% !important;
    overflow: visible !important;
    padding: 1rem !important;
}

.entry-list-item article.loop-entry .entry-header,
.entry-list-item article.loop-entry .entry-summary,
.entry-list-item article.loop-entry .entry-footer {
    display: block !important;
    width: 100% !important;
    overflow: visible !important;
    writing-mode: horizontal-tb !important;
}

.entry-list-item article.loop-entry .entry-title {
    writing-mode: horizontal-tb !important;
    white-space: normal !important;
    overflow: visible !important;
    width: 100% !important;
}

/* ----------------------------------------------------------
   BLOG — Override child theme grid-template-columns at tablet/mobile
   Child theme sets 350px 1fr with !important — need higher specificity
   ---------------------------------------------------------- */
@media (max-width: 1023px) {
    body.blog .kadence-posts-list .entry-list-item > article.has-post-thumbnail,
    body.archive .kadence-posts-list .entry-list-item > article.has-post-thumbnail,
    body.category .kadence-posts-list .entry-list-item > article.has-post-thumbnail {
        display: block !important;
        grid-template-columns: unset !important;
    }
}

/* ----------------------------------------------------------
   BLOG — Ensure thumbnail doesn't overlap content in block mode
   ---------------------------------------------------------- */
@media (max-width: 1023px) {
    body.blog .kadence-posts-list .entry-list-item > article.has-post-thumbnail a.post-thumbnail,
    body.archive .kadence-posts-list .entry-list-item > article.has-post-thumbnail a.post-thumbnail,
    body.category .kadence-posts-list .entry-list-item > article.has-post-thumbnail a.post-thumbnail {
        display: block !important;
        position: relative !important;
        float: none !important;
        width: 100% !important;
        height: auto !important;
        padding-top: 0 !important;
        margin: 0 !important;
    }

    body.blog .kadence-posts-list .entry-list-item > article.has-post-thumbnail .entry-content-wrap,
    body.archive .kadence-posts-list .entry-list-item > article.has-post-thumbnail .entry-content-wrap,
    body.category .kadence-posts-list .entry-list-item > article.has-post-thumbnail .entry-content-wrap {
        display: block !important;
        position: relative !important;
        width: 100% !important;
        clear: both !important;
    }
}
