/* ===========================================================================
   Uptown Laser — public reviews page
   Mobile-first. All rules are scoped under `.reviews-app` so this stylesheet
   can never collide with the main site's theme. No structural changes — styling
   only. Typography uses Montserrat (echoing the brand wordmark) + system fallback.
   =========================================================================== */

.reviews-app {
    --ul-ink:        #16171b;   /* near-black, brand wordmark */
    --ul-ink-soft:   #565a63;
    --ul-accent:     #c1973f;   /* warm gold accent */
    --ul-accent-dk:  #a87f2d;
    --ul-blue:       #7cc6ea;   /* sky-blue CTA, matches uptownlaser.com */
    --ul-blue-dk:    #5bb2de;
    --ul-bg:         #ffffff;
    --ul-bg-alt:     #f7f5f1;   /* warm off-white */
    --ul-line:       #e8e3da;
    --ul-card:       #ffffff;
    --ul-radius:     12px;
    --ul-container:  1140px;
    --ul-font:       "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

    margin: 0;
    font-family: var(--ul-font);
    font-weight: 400;
    color: var(--ul-ink);
    background: var(--ul-bg);
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.reviews-app *,
.reviews-app *::before,
.reviews-app *::after { box-sizing: border-box; }

.reviews-app .container {
    width: 100%;
    max-width: var(--ul-container);
    margin: 0 auto;
    padding: 0 20px;
}

/* ---------- Top bar (black) ---------- */
.reviews-app .ul-topbar {
    background: #000;
    color: #fff;
    font-size: 12.5px;
}
.reviews-app .ul-topbar-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 6px;
    padding: 9px 0;
}
.reviews-app .ul-topbar-loc {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #fff;
    text-decoration: none;
}
.reviews-app .ul-topbar-loc svg { width: 14px; height: 14px; fill: currentColor; flex: none; }
.reviews-app .ul-topbar-loc:hover { color: var(--ul-blue); }
.reviews-app .ul-topbar-es { font-weight: 600; }
.reviews-app .ul-topbar-social { display: inline-flex; align-items: center; gap: 14px; }
.reviews-app .ul-topbar-social a { color: #fff; display: inline-flex; transition: color .2s ease; }
.reviews-app .ul-topbar-social svg { width: 18px; height: 18px; fill: currentColor; }
.reviews-app .ul-topbar-social a:hover { color: var(--ul-blue); }

/* ---------- Header (logo + nav) ---------- */
.reviews-app .site-header {
    background: var(--ul-bg);
    border-bottom: 1px solid var(--ul-line);
    padding: 14px 0;
}
.reviews-app .site-header-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
}
.reviews-app .ul-logo { display: inline-flex; align-items: center; }
.reviews-app .ul-logo img { height: 40px; width: auto; display: block; }
.reviews-app .ul-nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 14px 18px;
}
.reviews-app .ul-nav-link {
    color: var(--ul-ink);
    text-decoration: none;
    font-weight: 500;
    font-size: 15px;
    letter-spacing: .2px;
    transition: color .2s ease;
}
.reviews-app .ul-nav-link:hover { color: var(--ul-blue-dk); }
.reviews-app .ul-cta {
    background: var(--ul-blue);
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
    padding: 11px 22px;
    border-radius: 999px;
    white-space: nowrap;
    transition: background .2s ease;
}
.reviews-app .ul-cta:hover { background: var(--ul-blue-dk); color: #fff; }

/* ---------- Tagline bar (black) ---------- */
.reviews-app .ul-tagline {
    background: #000;
    color: #fff;
    text-align: center;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: .4px;
    padding: 8px 0;
}

.reviews-app .brand-mark {
    font-weight: 800;
    font-size: 22px;
    letter-spacing: 3px;
    color: var(--ul-ink);
    text-transform: uppercase;
}

/* ---------- Intro (now inside hero) ---------- */
.reviews-app .intro-title {
    font-weight: 700;
    font-size: clamp(22px, 4.5vw, 30px);
    line-height: 1.3;
    margin: 0 auto 14px;
    max-width: 820px;
    color: var(--ul-ink);
}
.reviews-app .intro-text {
    font-size: clamp(14.5px, 2.4vw, 16px);
    color: var(--ul-ink-soft);
    line-height: 1.7;
    margin: 0 auto 32px;
    max-width: 760px;
}

/* ---------- Hero ---------- */
.reviews-app .hero {
    background: var(--ul-bg-alt);
    border-bottom: 1px solid var(--ul-line);
    text-align: center;
    padding: 44px 0 48px;
}
.reviews-app .hero-title {
    font-weight: 700;
    font-size: clamp(28px, 7vw, 44px);
    letter-spacing: 0.5px;
    margin: 0 0 18px;
    text-transform: uppercase;
}
.reviews-app .hero-rating {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    margin-bottom: 16px;
}
.reviews-app .hero-stars {
    color: var(--ul-accent);
    font-size: 30px;
    letter-spacing: 4px;
    line-height: 1;
}
.reviews-app .hero-avg {
    font-weight: 700;
    font-size: 22px;
    color: var(--ul-ink);
    margin-top: 8px;
}
.reviews-app .hero-avg-label {
    font-size: 12px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--ul-ink-soft);
}
.reviews-app .hero-count {
    font-size: clamp(16px, 4.5vw, 19px);
    font-weight: 400;
    color: var(--ul-ink-soft);
    margin: 4px 0 6px;
}
.reviews-app .hero-count strong { color: var(--ul-ink); font-weight: 700; }
.reviews-app .hero-statement {
    font-size: 15px;
    color: var(--ul-ink-soft);
    margin: 8px auto 0;
    max-width: 540px;
}

