/**
 * Community Page Styles
 * Styles for 55+ Community detail pages
 *
 * @package Avada-Child-USHS
 * @version 1.0.0
 */

/* ==========================================================================
   Inherit Design Tokens from Directory CSS
   ========================================================================== */

:root {
    /* Colors - USHS Brand */
    --ushs-primary: #175873;
    --ushs-primary-hover: #193046;
    --ushs-primary-light: #4282aa;
    --ushs-secondary: #8cb89f;
    --ushs-text-dark: #222222;
    --ushs-text-medium: #555555;
    --ushs-text-light: #777777;
    --ushs-border: #d8d9db;
    --ushs-border-light: #e8e9eb;
    --ushs-background: #f9f9fb;
    --ushs-white: #ffffff;
    --ushs-shadow: rgba(25, 48, 70, 0.12);
    --ushs-shadow-hover: rgba(25, 48, 70, 0.2);

    /* Spacing */
    --ushs-space-xs: 4px;
    --ushs-space-sm: 8px;
    --ushs-space-md: 16px;
    --ushs-space-lg: 24px;
    --ushs-space-xl: 32px;
    --ushs-space-2xl: 48px;

    /* Typography - Senior friendly */
    --ushs-font-size-sm: 14px;
    --ushs-font-size-base: 16px;
    --ushs-font-size-lg: 18px;
    --ushs-font-size-xl: 20px;
    --ushs-font-size-2xl: 24px;
    --ushs-font-size-3xl: 32px;

    /* Border Radius */
    --ushs-radius-sm: 4px;
    --ushs-radius-md: 8px;
    --ushs-radius-lg: 12px;
    --ushs-radius-xl: 16px;

    /* Transitions */
    --ushs-transition-fast: 150ms ease;
    --ushs-transition-base: 250ms ease;
}

/* ==========================================================================
   Breadcrumbs
   ========================================================================== */

.ushs-breadcrumbs {
    padding: var(--ushs-space-md) 0;
    margin-bottom: var(--ushs-space-md);
}

.ushs-breadcrumbs__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--ushs-space-xs);
    list-style: none;
    margin: 0;
    padding: 0;
}

.ushs-breadcrumbs__item {
    display: flex;
    align-items: center;
    gap: var(--ushs-space-xs);
    font-size: var(--ushs-font-size-base);
}

.ushs-breadcrumbs__link {
    color: var(--ushs-primary);
    text-decoration: none;
    transition: color var(--ushs-transition-fast);
}

.ushs-breadcrumbs__link:hover {
    color: var(--ushs-primary-hover);
    text-decoration: underline;
}

.ushs-breadcrumbs__current {
    color: var(--ushs-text-medium);
    font-weight: 500;
}

.ushs-breadcrumbs__separator {
    display: flex;
    align-items: center;
    color: var(--ushs-text-light);
}

.ushs-breadcrumbs__separator svg {
    width: 16px;
    height: 16px;
}

/* ==========================================================================
   City Link
   ========================================================================== */

.ushs-city-link {
    display: inline-flex;
    align-items: center;
    gap: var(--ushs-space-sm);
    padding: var(--ushs-space-sm) var(--ushs-space-lg);
    font-size: var(--ushs-font-size-base);
    font-weight: 500;
    color: var(--ushs-primary);
    background: var(--ushs-white);
    border: 1px solid var(--ushs-primary);
    border-radius: var(--ushs-radius-md);
    text-decoration: none;
    transition: all var(--ushs-transition-fast);
}

.ushs-city-link:hover {
    color: var(--ushs-white);
    background: var(--ushs-primary);
}

.ushs-city-link:hover .ushs-city-link__icon,
.ushs-city-link:hover .ushs-city-link__arrow {
    color: var(--ushs-white);
}

.ushs-city-link__icon {
    flex-shrink: 0;
    color: var(--ushs-primary);
    transition: color var(--ushs-transition-fast);
}

.ushs-city-link__text {
    flex: 1;
}

.ushs-city-link__arrow {
    flex-shrink: 0;
    color: var(--ushs-primary);
    transition: transform var(--ushs-transition-fast), color var(--ushs-transition-fast);
}

.ushs-city-link:hover .ushs-city-link__arrow {
    transform: translateX(4px);
}

/* ==========================================================================
   Skyler's Take / Insider Notes - Quote Style with Photo
   ========================================================================== */

.ushs-insider-notes {
    display: flex;
    align-items: flex-start;
    gap: var(--ushs-space-xl);
    background: var(--ushs-background);
    border-radius: var(--ushs-radius-lg);
    padding: var(--ushs-space-xl);
    margin: var(--ushs-space-2xl) 0;
    position: relative;
}

/* Large decorative quote mark */
.ushs-insider-notes::before {
    content: '"';
    position: absolute;
    top: var(--ushs-space-md);
    right: var(--ushs-space-lg);
    font-size: 120px;
    font-family: Georgia, serif;
    color: var(--ushs-primary);
    opacity: 0.1;
    line-height: 1;
    pointer-events: none;
}

/* Photo styling */
.ushs-insider-notes__photo-wrapper {
    flex-shrink: 0;
}

.ushs-insider-notes__photo {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid var(--ushs-white);
    box-shadow: 0 4px 12px var(--ushs-shadow);
    image-rendering: -webkit-optimize-contrast; /* Helps with image clarity */
}

/* Content wrapper */
.ushs-insider-notes__content-wrapper {
    flex: 1;
    min-width: 0;
}

.ushs-insider-notes__title {
    font-size: var(--ushs-font-size-sm);
    font-weight: 600;
    color: var(--ushs-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0 0 var(--ushs-space-sm) 0;
}

/* Blockquote styling */
.ushs-insider-notes__quote {
    margin: 0;
    padding: 0;
    border: none;
}

.ushs-insider-notes__content {
    font-size: var(--ushs-font-size-lg);
    font-style: italic;
    line-height: 1.8;
    color: var(--ushs-text-dark);
}

.ushs-insider-notes__content p {
    margin: 0 0 var(--ushs-space-md) 0;
}

.ushs-insider-notes__content p:last-child {
    margin-bottom: 0;
}

.ushs-insider-notes__content p:first-child::before {
    content: '"';
}

.ushs-insider-notes__content p:last-child::after {
    content: '"';
}

/* If there's only one paragraph, handle quotes properly */
.ushs-insider-notes__content p:only-child::before {
    content: '"';
}

.ushs-insider-notes__content p:only-child::after {
    content: '"';
}

.ushs-insider-notes__content ul,
.ushs-insider-notes__content ol {
    margin: var(--ushs-space-md) 0;
    padding-left: var(--ushs-space-lg);
    font-style: normal;
}

.ushs-insider-notes__content li {
    margin-bottom: var(--ushs-space-xs);
}

/* Attribution */
.ushs-insider-notes__attribution {
    display: flex;
    flex-direction: column;
    margin-top: var(--ushs-space-md);
    padding-top: var(--ushs-space-md);
    border-top: 1px solid var(--ushs-border-light);
}

.ushs-insider-notes__author {
    font-size: var(--ushs-font-size-base);
    font-weight: 700;
    font-style: normal;
    color: var(--ushs-text-dark);
}

.ushs-insider-notes__credential {
    font-size: var(--ushs-font-size-sm);
    color: var(--ushs-text-medium);
    margin-top: 2px;
}

/* ==========================================================================
   Nearby Communities Section
   ========================================================================== */

.ushs-nearby-communities {
    padding: var(--ushs-space-2xl) 0;
    margin-top: var(--ushs-space-xl);
    border-top: 1px solid var(--ushs-border);
}

.ushs-nearby-communities__header {
    text-align: center;
    margin-bottom: var(--ushs-space-xl);
}

.ushs-nearby-communities__title {
    font-size: var(--ushs-font-size-3xl);
    font-weight: 700;
    color: var(--ushs-text-dark);
    margin: 0 0 var(--ushs-space-sm) 0;
}

.ushs-nearby-communities__subtitle {
    font-size: var(--ushs-font-size-lg);
    color: var(--ushs-text-medium);
    margin: 0;
}

/* Swiper Container */
.ushs-nearby-swiper {
    padding-bottom: var(--ushs-space-2xl);
    position: relative;
}

.ushs-nearby-swiper .swiper-slide {
    height: auto;
}

/* Swiper Navigation */
.ushs-nearby-swiper .swiper-button-prev,
.ushs-nearby-swiper .swiper-button-next {
    width: 44px;
    height: 44px;
    background: var(--ushs-white);
    border-radius: 50%;
    box-shadow: 0 2px 8px var(--ushs-shadow);
    color: var(--ushs-primary);
    transition: all var(--ushs-transition-fast);
}

.ushs-nearby-swiper .swiper-button-prev:hover,
.ushs-nearby-swiper .swiper-button-next:hover {
    background: var(--ushs-primary);
    color: var(--ushs-white);
}

.ushs-nearby-swiper .swiper-button-prev::after,
.ushs-nearby-swiper .swiper-button-next::after {
    font-size: 18px;
    font-weight: bold;
}

.ushs-nearby-swiper .swiper-button-disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Swiper Pagination */
.ushs-nearby-swiper .swiper-pagination {
    bottom: 0;
}

.ushs-nearby-swiper .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: var(--ushs-border);
    opacity: 1;
    transition: all var(--ushs-transition-fast);
}