/* ---------- Reviews section ---------- */
.reviews-app .reviews-section { padding: 38px 0 64px; }

.reviews-app .reviews-search {
    max-width: 560px;
    margin: 0 auto 30px;
}
.reviews-app .reviews-search-input {
    width: 100%;
    padding: 14px 18px;
    font-family: inherit;
    font-size: 15px;
    color: var(--ul-ink);
    border: 1px solid var(--ul-line);
    border-radius: 999px;
    background: #fff;
    transition: border-color .2s ease, box-shadow .2s ease;
}
.reviews-app .reviews-search-input::placeholder { color: #9aa0a8; }
.reviews-app .reviews-search-input:focus {
    outline: none;
    border-color: var(--ul-accent);
    box-shadow: 0 0 0 3px rgba(193, 151, 63, 0.16);
}
.reviews-app .search-feedback {
    margin: 14px 0 0;
    text-align: center;
    font-size: 15.5px;
    font-weight: 600;
    color: var(--ul-ink);
}
.reviews-app .search-chips {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 8px 10px;
    margin-top: 14px;
}
.reviews-app .search-chips-label {
    font-size: 13px;
    color: var(--ul-ink-soft);
    font-weight: 500;
}
.reviews-app .search-chip {
    font-family: inherit;
    font-size: 13px;
    font-weight: 500;
    color: var(--ul-ink);
    background: var(--ul-bg-alt);
    border: 1px solid var(--ul-line);
    padding: 6px 14px;
    border-radius: 999px;
    cursor: pointer;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.reviews-app .search-chip:hover {
    background: var(--ul-line);
    border-color: #d5d0c5;
}
.reviews-app .search-chip.is-active {
    background: var(--ul-ink);
    border-color: var(--ul-ink);
    color: #fff;
}

/* Mobile-first: single column */
.reviews-app .reviews-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

.reviews-app .review-card {
    background: var(--ul-card);
    border: 1px solid var(--ul-line);
    border-radius: var(--ul-radius);
    padding: 22px 22px 18px;
    display: flex;
    flex-direction: column;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.reviews-app .review-card:hover {
    transform: translateY(-2px);
    border-color: #ded7c9;
    box-shadow: 0 12px 28px rgba(22, 23, 27, 0.08);
}

.reviews-app .review-stars {
    color: var(--ul-accent);
    font-size: 16px;
    letter-spacing: 2px;
    margin-bottom: 12px;
}
.reviews-app .review-body { flex: 1 1 auto; }
.reviews-app .review-text-primary,
.reviews-app .review-text-full {
    font-size: 15.5px;
    color: #33373f;
    margin: 0;
}
.reviews-app .review-text-full { margin-top: 10px; }

.reviews-app .read-more {
    margin-top: 12px;
    align-self: flex-start;
    background: none;
    border: none;
    padding: 0;
    color: var(--ul-accent-dk);
    font-family: inherit;
    font-size: 13.5px;
    font-weight: 600;
    letter-spacing: .3px;
    cursor: pointer;
}
.reviews-app .read-more:hover { text-decoration: underline; }

.reviews-app .review-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid var(--ul-line);
}
.reviews-app .review-author {
    font-weight: 600;
    font-size: 15px;
    color: var(--ul-ink);
}
.reviews-app .review-source {
    font-size: 10.5px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding: 4px 10px;
    border-radius: 999px;
    white-space: nowrap;
}
.reviews-app .review-source-google   { background: #f3f0e8; color: var(--ul-accent-dk); }
.reviews-app .review-source-facebook { background: #eef1f7; color: #345; }

.reviews-app .review-card.is-hidden { display: none; }

/* ---------- In-grid CTA (gentle funnel between reviews) ---------- */
.reviews-app .review-cta {
    grid-column: 1 / -1;
    text-align: center;
    background: var(--ul-bg-alt);
    border: 1px solid var(--ul-line);
    border-radius: var(--ul-radius);
    padding: 30px 24px;
}
.reviews-app .review-cta-title {
    font-size: clamp(17px, 3vw, 20px);
    font-weight: 600;
    color: var(--ul-ink);
    margin: 0 0 18px;
}

.reviews-app .no-results {
    text-align: center;
    color: var(--ul-ink-soft);
    font-size: 16px;
    padding: 28px 0;
}

/* ---------- Load more ---------- */
.reviews-app .load-more-wrap { text-align: center; margin-top: 36px; }
.reviews-app .load-more {
    font-family: inherit;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #fff;
    background: var(--ul-ink);
    border: 1px solid var(--ul-ink);
    padding: 14px 34px;
    border-radius: 999px;
    cursor: pointer;
    transition: background .2s ease, border-color .2s ease, color .2s ease, transform .1s ease;
}
.reviews-app .load-more:hover {
    background: var(--ul-accent);
    border-color: var(--ul-accent);
    color: var(--ul-ink);
}
.reviews-app .load-more:active { transform: translateY(1px); }

/* ---------- Footer ---------- */
.reviews-app .site-footer {
    background: #000;
    color: #c7c9cc;
    padding: 48px 0 40px;
}
.reviews-app .site-footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 34px;
}
.reviews-app .footer-logo { display: inline-block; }
.reviews-app .footer-logo img { height: 46px; width: auto; display: block; margin-bottom: 18px; }
.reviews-app .footer-brand p { margin: 0 0 10px; font-size: 14px; line-height: 1.6; }
.reviews-app .footer-call a,
.reviews-app .footer-privacy a { color: #7cc6ea; text-decoration: none; font-weight: 600; }
.reviews-app .footer-call a:hover,
.reviews-app .footer-privacy a:hover { text-decoration: underline; }
.reviews-app .footer-address { display: flex; align-items: flex-start; gap: 7px; color: #c7c9cc; }
.reviews-app .footer-address svg { width: 14px; height: 14px; fill: currentColor; flex: none; margin-top: 4px; }
.reviews-app .footer-copy { color: #9a9da2; font-size: 13px; }
.reviews-app .footer-rating { font-size: 14px; color: #fff; }
.reviews-app .footer-rating strong { font-weight: 700; }
.reviews-app .footer-rating-stars { color: #f3b900; letter-spacing: 1px; }

.reviews-app .footer-heading {
    color: #7cc6ea;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin: 0 0 18px;
}
.reviews-app .footer-heading::before { content: "[ "; color: #d98a3d; }
.reviews-app .footer-heading::after  { content: " ]"; color: #d98a3d; }

.reviews-app .footer-links { list-style: none; margin: 0; padding: 0; }
.reviews-app .footer-links li { margin: 0 0 11px; }
.reviews-app .footer-links a {
    color: #d4d6d9;
    text-decoration: none;
    font-size: 14px;
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
    transition: color .2s ease;
}
.reviews-app .footer-links a::before { content: "\203A"; color: #7cc6ea; font-weight: 700; }
.reviews-app .footer-links a:hover { color: #fff; }

.reviews-app .footer-social { display: inline-flex; gap: 10px; }
.reviews-app .footer-social a {
    width: 38px;
    height: 38px;
    background: #1b1b1d;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    transition: background .2s ease, color .2s ease;
}
.reviews-app .footer-social svg { width: 18px; height: 18px; fill: currentColor; }
.reviews-app .footer-social a:hover { background: #7cc6ea; color: #000; }

/* ===========================================================================
   Tablet (>= 768px)
   =========================================================================== */
@media (min-width: 768px) {
    .reviews-app .container { padding: 0 28px; }
    .reviews-app .ul-topbar-inner {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
        gap: 16px;
    }
    .reviews-app .site-header { padding: 16px 0; }
    .reviews-app .site-header-inner {
        flex-direction: row;
        justify-content: space-between;
    }
    .reviews-app .ul-logo img { height: 44px; }
    .reviews-app .ul-nav { justify-content: flex-end; gap: 22px; }
    .reviews-app .site-footer-grid {
        grid-template-columns: 1.7fr 1fr 1fr 1fr;
        gap: 40px;
    }
    .reviews-app .hero { padding: 60px 0 64px; }
    .reviews-app .hero-stars { font-size: 36px; }
    .reviews-app .reviews-section { padding: 52px 0 80px; }
    .reviews-app .reviews-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 22px;
    }
    .reviews-app .review-card { padding: 26px 26px 20px; }
}

/* ===========================================================================
   Desktop (>= 1024px)
   =========================================================================== */
@media (min-width: 1024px) {
    .reviews-app .hero { padding: 72px 0 76px; }
    .reviews-app .reviews-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 24px;
    }
}