.ushs-nearby-swiper .swiper-pagination-bullet-active {
    width: 24px;
    border-radius: 5px;
    background: var(--ushs-primary);
}

/* ==========================================================================
   Nearby Community Card
   ========================================================================== */

.ushs-nearby-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: var(--ushs-white);
    border-radius: var(--ushs-radius-lg);
    overflow: hidden;
    box-shadow: 0 2px 8px var(--ushs-shadow);
    text-decoration: none;
    transition: transform var(--ushs-transition-base), box-shadow var(--ushs-transition-base);
}

.ushs-nearby-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px var(--ushs-shadow-hover);
}

.ushs-nearby-card__image-wrapper {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--ushs-background);
}

.ushs-nearby-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--ushs-transition-base);
}

.ushs-nearby-card:hover .ushs-nearby-card__image {
    transform: scale(1.05);
}

.ushs-nearby-card__image-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: var(--ushs-background);
    color: var(--ushs-text-light);
}

.ushs-nearby-card__image-placeholder svg {
    width: 48px;
    height: 48px;
}

.ushs-nearby-card__distance {
    position: absolute;
    top: var(--ushs-space-sm);
    right: var(--ushs-space-sm);
    padding: var(--ushs-space-xs) var(--ushs-space-sm);
    font-size: var(--ushs-font-size-sm);
    font-weight: 600;
    color: var(--ushs-white);
    background: var(--ushs-secondary);
    border-radius: var(--ushs-radius-sm);
}

.ushs-nearby-card__content {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: var(--ushs-space-md);
}

.ushs-nearby-card__name {
    font-size: var(--ushs-font-size-lg);
    font-weight: 700;
    color: var(--ushs-text-dark);
    margin: 0 0 var(--ushs-space-xs) 0;
    line-height: 1.3;
}

.ushs-nearby-card__location {
    font-size: var(--ushs-font-size-base);
    color: var(--ushs-text-medium);
    margin: 0 0 var(--ushs-space-sm) 0;
}

.ushs-nearby-card__price {
    font-size: var(--ushs-font-size-base);
    font-weight: 600;
    color: var(--ushs-primary);
    margin: 0;
    margin-top: auto;
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */

@media (max-width: 1024px) {
    .ushs-nearby-swiper .swiper-button-prev,
    .ushs-nearby-swiper .swiper-button-next {
        display: none;
    }
}

@media (max-width: 768px) {
    .ushs-breadcrumbs {
        padding: var(--ushs-space-sm) 0;
    }

    .ushs-breadcrumbs__item {
        font-size: var(--ushs-font-size-sm);
    }

    .ushs-insider-notes {
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: var(--ushs-space-lg);
        margin: var(--ushs-space-xl) 0;
        gap: var(--ushs-space-lg);
    }

    .ushs-insider-notes::before {
        font-size: 80px;
        top: var(--ushs-space-sm);
        right: var(--ushs-space-md);
    }

    .ushs-insider-notes__photo {
        width: 140px;
        height: 140px;
    }

    .ushs-insider-notes__content {
        font-size: var(--ushs-font-size-base);
    }

    .ushs-insider-notes__attribution {
        align-items: center;
    }

    .ushs-nearby-communities {
        padding: var(--ushs-space-xl) 0;
    }

    .ushs-nearby-communities__title {
        font-size: var(--ushs-font-size-2xl);
    }

    .ushs-nearby-communities__subtitle {
        font-size: var(--ushs-font-size-base);
    }

    .ushs-city-link {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 480px) {
    .ushs-breadcrumbs__list {
        gap: 2px;
    }

    .ushs-breadcrumbs__separator svg {
        width: 12px;
        height: 12px;
    }
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
    /* General print optimizations */
    * {
        background: transparent !important;
        color: #000 !important;
        box-shadow: none !important;
        text-shadow: none !important;
    }

    a,
    a:visited {
        text-decoration: underline;
    }

    a[href]::after {
        content: " (" attr(href) ")";
        font-size: 0.8em;
        font-weight: normal;
    }

    /* Don't show URL for internal links */
    a[href^="/"]::after,
    a[href^="#"]::after {
        content: "";
    }

    /* Hide non-essential elements */
    .ushs-nearby-communities,
    .ushs-city-link,
    .swiper-button-prev,
    .swiper-button-next,
    .swiper-pagination,
    nav.fusion-main-menu,
    .fusion-header,
    .fusion-footer,
    .fusion-sliding-bar,
    #wrapper > .fusion-header-wrapper,
    .fusion-mobile-menu-icons,
    .fusion-social-links,
    .avada-blog-archive,
    button,
    input,
    select,
    textarea,
    video,
    iframe,
    .gform_wrapper,
    .ninja-forms-cont,
    .calendly-inline-widget,
    [id*="popup"],
    [class*="popup"],
    [id*="modal"],
    [class*="modal"] {
        display: none !important;
    }

    /* Show breadcrumbs but simplify */
    .ushs-breadcrumbs {
        border-bottom: 1px solid #ccc;
        padding-bottom: var(--ushs-space-sm);
        margin-bottom: var(--ushs-space-md);
    }

    .ushs-breadcrumbs__link::after {
        content: "" !important; /* Don't show URL for breadcrumbs */
    }

    /* Insider notes should print - it's valuable content */
    .ushs-insider-notes {
        border: 1px solid #ccc !important;
        page-break-inside: avoid;
        flex-direction: row !important;
        text-align: left !important;
    }

    .ushs-insider-notes::before {
        display: none !important; /* Hide decorative quote in print */
    }

    .ushs-insider-notes__photo {
        width: 80px !important;
        height: 80px !important;
        border: 2px solid #ccc !important;
        box-shadow: none !important;
    }

    /* Ensure images print */
    img {
        max-width: 100% !important;
        page-break-inside: avoid;
    }

    /* Page breaks */
    h1, h2, h3, h4, h5, h6 {
        page-break-after: avoid;
        page-break-inside: avoid;
    }

    p, blockquote, ul, ol, dl, table, pre {
        page-break-inside: avoid;
    }

    /* Ensure content is readable */
    body {
        font-size: 12pt;
        line-height: 1.5;
    }

    h1 {
        font-size: 24pt;
    }

    h2 {
        font-size: 18pt;
    }

    h3 {
        font-size: 14pt;
    }

    /* Show contact info clearly */
    .entry-content a[href^="tel:"]::after {
        content: "";
    }

    .entry-content a[href^="mailto:"]::after {
        content: "";
    }

    /* Ensure full width */
    .fusion-fullwidth,
    .fusion-builder-row,
    .fusion-layout-column {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Print header with contact info */
    @page {
        margin: 0.75in;
    }

    /* Add footer with URL */
    @page :footer {
        content: "Utah Seniors Home Search | utahseniorshomesearch.com | (801) 341-9204";
    }
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

.ushs-breadcrumbs :focus-visible,
.ushs-city-link:focus-visible,
.ushs-nearby-card:focus-visible {
    outline: 2px solid var(--ushs-primary);
    outline-offset: 2px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .ushs-nearby-card,
    .ushs-nearby-card__image,
    .ushs-city-link,
    .ushs-city-link__arrow {
        transition: none !important;
    }
}

/* High contrast mode */
@media (prefers-contrast: high) {
    .ushs-breadcrumbs__link,
    .ushs-city-link,
    .ushs-nearby-card__price {
        text-decoration: underline;
    }

    .ushs-nearby-card {
        border: 2px solid currentColor;
    }
}
