/* ═══════════════════════════════════════════════════════════════════════
   Organization Profile Page — v3 Redesign
   Premium warm-white + serif elegance, inspired by vetgreenpines.com
   ═══════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,300;0,400;0,500;0,700;1,400&display=swap');

:root {
    --org-accent:        #4A7CF6;
    --org-accent-dark:   #3566e0;
    --org-accent-light:  #EEF2FF;
    --org-text:          #1c1c1e;
    --org-text-muted:    #6b7280;
    --org-border:        #ede8e0;
    --org-bg:            #faf8f5;
    --org-card-bg:       #ffffff;
    --org-warm-section:  #f5f0eb;
    --org-radius:        16px;
    --org-radius-sm:     10px;
    --org-shadow:        0 2px 16px rgba(0,0,0,.05);
    --org-shadow-hover:  0 6px 28px rgba(0,0,0,.09);
    --org-gold:          #e8a930;
    --org-serif:         'Roboto', sans-serif;
}

/* ── Base font ───────────────────────────────────────────────────────── */
.org-profile-wrap,
.org-profile-wrap * {
    font-family: 'Roboto', sans-serif;
}

/* Baseline readable type size — keeps body copy comfortably larger than
   breadcrumbs and supporting UI chrome. Individual components override. */
.org-profile-wrap { font-size: 1rem; line-height: 1.55; }

/* ── Page wrapper ─────────────────────────────────────────────────────── */
.org-profile-wrap {
    background: var(--org-bg);
    min-height: 80vh;
}

/* ── Inner content max-width (profile bar, blocks, nav) ──────────────── */
.org-profile__profile-bar,
.org-actions-bar,
.org-page-nav__inner,
#org-blocks-wrap {
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
}
/* profile-bar and actions-bar need their own horizontal padding */
.org-profile__profile-bar { padding-left: 2rem; padding-right: 2rem; }
.org-actions-bar { padding-left: 1.5rem; padding-right: 1.5rem; }
@media (max-width: 575.98px) {
    .org-profile__profile-bar { padding-left: 1rem; padding-right: 1rem; }
    .org-actions-bar { padding-left: 1rem; padding-right: 1rem; }
}
#org-blocks-wrap { padding-left: 0; padding-right: 0; }

/* ── Hero (full-width, no card) ──────────────────────────────────── */
.org-profile__hero {
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    margin-bottom: 0;
    position: relative;
    overflow: visible;
}

/* ── Yelp-style photo mosaic ──────────────────────────────────────────
   1 big left + up to 4 small on right in a 2×2 grid. Count modifier
   controls layout (1, 2, 3, 4, 5 tiles visible at once). All tiles open
   the gallery modal. On mobile, collapses to a single hero image.
   ──────────────────────────────────────────────────────────────────── */
.org-hero-mosaic {
    position: relative;
    width: 100%;
    height: 520px;
    display: grid;
    gap: 4px;
    background: #111;
    overflow: hidden;
}
@media (max-width: 991.98px) { .org-hero-mosaic { height: 380px; } }
@media (max-width: 575.98px)  { .org-hero-mosaic { height: 280px; } }

/* Layout per visible count */
.org-hero-mosaic--1 {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
}
.org-hero-mosaic--2 {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr;
}
.org-hero-mosaic--3 {
    grid-template-columns: 2fr 1fr;
    grid-template-rows: 1fr 1fr;
}
.org-hero-mosaic--3 .org-hero-mosaic__tile:nth-child(1) { grid-row: 1 / span 2; }
.org-hero-mosaic--4 {
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: 1fr 1fr;
}
.org-hero-mosaic--4 .org-hero-mosaic__tile:nth-child(1) { grid-row: 1 / span 2; }
.org-hero-mosaic--4 .org-hero-mosaic__tile:nth-child(2) { grid-column: 2; grid-row: 1; }
.org-hero-mosaic--4 .org-hero-mosaic__tile:nth-child(3) { grid-column: 3; grid-row: 1; }
.org-hero-mosaic--4 .org-hero-mosaic__tile:nth-child(4) { grid-column: 2 / span 2; grid-row: 2; }
.org-hero-mosaic--5 {
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: 1fr 1fr;
}
.org-hero-mosaic--5 .org-hero-mosaic__tile:nth-child(1) { grid-row: 1 / span 2; }

/* Mobile: collapse to single first photo */
@media (max-width: 767.98px) {
    .org-hero-mosaic { grid-template-columns: 1fr !important; grid-template-rows: 1fr !important; }
    .org-hero-mosaic__tile { grid-row: 1 !important; grid-column: 1 !important; }
    .org-hero-mosaic__tile:not(:first-child) { display: none; }
}

/* Tile */
.org-hero-mosaic__tile {
    position: relative;
    overflow: hidden;
    padding: 0;
    border: none;
    background: #111;
    cursor: pointer;
}
.org-hero-mosaic__tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease, filter .2s ease;
    user-select: none;
    -webkit-user-drag: none;
}
.org-hero-mosaic__tile:hover img { transform: scale(1.03); filter: brightness(.95); }

/* "+N more" overlay on last tile */
.org-hero-mosaic__more {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.55);
    color: #fff;
    font-size: 1.6rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    letter-spacing: .02em;
}

/* "All photos" floating button */
.org-hero-mosaic__all-btn {
    position: absolute;
    bottom: 16px; right: 16px;
    background: rgba(255,255,255,.94);
    color: #1c1c1e;
    border-radius: 8px;
    padding: 8px 16px;
    font-size: .85rem;
    font-weight: 600;
    cursor: pointer;
    display: flex; align-items: center; gap: 6px;
    box-shadow: 0 2px 8px rgba(0,0,0,.2);
    z-index: 20;
    transition: background .15s, transform .15s;
    border: none;
}
.org-hero-mosaic__all-btn:hover { background: #fff; transform: translateY(-1px); }

/* Desktop: lift above floating CTA glass-panel */
@media (min-width: 992px) {
    .org-hero-mosaic__all-btn { bottom: 120px; z-index: 25; }
}

/* Edit cover overlay on mosaic */
.org-cover-edit-overlay {
    position: absolute;
    top: 12px; right: 12px;
    background: rgba(0,0,0,.45);
    color: #fff;
    border-radius: 10px;
    padding: 7px 14px;
    font-size: .82rem;
    display: none;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    backdrop-filter: blur(4px);
    transition: background .15s;
    z-index: 30;
}

/* Cover image wrapper (legacy fallback — single image) */
.org-profile__cover-wrap {
    border-radius: 0;
    overflow: hidden;
    position: relative;
}

.org-profile__cover {
    width: 100%;
    height: 340px;
    object-fit: cover;
    display: block;
}

.org-profile__cover-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        180deg,
        rgba(0,0,0,.20) 0%,
        transparent 45%,
        rgba(0,0,0,.12) 100%
    );
}

body.org-editing .org-cover-edit-overlay { display: flex; }
.org-cover-edit-overlay:hover { background: rgba(0,0,0,.65); }
.org-cover-edit-overlay { transition: background .15s; }

/* Profile bar: overlays bottom of carousel */
.org-profile__profile-bar {
    display: flex;
    align-items: flex-end;
    gap: 1.25rem;
    padding: 2rem 3rem 1.75rem;
    background: transparent;
    border-radius: 0;
    border-bottom: none;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 15;
}
/* Desktop: reserve right half of hero bottom for a floating CTA panel */
@media (min-width: 992px) {
    .org-profile__profile-bar {
        padding-right: calc(48% + 2.5rem); /* leave space on the right for the CTA overlay */
    }
}

/* Logo column — no negative margin, sits at bottom */
.org-profile__logo-col {
    flex-shrink: 0;
    margin-top: 0;
    position: relative;
    z-index: 10;
}

.org-profile__logo {
    width: 96px; height: 96px;
    border-radius: 50%;
    border: 4px solid #fff;
    box-shadow: 0 4px 20px rgba(0,0,0,.18);
    object-fit: cover;
    background: #fff;
    display: block;
}

.org-logo-placeholder {
    width: 96px; height: 96px;
    border-radius: 50%;
    border: 4px solid #fff;
    box-shadow: 0 4px 20px rgba(0,0,0,.18);
    background: #f0f2f5;
    display: flex; align-items: center; justify-content: center;
}

.org-logo-wrap {
    position: relative;
    display: inline-block;
    cursor: default;
    border-radius: 50%;
}
body.org-editing .org-logo-wrap { cursor: pointer; }

.org-logo-overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,.45);
    display: flex; opacity: 0;
    align-items: center; justify-content: center;
    transition: opacity .2s;
    border-radius: 50%;
    pointer-events: none;
}
body.org-editing .org-logo-wrap:hover .org-logo-overlay { opacity: 1; }
.org-logo-overlay i { font-size: 1.5rem; color: #fff; }

.org-logo-camera-badge {
    position: absolute;
    bottom: 3px; right: 3px;
    background: var(--org-accent);
    color: #fff;
    border-radius: 50%;
    width: 24px; height: 24px;
    display: none;
    align-items: center; justify-content: center;
    font-size: .72rem;
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
}
body.org-editing .org-logo-camera-badge { display: flex; }
.org-logo-uploading { opacity: .6; }

/* Profile info column */
.org-profile__profile-info {
    flex: 1;
    padding-top: 0;
    padding-bottom: .25rem;
    min-width: 0;
}

.org-profile__name {
    font-family: var(--org-serif);
    font-size: 1.9rem;
    font-weight: 700;
    color: #fff;
    margin: 0 0 .4rem;
    line-height: 1.2;
    /* Deeper shadow + subtle outer glow so the title stays legible on any cover photo */
    text-shadow:
        0 2px 12px rgba(0,0,0,.55),
        0 0 2px rgba(0,0,0,.35);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .35rem;
}

/* Inline editable name for owner */
.org-inline-title {
    font: inherit;
    color: inherit;
    background: transparent;
    border: none;
    border-bottom: 2px dashed rgba(0,0,0,.2);
    outline: none;
    padding: 0;
    width: 100%;
    max-width: 480px;
    line-height: inherit;
}
.org-inline-title:focus { border-bottom-color: var(--org-accent); }

.org-profile__verified-badge {
    color: #7dd3fc;
    font-size: 1.1rem;
    flex-shrink: 0;
}

/* Meta row: type + premium badges */
.org-profile__profile-meta {
    display: flex;
    align-items: center;
    gap: .45rem;
    flex-wrap: wrap;
    margin-bottom: .55rem;
}

.org-type-pill {
    background: rgba(255,255,255,.95);
    color: #0f172a;
    border-radius: 20px;
    padding: 3px 12px;
    font-size: .75rem;
    font-weight: 600;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border: 1px solid rgba(255,255,255,.4);
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
}

.org-premium-badge {
    display: inline-flex; align-items: center; gap: 4px;
    border-radius: 20px; padding: 3px 10px;
    font-size: .75rem; font-weight: 600;
}
.org-premium-badge--sponsored { background: rgba(251,191,36,.3); color: #fef3c7; }
.org-premium-badge--premium   { background: rgba(139,92,246,.3); color: #ede9fe; }

/* Rating row */
.org-profile__rating-row {
    display: flex;
    align-items: center;
    gap: .6rem;
    flex-wrap: wrap;
    font-size: .88rem;
}

.org-profile__stars {
    color: #fbbf24;
    letter-spacing: 1.5px;
    font-size: 1rem;
    text-shadow: 0 1px 4px rgba(0,0,0,.45);
}
.org-profile__rating-text {
    color: #fff;
    font-size: .84rem;
    font-weight: 600;
    text-shadow: 0 1px 4px rgba(0,0,0,.5);
}
.org-profile__google-rating {
    display: inline-flex; align-items: center; gap: 4px;
    background: rgba(255,255,255,.18);
    border-radius: 12px;
    padding: 2px 9px;
    font-size: .8rem;
    color: rgba(255,255,255,.9);
    backdrop-filter: blur(4px);
}

/* Responsive */
@media (max-width: 575.98px) {
    .org-profile__cover { height: 220px; }
    .org-profile__profile-bar { padding: 0 1rem 1.25rem; gap: .85rem; }
    .org-profile__logo-col { margin-top: -32px; }
    .org-profile__logo, .org-logo-placeholder { width: 72px; height: 72px; }
    .org-profile__name { font-size: 1.3rem; }
}

/* ── Actions bar ──────────────────────────────────────────────────────── */
.org-actions-bar {
    background: var(--org-card-bg);
    border-radius: 0;
    padding: .9rem 1.5rem;
    margin-bottom: 0;
    border-bottom: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: .65rem;
}

/* Desktop: glassy CTA panel floating up into the hero bottom-right.
   margin-top: -90px pulls the card into the hero, but then following siblings
   inherit that shift and end up under the cover. margin-bottom: 90px cancels
   the pull in the vertical flow so claim-cta / owner-bar land below the hero. */
@media (min-width: 992px) {
    .org-actions-bar {
        margin-top: -90px;           /* pull up into hero */
        margin-bottom: 90px;         /* cancel pull-up for following siblings */
        margin-right: 2rem;
        margin-left: auto;
        max-width: min(620px, calc(50% - 2rem));
        background: rgba(255, 255, 255, .94);
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
        border-radius: 14px;
        box-shadow:
            0 10px 30px rgba(0,0,0,.28),
            0 2px 6px rgba(0,0,0,.15);
        padding: .85rem 1.1rem;
        position: relative;
        z-index: 18;
        gap: .5rem;
    }
    .org-actions-bar .org-actions-main { gap: .4rem; }
    .org-actions-bar .org-actions-owner { gap: .35rem; }
}

/* Main actions group */
.org-actions-main {
    display: flex;
    align-items: center;
    gap: .45rem;
    flex-wrap: wrap;
}

/* Vertical separator between primary and secondary actions */
.org-actions-sep {
    width: 1px;
    height: 28px;
    background: var(--org-border);
    flex-shrink: 0;
    margin: 0 .15rem;
}

/* Primary CTA buttons (Call, Book) */
.org-btn-cta {
    border-radius: 24px;
    font-size: .88rem;
    font-weight: 600;
    padding: .5rem 1.3rem;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    transition: transform .15s, box-shadow .15s, background .15s, color .15s;
    white-space: nowrap;
    border: 2px solid transparent;
    cursor: pointer;
}
.org-btn-cta { text-decoration: none !important; }
.org-btn-cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(0,0,0,.14);
    text-decoration: none;
}
/* Call — solid green */
.org-btn-cta-call {
    background: #16a34a;
    border-color: #16a34a;
    color: #fff !important;
}
.org-btn-cta-call:hover {
    background: #15803d;
    border-color: #15803d;
    color: #fff !important;
}
/* Book — accent outline */
.org-btn-cta-book {
    background: var(--org-accent-light);
    border-color: var(--org-accent);
    color: var(--org-accent) !important;
}
.org-btn-cta-book:hover {
    background: var(--org-accent);
    color: #fff !important;
}
.org-btn-cta-book--disabled,
.org-btn-cta-book--disabled:hover {
    background: #f3f4f6 !important;
    border-color: #d1d5db !important;
    color: #9ca3af !important;
    cursor: not-allowed !important;
    transform: none !important;
    box-shadow: none !important;
    opacity: .75;
}

/* Small icon-action buttons (Directions, Website, Share, Inquiry) */
.org-btn-icon {
    border-radius: 20px;
    font-size: .76rem;
    font-weight: 500;
    padding: .32rem .7rem;
    display: inline-flex;
    align-items: center;
    gap: .28rem;
    border: 1.5px solid var(--org-border);
    color: var(--org-text-muted);
    background: transparent;
    transition: border-color .15s, color .15s, background .15s;
    white-space: nowrap;
    cursor: pointer;
    text-decoration: none !important;
}
.org-btn-icon:hover {
    border-color: var(--org-accent);
    color: var(--org-accent);
    background: var(--org-accent-light);
    text-decoration: none !important;
}

/* Favorite button */
.org-btn-fav {
    background: transparent;
    border: 1.5px solid #fca5a5;
    border-radius: 20px;
    padding: .36rem .75rem;
    color: #dc2626;
    font-size: .79rem;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: .32rem;
    cursor: pointer;
    transition: background .15s, border-color .15s;
    white-space: nowrap;
}
.org-btn-fav:hover { background: #fee2e2; border-color: #ef4444; }
.org-btn-fav.is-fav { background: #fee2e2; border-color: #ef4444; }

/* Owner controls (right side of bar) — legacy selector kept for in-bar layouts */
.org-actions-owner {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-shrink: 0;
}

/* Standalone owner control strip rendered after .org-actions-bar.
   Full-width, right-aligned, sits below the hero so it is never hidden under
   the floating CTA card on desktop. */
.org-owner-bar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .5rem;
    padding: .65rem 1.5rem;
    background: #f8f6f2;
    border-bottom: 1px solid var(--org-border);
}
@media (max-width: 575.98px) {
    .org-owner-bar { padding: .6rem 1rem; flex-wrap: wrap; }
}

/* Owner tip banner — dismissible hint shown once per org per browser */
.org-owner-tip {
    max-width: 1200px;
    margin: 1rem auto 0.5rem;
    padding: .85rem 1.1rem;
    background: linear-gradient(135deg, #eef4ff 0%, #f3efff 100%);
    border: 1px solid #c7d4f5;
    border-left: 4px solid var(--org-accent);
    border-radius: var(--org-radius-sm);
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    font-size: .92rem;
    line-height: 1.5;
    color: #1f2a44;
}
.org-owner-tip__icon { color: var(--org-accent); font-size: 1.25rem; flex-shrink: 0; margin-top: 2px; }
.org-owner-tip__body { flex: 1; }
.org-owner-tip__body strong { color: #0d1b3d; display: block; margin-bottom: 2px; }
.org-owner-tip__body .bi-pencil-fill { margin-right: 3px; }
.org-owner-tip__close {
    background: none; border: none;
    font-size: 1.4rem; line-height: 1;
    color: #6b7280; cursor: pointer;
    padding: 0 4px;
    align-self: flex-start;
}
.org-owner-tip__close:hover { color: var(--org-text); }
@media (max-width: 575.98px) {
    .org-owner-tip { margin-left: 1rem; margin-right: 1rem; }
}

/* Subtle "you own this" indicator — NOT a button, muted pill */
.org-owner-chip {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .22rem .6rem;
    font-size: .72rem;
    font-weight: 500;
    color: #16a34a;
    background: #dcfce7;
    border: 1px solid #bbf7d0;
    border-radius: 10px;
    cursor: default;
    user-select: none;
    white-space: nowrap;
}
.org-owner-chip i { font-size: .85rem; }

/* Responsive */
@media (max-width: 575.98px) {
    .org-actions-bar { padding: .8rem 1rem; }
    .org-actions-sep { display: none; }
    .org-btn-cta { font-size: .82rem; padding: .45rem 1.1rem; }
}

/* Claim CTA */
.org-claim-cta {
    margin-bottom: .75rem;
    font-size: .85rem;
    color: var(--org-text-muted);
    text-align: center;
    width: 100%;
}

/* ── Block container ──────────────────────────────────────────────────── */
#org-blocks-wrap {
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* ── Single block ─────────────────────────────────────────────────────── */
.org-block {
    background: var(--org-card-bg);
    border-radius: 0;
    box-shadow: none;
    border-bottom: none;
    transition: opacity .2s;
    overflow: visible;
}
.org-block:hover { box-shadow: none; }

.org-block--hidden .org-block__body { opacity: .35; pointer-events: none; }
.org-block--hidden .org-block__bar  { background: #fffbeb; border-bottom-color: #fde68a; }
.org-block--ghost  { opacity: .5; background: var(--org-accent-light); }
.org-block--chosen { box-shadow: 0 8px 30px rgba(74,124,246,.25) !important; }

/* Block control bar (owner-only, only visible in edit mode) */
.org-block__bar {
    display: none;
    align-items: center;
    gap: .75rem;
    padding: .5rem 1rem;
    background: #f9fafb;
    border-bottom: 1px solid var(--org-border);
    font-size: .8rem;
    color: var(--org-text-muted);
}
body.org-editing .org-block__bar { display: flex; }

.org-block__drag-handle {
    cursor: grab;
    color: #9ca3af;
    display: flex;
    align-items: center;
    padding: 2px 4px;
    border-radius: 4px;
    transition: color .15s, background .15s;
    flex-shrink: 0;
}
.org-block__drag-handle:hover { color: var(--org-accent); background: var(--org-accent-light); }
.org-block__drag-handle:active { cursor: grabbing; }

.org-block__arrows {
    display: flex;
    flex-direction: column;
    gap: 1px;
    flex-shrink: 0;
}

.org-block__arrow-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 18px;
    background: none;
    border: 1px solid var(--org-border);
    border-radius: 4px;
    color: #6b7280;
    cursor: pointer;
    padding: 0;
    font-size: 11px;
    line-height: 1;
    transition: all .15s;
}

.org-block__arrow-btn:hover {
    background: var(--org-accent-light);
    border-color: var(--org-accent);
    color: var(--org-accent);
}

.org-block__bar-label {
    flex: 1;
    font-weight: 600;
    color: #374151;
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.org-block__vis-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    background: none;
    border: 1px solid var(--org-border);
    border-radius: 20px;
    padding: 3px 12px;
    font-size: .75rem;
    color: var(--org-text-muted);
    cursor: pointer;
    transition: all .15s;
    white-space: nowrap;
}
.org-block__vis-btn:hover {
    background: var(--org-accent-light);
    border-color: var(--org-accent);
    color: var(--org-accent);
}
.org-block--hidden .org-block__vis-btn {
    border-color: #f59e0b;
    color: #d97706;
}

/* Remove block button */
.org-block__remove-btn {
    display: flex;
    align-items: center;
    gap: 4px;
    background: none;
    border: 1px solid transparent;
    border-radius: 20px;
    padding: 3px 10px;
    font-size: .75rem;
    color: #9ca3af;
    cursor: pointer;
    transition: all .15s;
    white-space: nowrap;
    flex-shrink: 0;
}
.org-block__remove-btn:hover {
    background: #fff1f2;
    border-color: #fecdd3;
    color: #e11d48;
}

/* ── "Add block" panel — floats above save bar ────────────────────── */
.org-add-block-panel {
    display: none;
    position: fixed;
    bottom: 64px; /* just above the save bar */
    left: 50%;
    transform: translateX(-50%);
    width: min(520px, calc(100vw - 32px));
    background: var(--org-card-bg);
    border-radius: var(--org-radius);
    box-shadow: 0 8px 32px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.08);
    border: 1px solid var(--org-border);
    padding: 1.1rem 1.4rem;
    z-index: 1060;
    animation: orgPanelIn .15s ease;
}
@keyframes orgPanelIn {
    from { opacity: 0; transform: translateX(-50%) translateY(8px); }
    to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
.org-add-block-panel.is-open { display: block; }

.org-add-block-panel__title {
    font-weight: 700;
    font-size: .9rem;
    color: var(--org-text-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 1rem;
}

.org-add-block-panel__list {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.org-add-block-item {
    display: flex;
    align-items: center;
    gap: .45rem;
    padding: .45rem 1rem;
    background: var(--org-bg);
    border: 1px solid var(--org-border);
    border-radius: 20px;
    font-size: .82rem;
    color: var(--org-text);
    cursor: pointer;
    transition: all .15s;
}
.org-add-block-item:hover {
    background: var(--org-accent-light);
    border-color: var(--org-accent);
    color: var(--org-accent);
}

/* ── Custom block title ───────────────────────────────────────────── */
.org-custom-title-wrap { position: relative; }
.org-custom-title-view { display: block; }
body.org-editing .org-custom-title-view { display: none; }

/* show the input only in edit mode */
.org-custom-title-input {
    display: none;
    font-family: var(--org-serif);
    font-size: 1.45rem;
    font-weight: 700;
    color: var(--org-text);
    background: #f3f4f6;
    border: 1.5px dashed var(--org-border);
    border-radius: 8px;
    padding: .3rem .7rem;
    width: 100%;
    margin-bottom: .9rem;
    box-sizing: border-box;
    line-height: 1.3;
}
.org-custom-title-input:focus {
    outline: none;
    border-color: var(--org-accent);
    background: #fff;
}
body.org-editing .org-custom-title-input { display: block; }

/* ── Custom block WYSIWYG editor ─────────────────────────────────── */
/* View mode: no border, just content */
.org-custom-editor {
    border: none;
    border-radius: 0;
    background: transparent;
    overflow: visible;
}
/* Edit mode: show editor frame */
body.org-editing .org-custom-editor {
    border: 1px solid var(--org-border);
    border-radius: var(--org-radius-sm);
    background: #fff;
    overflow: hidden;
}

/* Toolbar */
.org-custom-editor__toolbar {
    display: none;
    align-items: center;
    flex-wrap: wrap;
    gap: 2px;
    padding: .45rem .75rem;
    background: #f9fafb;
    border-bottom: 1px solid var(--org-border);
}
body.org-editing .org-custom-editor__toolbar { display: flex; }

.org-ce-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    min-width: 30px;
    height: 28px;
    padding: 0 7px;
    border: 1px solid transparent;
    border-radius: 6px;
    background: none;
    font-size: .8rem;
    color: var(--org-text);
    cursor: pointer;
    transition: all .12s;
    font-family: inherit;
    white-space: nowrap;
}
.org-ce-btn:hover { background: var(--org-border); border-color: transparent; }
.org-ce-btn.is-active { background: var(--org-accent-light); border-color: var(--org-accent); color: var(--org-accent); }
.org-ce-btn--save {
    background: var(--org-accent);
    color: #fff;
    font-weight: 600;
    margin-left: auto;
    padding: 0 14px;
}
.org-ce-btn--save:hover { background: var(--org-accent-dark); border-color: transparent; }
.org-ce-btn--html { font-family: monospace; font-size: .75rem; color: var(--org-text-muted); }
.org-ce-btn--html.is-active { color: #c026d3; border-color: #e879f9; background: #fdf4ff; }

.org-ce-sep {
    width: 1px;
    height: 20px;
    background: var(--org-border);
    margin: 0 4px;
    flex-shrink: 0;
}

/* Editor body: contenteditable */
.org-custom-editor__body {
    min-height: 0;
    max-height: none;
    overflow-y: visible;
    padding: 0;
    font-size: .95rem;
    line-height: 1.75;
    color: var(--org-text);
    outline: none;
    cursor: default;
}
body.org-editing .org-custom-editor__body {
    min-height: 160px;
    max-height: 600px;
    overflow-y: auto;
    padding: 1.25rem 1.5rem;
}
body.org-editing .org-custom-editor__body { cursor: text; }
.org-custom-editor__body:focus { outline: none; }
.org-custom-editor__body[contenteditable="true"]:empty::before {
    content: attr(data-placeholder);
    color: var(--org-text-muted);
    pointer-events: none;
}
.org-custom-editor__body h2 { font-size: 1.3rem; font-weight: 700; margin: 1rem 0 .5rem; }
.org-custom-editor__body h3 { font-size: 1.1rem; font-weight: 600; margin: .9rem 0 .4rem; }
.org-custom-editor__body p  { margin: 0 0 .75rem; }
.org-custom-editor__body ul,
.org-custom-editor__body ol { padding-left: 1.5rem; margin: 0 0 .75rem; }
.org-custom-editor__body li { margin-bottom: .25rem; }
.org-custom-editor__body a  { color: var(--org-accent); text-decoration: underline; }
.org-custom-editor__body img {
    max-width: 100%;
    height: auto;
    border-radius: var(--org-radius-sm);
    margin: .5rem 0;
    display: block;
}
.org-custom-editor__body blockquote {
    border-left: 3px solid var(--org-gold);
    margin: .75rem 0;
    padding: .5rem 1rem;
    color: var(--org-text-muted);
    font-style: italic;
}

/* HTML source textarea */
.org-custom-editor__source {
    display: none;
    width: 100%;
    min-height: 160px;
    padding: 1rem 1.25rem;
    font-family: monospace;
    font-size: .8rem;
    line-height: 1.6;
    border: none;
    resize: vertical;
    color: #1e293b;
    background: #f8fafc;
    box-sizing: border-box;
}
.org-custom-editor__source:focus { outline: none; }

/* Status dot for save feedback */
.org-ce-save-status {
    font-size: .76rem;
    font-weight: 500;
    padding: 2px 8px;
    border-radius: 20px;
    transition: all .2s;
}

/* Public output for non-owners */
.org-custom-block-output {
    line-height: 1.75;
    color: var(--org-text);
    font-size: .95rem;
    padding: 1.25rem 1.5rem;
}
.org-custom-block-output h2 { font-size: 1.3rem; font-weight: 700; margin: 1rem 0 .5rem; }
.org-custom-block-output h3 { font-size: 1.1rem; font-weight: 600; margin: .9rem 0 .4rem; }
.org-custom-block-output p  { margin: 0 0 .75rem; }
.org-custom-block-output ul,
.org-custom-block-output ol { padding-left: 1.5rem; margin: 0 0 .75rem; }
.org-custom-block-output a  { color: var(--org-accent); text-decoration: underline; }
.org-custom-block-output img {
    max-width: 100%;
    height: auto;
    border-radius: var(--org-radius-sm);
    margin: .5rem 0;
    display: block;
}
.org-custom-block-output blockquote {
    border-left: 3px solid var(--org-gold);
    margin: .75rem 0;
    padding: .5rem 1rem;
    color: var(--org-text-muted);
    font-style: italic;
}
.org-custom-block-output:empty::before {
    content: '— ще немає вмісту —';
    color: var(--org-text-muted);
    font-style: italic;
    font-size: .9rem;
}

.org-block__body { padding: 0; }

/* ── Section (block body inner container) — full width ───────────────── */
.org-profile__section {
    padding: 2.5rem 3rem;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    overflow: visible;
}
/* Consistent vertical rhythm between blocks */
.org-profile__section-wrap + .org-profile__section-wrap,
.org-block + .org-block {
    margin-top: 0;
}
/* Subtle separator between sections for scannability */
.org-block:not(:first-of-type) { border-top: 1px solid color-mix(in srgb, var(--org-border) 55%, transparent); }

/* ── Section heading — warm gold underline accent ─────────────────── */
.org-section-h {
    font-family: var(--org-serif);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--org-text);
    margin-bottom: 1.75rem;
    line-height: 1.3;
    position: relative;
    padding-left: 0;
    padding-bottom: .65rem;
    display: flex;
    align-items: center;
    gap: .7rem;
}
.org-section-h::after { display: none; }
.org-section-h.mb-0 { margin-bottom: 0; padding-bottom: 0; }
.org-section-h__icon {
    flex-shrink: 0;
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    background: linear-gradient(135deg, color-mix(in srgb, var(--org-accent) 18%, #fff) 0%, color-mix(in srgb, var(--org-accent) 8%, #fff) 100%);
    color: var(--org-accent);
    border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,.05), inset 0 0 0 1px color-mix(in srgb, var(--org-accent) 16%, transparent);
}
.org-section-h__text { line-height: 1.25; }
.org-section-h__editable {
    cursor: default;
    border-radius: 6px;
    padding: 2px 6px;
    margin: -2px -6px;
    transition: background .15s, outline .15s;
    outline: 2px solid transparent;
    min-width: 60px;
    display: inline-block;
}
body.org-editing .org-section-h__editable {
    cursor: text;
    border-bottom: 2px dashed rgba(0,0,0,.2);
    border-radius: 0;
    padding-bottom: 3px;
}
body.org-editing .org-section-h__editable::after {
    content: '\F4CB';
    font-family: 'bootstrap-icons';
    font-size: .55em;
    font-weight: 400;
    opacity: .45;
    margin-left: 6px;
    vertical-align: middle;
    pointer-events: none;
}
body.org-editing .org-section-h__editable:hover {
    background: rgba(0,0,0,.04);
    border-bottom-color: rgba(0,0,0,.4);
}
body.org-editing .org-section-h__editable:focus {
    outline: none;
    border-bottom: 2px solid var(--org-accent, #9c7f6b);
    background: transparent;
}
.org-section-h__editable--saving {
    opacity: .6;
}
.org-section-h__editable--saved::after {
    content: ' ✓' !important;
    font-family: inherit !important;
    font-size: .7em;
    color: #28a745;
    font-weight: 400;
    opacity: 1 !important;
}
@media (max-width: 575.98px) {
    .org-section-h { gap: .55rem; }
    .org-section-h__icon { width: 34px; height: 34px; font-size: 1rem; border-radius: 9px; }
}

/* Legacy — kept for backward compat, no longer used in markup */
.org-section-label { display: none; }
.org-profile__section-title {
    font-family: var(--org-serif);
    font-size: 1.45rem;
    font-weight: 700;
    color: var(--org-text);
    margin-bottom: 1.5rem;
    line-height: 1.3;
    position: relative;
    padding-left: 1.05rem;
    display: block;
    border-bottom: none;
    padding-bottom: 0;
}
.org-profile__section-title::before {
    content: '';
    position: absolute;
    left: 0; top: .1em; bottom: .05em;
    width: 3px;
    background: var(--org-accent);
    border-radius: 3px;
}
.org-profile__section-title em { font-style: italic; color: var(--org-accent); }
.org-profile__section-title i { display: none; }

/* ── Contact cards grid (centered vertical cards, warm/airy style) ──────
   auto-fit: ніяких "dangling" останніх рядків з розтягнутими 2 картками.
   minmax(260px, 1fr) забезпечує, що картки не стають надто вузькими. */
.org-contact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.25rem;
    margin-bottom: 1.5rem;
    width: 100%;
}
.org-contact-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    gap: .6rem;
    padding: 2.2rem 1.4rem 2rem;
    background: #fff;
    border: 1px solid var(--org-border);
    border-radius: 14px;
    transition: box-shadow .2s, border-color .2s, transform .2s;
    text-decoration: none;
    color: inherit;
    min-height: 230px;
}
.org-contact-item:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,.07);
    border-color: var(--org-accent);
    text-decoration: none;
    color: inherit;
    transform: translateY(-2px);
}
.org-contact-item--social:hover { border-color: transparent; box-shadow: 0 8px 24px rgba(0,0,0,.1); }
/* Working-Hours card: same layout, multi-line value is natural */
.org-contact-icon {
    width: 62px; height: 62px;
    background: var(--org-accent-light);
    color: var(--org-accent);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
    margin-bottom: .35rem;
}
.org-contact-item__label {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--org-text);
    line-height: 1.3;
    margin-bottom: .15rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    flex-wrap: wrap;
}
.org-contact-item__value {
    font-size: .92rem;
    color: var(--org-text-muted);
    font-weight: 400;
    line-height: 1.5;
    width: 100%;
    word-break: break-word;
}
.org-contact-item__value a { color: var(--org-accent); text-decoration: none; }
.org-contact-item__value a:hover { text-decoration: underline; }
/* Social items: value is the handle */
.org-contact-item--social .org-contact-item__value { color: var(--org-accent); }

/* Tablet: 2 columns */
@media (max-width: 900px) {
    .org-contact-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
}

/* ── Compact hours rows inside card (centered, matching card layout) ─── */
.org-hours-compact-row {
    display: flex;
    justify-content: center;
    align-items: baseline;
    gap: .4rem;
    font-size: .88rem;
    padding: .2rem 0;
}
.org-hours-compact-row__days {
    color: var(--org-text);
    white-space: nowrap;
    font-weight: 500;
}
.org-hours-compact-row__days::after { content: ':'; }
.org-hours-compact-row__time {
    color: var(--org-text-muted);
    font-weight: 400;
    font-variant-numeric: tabular-nums;
}
.org-hours-compact-row__time.is-closed { color: #dc2626; font-weight: 500; }

/* ── Hours edit wrap (owner edit mode only) ─────────────────────────────── */
.org-contact-hours-wrap {
    display: none;
    border-top: 1px solid var(--org-border);
    padding-top: 1.25rem;
    margin-bottom: 1.25rem;
}
body.org-editing .org-contact-hours-wrap { display: block; }
.org-contact-hours-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .85rem;
}
.org-contact-hours-title {
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--org-text-muted);
}

/* ── About ────────────────────────────────────────────────────────────── */
.org_description {
    line-height: 1.7;
    color: var(--org-text);
    font-size: 1.0625rem;
    border-left: 3px solid var(--org-accent-light);
    padding-left: 1.1rem;
    margin: 0;
    position: relative;
}
/* When collapsed by readmore.js, add a fade-out at the bottom so text
   doesn't get hard-cut mid-sentence. Readmore adds inline max-height on
   the element when collapsed — we piggyback on that via :not(.expanded). */
.org_description[data-readmore] {
    -webkit-mask-image: linear-gradient(180deg, #000 70%, transparent 100%);
            mask-image: linear-gradient(180deg, #000 70%, transparent 100%);
}
.org_description[data-readmore][aria-expanded="true"] {
    -webkit-mask-image: none;
            mask-image: none;
}

/* Button-like read-more trigger (more obvious than a plain link) */
.org-readmore-btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin-top: .9rem;
    padding: .4rem .9rem;
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 600;
    background: var(--org-accent-light);
    color: var(--org-accent);
    border: 1px solid transparent;
    text-decoration: none !important;
    transition: background .15s, color .15s, border-color .15s;
}
.org-readmore-btn:hover {
    background: #fff;
    border-color: var(--org-accent);
    color: var(--org-accent);
    text-decoration: none;
}
.org-readmore-btn i { font-size: .78rem; }
.org-readmore-btn--less { background: #f1f5f9; color: #475569; }
.org-readmore-btn--less:hover { background: #e2e8f0; border-color: #cbd5e1; color: #334155; }
.org-view-placeholder { display: block; white-space: pre-wrap; }

/* ── Services grid ────────────────────────────────────────────────────── */
.org-profile__services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
    margin-bottom: .75rem;
}

.org-profile__service-card {
    background: var(--org-card-bg);
    border: 1px solid var(--org-border);
    border-radius: 12px;
    padding: 1.2rem 1.2rem 1.1rem;
    position: relative;
    transition: box-shadow .15s, border-color .15s, transform .15s;
    display: flex;
    flex-direction: column;
    gap: .35rem;
}
.org-profile__service-icon {
    width: 42px; height: 42px;
    border-radius: 10px;
    background: var(--org-accent-light);
    color: var(--org-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    margin-bottom: .2rem;
}
.org-profile__service-card:hover {
    box-shadow: 0 4px 16px rgba(74,124,246,.10);
    border-color: var(--org-accent);
    transform: translateY(-1px);
}

.org-profile__service-name {
    font-weight: 700;
    font-size: 1rem;
    color: var(--org-text);
    margin-bottom: .1rem;
    line-height: 1.35;
}
.org-profile__service-desc {
    font-size: .82rem;
    color: var(--org-text-muted);
    margin-bottom: .3rem;
    line-height: 1.45;
}
/* Price as a subtle pill at the bottom (not competing with name) */
.org-profile__service-price {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    background: #f3f4f6;
    color: #1f2937;
    border-radius: 999px;
    padding: 3px 10px;
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .01em;
    align-self: flex-start;
}

.org-service-delete-btn {
    position: absolute; top: 6px; right: 8px;
    background: none; border: none; color: #ef4444;
    font-size: 1.1rem; cursor: pointer; display: none;
    line-height: 1; padding: 0;
    opacity: .6; transition: opacity .15s;
}
body.org-editing .org-service-delete-btn { display: flex; }
.org-service-delete-btn:hover { opacity: 1; }

.org-service-add-form { margin-top: .75rem; }
.org-service-add-form__inner {
    background: #f9fafb;
    border: 1px dashed var(--org-border);
    border-radius: var(--org-radius-sm);
    padding: 1rem;
}

/* ── Team ─────────────────────────────────────────────────────────────── */
.org-profile__team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 1rem;
}

.org-profile__team-member {
    display: grid;
    grid-template-rows: auto auto auto 1fr;
    text-align: center;
    background: #f9fafb;
    border-radius: var(--org-radius-sm);
    padding: 1.2rem .9rem 1.1rem;
    border: 1px solid var(--org-border);
    transition: box-shadow .15s, transform .15s, border-color .15s;
}
.org-profile__team-member:hover {
    box-shadow: 0 6px 18px rgba(0,0,0,.08);
    transform: translateY(-2px);
    border-color: var(--org-accent-light);
}

.org-profile__team-photo {
    width: 72px; height: 72px;
    border-radius: 50%;
    object-fit: cover;
    margin: 0 auto .6rem;
    display: block;
    border: 3px solid #fff;
    box-shadow: 0 2px 8px rgba(15,23,42,.1);
}
/* Legacy placeholder kept for back-compat (no longer rendered by template) */
.org-profile__team-photo-placeholder {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: var(--org-accent-light);
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; color: var(--org-accent);
    margin: 0 auto .6rem;
}
/* Monogram avatar — deterministic color gradient + initials */
.org-profile__team-monogram {
    width: 72px; height: 72px;
    border-radius: 50%;
    margin: 0 auto .6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: 1.4rem;
    letter-spacing: .02em;
    border: 3px solid #fff;
    box-shadow: 0 2px 8px rgba(15,23,42,.12);
    font-family: var(--org-sans, system-ui, sans-serif);
    user-select: none;
}
.org-profile__team-name {
    font-weight: 700;
    font-size: .95rem;
    line-height: 1.3;
    color: var(--org-text);
    min-height: 2.6em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.org-profile__team-role {
    font-size: .78rem;
    font-weight: 500;
    color: var(--org-accent);
    margin-top: .25rem;
    min-height: 2.2em;
    display: flex;
    align-items: center;
    justify-content: center;
}
.org-profile__team-spec {
    font-size: .78rem;
    color: var(--org-text-muted);
    margin-top: .3rem;
    line-height: 1.45;
    align-self: end;
}

/* ── Gallery Viewer ────────────────────────────────────────────────────── */
.org-gallery-viewer {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .7rem;
    margin-bottom: .75rem;
}

/* Main image — near-full width with small margins */
.org-gallery-main {
    width: calc(100% - 64px);
    border-radius: var(--org-radius);
    overflow: hidden;
    background: #f3f4f6;
    cursor: pointer;
    position: relative;
    box-shadow: 0 2px 16px rgba(0,0,0,.1);
}
.org-gallery-main-img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    display: block;
    transition: opacity .18s;
}
.org-gallery-main:hover .org-gallery-main-img { opacity: .93; }

/* Prev / Next arrows */
.org-gallery-nav {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    background: rgba(0,0,0,.45);
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 42px; height: 42px;
    font-size: 1.7rem;
    line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    opacity: .85;
    transition: opacity .15s, background .15s;
    z-index: 2;
}
.org-gallery-nav:hover { background: rgba(0,0,0,.72); opacity: 1; }
.org-gallery-nav--prev { left: 12px; }
.org-gallery-nav--next { right: 12px; }

/* Thumbnail strip — single centered row, horizontal scroll */
.org-gallery-thumbs-wrap {
    width: calc(100% - 64px);
    display: flex;
    justify-content: center;
}
.org-gallery-thumbs {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    gap: .45rem;
    overflow-x: auto;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 4px 2px;
    max-width: 100%;
}
.org-gallery-thumbs::-webkit-scrollbar { display: none; }

.org-gallery-thumb {
    width: 76px;
    height: 76px;
    border-radius: var(--org-radius-sm);
    overflow: hidden;
    position: relative;
    cursor: pointer;
    flex-shrink: 0;
    border: 2.5px solid transparent;
    transition: border-color .15s, opacity .15s, transform .15s;
    background: #f3f4f6;
    opacity: .72;
}
.org-gallery-thumb.is-active {
    border-color: var(--org-accent);
    opacity: 1;
    transform: scale(1.05);
}
.org-gallery-thumb:hover { opacity: 1; }
.org-gallery-thumb-img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}

.org-gallery-delete-btn {
    position: absolute; top: 5px; right: 5px;
    background: rgba(239,68,68,.85); color: #fff;
    border: none; border-radius: 50%;
    width: 22px; height: 22px;
    display: none; align-items: center; justify-content: center;
    font-size: .9rem; cursor: pointer; line-height: 1;
    transition: background .15s;
}
body.org-editing .org-gallery-delete-btn { display: flex; }
.org-gallery-delete-btn:hover { background: #dc2626; }

.org-gallery-upload-area { display: none; }
body.org-editing .org-gallery-upload-area { display: block; }
.org-gallery-upload-area {
    border: 2px dashed var(--org-border);
    border-radius: var(--org-radius-sm);
    background: #fafbfc;
    transition: border-color .2s, background .2s;
}
.org-gallery-upload-label {
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 6px; padding: 20px 16px;
    cursor: pointer; text-align: center;
}
.org-gallery-upload-label i { font-size: 1.8rem; color: #9ca3af; }
.org-gallery-upload-label__main { font-weight: 600; color: var(--org-accent); font-size: .9rem; }
.org-gallery-upload-label__sub { font-size: .78rem; color: #9ca3af; }
.org-gallery-upload-area:hover,
.org-gallery-upload-label:hover { border-color: var(--org-accent); background: var(--org-accent-light); }
.org-gallery-upload-area.drag-over,
.org-gallery-upload-label.drag-over { border-color: var(--org-accent); background: var(--org-accent-light); }
.org-gallery-upload-footer {
    display: flex; align-items: center; gap: 10px;
    padding: 6px 14px 12px; flex-wrap: wrap;
}
.org-gallery-upload-area--limit { padding: 12px 16px; color: #6b7280; font-size: .88rem; }

/* ── Photos Modal ─────────────────────────────────────────────────────── */
.org-photos-modal.modal-dialog { margin: 1.5vh auto; max-width: 92vw; height: 95vh; }
.org-photos-modal .modal-content { border-radius: 12px; border: none; height: 100%; display: flex; flex-direction: column; overflow: hidden; }
.org-photos-modal .modal-body { overflow-y: auto; flex: 1 1 auto; }
.org-photos-modal .modal-header { flex-shrink: 0; }
.org-photos-modal__header {
    background: #fff;
    border-bottom: 1px solid var(--org-border);
    padding: 1rem 1.25rem;
    gap: .75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
}
.org-photos-modal__header .btn-close {
    margin-left: auto;
    flex-shrink: 0;
}
.org-photos-modal__header .modal-title {
    font-size: 1rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.org-photos-modal__count { color: var(--org-text-muted); font-weight: 400; font-size: .9rem; }
.org-photos-modal__add-btn { margin-left: auto; flex-shrink: 0; }
.org-photos-modal__body { padding: 1.25rem; background: #f8f9fa; }

/* Photo grid */
.org-photos-modal__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 8px;
}
.org-photos-modal__item {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 8px;
    cursor: pointer;
    background: #e5e7eb;
}
.org-photos-modal__item img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .25s ease;
}
.org-photos-modal__item:hover img { transform: scale(1.04); }

.org-photos-modal__delete {
    position: absolute;
    top: 6px; right: 6px;
    width: 26px; height: 26px;
    background: rgba(220,38,38,.85);
    border: none;
    border-radius: 50%;
    color: #fff;
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 5;
    transition: background .15s;
}
.org-photos-modal__delete:hover { background: #dc2626; }
body.org-editing .org-photos-modal__delete { display: flex; }

@media (max-width: 575.98px) {
    .org-photos-modal__grid { grid-template-columns: repeat(2, 1fr); gap: 5px; }
}

/* ── Reviews ──────────────────────────────────────────────────────────── */

/* Rating summary (avg score + bar chart) */
.org-profile__review-summary {
    display: flex;
    gap: 2rem;
    margin-bottom: 2rem;
    padding: 1.25rem 1.5rem;
    background: var(--org-warm-section);
    border-radius: var(--org-radius-sm);
    align-items: center;
    border: 1px solid var(--org-border);
}
.org-profile__review-avg { text-align: center; flex-shrink: 0; }
.org-profile__review-avg-number { font-family: var(--org-serif); font-size: 3.2rem; font-weight: 700; color: var(--org-text); line-height: 1; }
.org-profile__review-avg-stars  { font-size: 1.2rem; color: var(--org-gold); letter-spacing: 2px; }
.org-profile__review-avg-count  { font-size: .8rem; color: var(--org-text-muted); margin-top: .25rem; }
.org-profile__review-bars       { flex: 1; display: flex; flex-direction: column; gap: .4rem; }
.org-profile__review-bar        { display: flex; align-items: center; gap: .5rem; }
.org-profile__review-bar-label  { font-size: .78rem; color: var(--org-text-muted); width: 24px; text-align: right; flex-shrink: 0; }
.org-profile__review-bar-track  { flex: 1; height: 6px; background: #e0d9d0; border-radius: 3px; overflow: hidden; }
.org-profile__review-bar-fill   { height: 100%; background: var(--org-gold); border-radius: 3px; transition: width .4s; }
.org-profile__review-bar-count  { font-size: .75rem; color: var(--org-text-muted); width: 20px; }

/* ── Compact 3-column review cards ──────────────────────────────────
   Keep cards scannable — clamp long reviews to 6 lines with fade-out;
   click card to expand. Tighter padding + smaller quote-mark decoration.
   ──────────────────────────────────────────────────────────────────── */
.org-reviews-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: 2rem;
}

.org-review-card {
    background: var(--org-card-bg);
    border: 1px solid var(--org-border);
    border-radius: var(--org-radius-sm);
    padding: 1.1rem 1.15rem .9rem;
    display: flex;
    flex-direction: column;
    position: relative;
    box-shadow: var(--org-shadow);
    transition: box-shadow .2s;
    overflow: hidden;
}
.org-review-card:hover { box-shadow: var(--org-shadow-hover); }

/* Decorative quote mark — smaller, more subtle */
.org-review-card__quote-mark {
    position: absolute;
    top: .35rem;
    right: .85rem;
    font-family: var(--org-serif);
    font-size: 1.8rem;
    line-height: 1;
    color: #e5e7eb;
    opacity: .45;
    pointer-events: none;
    user-select: none;
}

.org-review-card__stars {
    color: var(--org-gold);
    font-size: .9rem;
    letter-spacing: 2px;
    margin-bottom: .6rem;
}

/* Body text: clamp to ~6 lines with fade. Expanded by adding .is-expanded. */
.org-review-card__text {
    color: #4b4b4b;
    font-size: .95rem;
    line-height: 1.55;
    flex: 1;
    margin-bottom: .75rem;
    position: relative;
    display: -webkit-box;
    -webkit-line-clamp: 6;
    -webkit-box-orient: vertical;
    overflow: hidden;
    cursor: pointer;
}
.org-review-card__text.is-expanded {
    display: block;
    -webkit-line-clamp: unset;
    cursor: default;
}
.org-review-card__text:not(.is-expanded)::after {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 2.2em;
    background: linear-gradient(to bottom, rgba(255,255,255,0), var(--org-card-bg));
    pointer-events: none;
}

.org-review-card__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: .8rem;
    border-top: 1px solid #f0ebe3;
    margin-top: auto;
}

.org-review-card__author {
    font-weight: 600;
    font-size: .85rem;
    color: var(--org-text);
}

.org-review-card__meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}
.org-review-card__date {
    font-size: .72rem;
    color: #9ca3af;
}
.org-review-card__source {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #9ca3af;
    display: flex;
    align-items: center;
    gap: 3px;
}

/* "Review us on Google" CTA button */
.org-reviews-google-cta {
    display: flex;
    justify-content: center;
    margin-bottom: 2rem;
}
.org-reviews-google-cta a {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    border: 2px solid #dadce0;
    border-radius: 28px;
    padding: .55rem 1.5rem;
    font-weight: 600;
    font-size: .88rem;
    color: var(--org-text);
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s;
    background: #fff;
}
.org-reviews-google-cta a:hover {
    border-color: var(--org-accent);
    box-shadow: 0 2px 8px rgba(74,124,246,.12);
}

/* ── Reviews list ──────────────────────────────────────────────────────── */
/* All-reviews heading */
.org-reviews-unified h6 {
    font-family: var(--org-serif);
    font-size: 1rem;
    font-weight: 600;
}

/* Leave-a-review form */
.org-review-form {
    background: var(--org-bg);
    border: 1px solid var(--org-border);
    border-radius: var(--org-radius-sm);
    padding: .95rem 1.1rem;
    margin-bottom: 1.25rem;
}

/* Star input labels */
.org-star-label { font-size: 1.5rem; color: #d1d5db; cursor: pointer; transition: color .1s; }
.org-star-label.active, .org-star-label.hovered { color: var(--org-gold); }

/* Individual review item — separator style, no Bootstrap card */
.org-review-item {
    padding: .9rem 0;
    border-bottom: 1px solid var(--org-border);
}
.org-review-item:last-child { border-bottom: none; }

/* Reviewer avatar circle */
.org-reviewer-avatar {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--org-accent), #8b5cf6);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem; font-weight: 700;
    flex-shrink: 0;
}

/* Source badge (Animal-ID / Google) */
.org-review-source {
    font-size: .65rem;
    background: #f1f3f4;
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--org-text-muted);
}

/* Owner response block */
.org-owner-response {
    margin-top: .6rem;
    padding: .6rem .85rem;
    background: var(--org-accent-light);
    border-left: 3px solid var(--org-accent);
    border-radius: 0 var(--org-radius-sm) var(--org-radius-sm) 0;
}

/* Guest / info notice */
.org-review-notice {
    display: flex;
    align-items: center;
    gap: .7rem;
    flex-wrap: wrap;
    background: var(--org-bg);
    border: 1px solid var(--org-border);
    border-radius: var(--org-radius-sm);
    padding: .85rem 1.1rem;
    font-size: .88rem;
    color: var(--org-text-muted);
    margin-bottom: 1rem;
}
.org-review-notice > i { color: var(--org-text-muted); font-size: 1rem; }
.org-review-notice__text { flex: 1; min-width: 0; }
.org-review-notice__login {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .4rem 1rem;
    border-radius: 999px;
    background: var(--org-accent);
    color: #fff;
    font-weight: 600;
    font-size: .82rem;
    text-decoration: none;
    transition: background .15s, transform .15s;
}
.org-review-notice__login:hover {
    background: var(--org-accent-dark, #3b82f6);
    color: #fff;
    text-decoration: none;
    transform: translateY(-1px);
}
@media (max-width: 575.98px) {
    .org-review-notice { flex-direction: column; align-items: flex-start; }
    .org-review-notice__login { width: 100%; justify-content: center; }
}

/* ── Hours ────────────────────────────────────────────────────────────── */
.org-hours-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 20px;
    padding: 5px 14px;
    font-size: .78rem;
    font-weight: 600;
    flex-shrink: 0;
}
.org-hours-badge--open  { background: #d1fae5; color: #059669; }
.org-hours-badge--closed { background: #fee2e2; color: #dc2626; }

.org-hours-badge__dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
    animation: hours-pulse 2s ease-in-out infinite;
}
.org-hours-badge--open  .org-hours-badge__dot { background: #059669; }
.org-hours-badge--closed .org-hours-badge__dot { background: #dc2626; animation: none; }
@keyframes hours-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: .6; transform: scale(.85); }
}

.org-hours-badge__time {
    font-weight: 500;
    border-left: 1px solid rgba(5,150,105,.3);
    padding-left: 7px;
    margin-left: 1px;
}

/* ── 7-day week strip ──────────────────────────────────────────────────── */
/* ── Hours list (Google-style) ───────────────────────────────────── */
.org-hours-list {
    display: flex;
    flex-direction: column;
    max-width: 480px;
}

.org-hours-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: .55rem 0;
    border-bottom: 1px solid var(--org-border);
    font-size: .9rem;
}
.org-hours-row:last-child { border-bottom: none; }

.org-hours-row__day {
    width: 42px;
    flex-shrink: 0;
    font-weight: 400;
    color: var(--org-text-muted);
    font-size: .88rem;
}

.org-hours-row--today .org-hours-row__day {
    font-weight: 700;
    color: var(--org-text);
}

.org-hours-row__time {
    flex: 1;
    font-variant-numeric: tabular-nums;
    color: var(--org-text);
    font-size: .88rem;
}
.org-hours-row--today .org-hours-row__time {
    font-weight: 600;
}
.org-hours-row__time--closed {
    color: var(--org-text-muted);
}

.org-hours-row__now {
    font-size: .78rem;
    font-weight: 600;
    color: #059669;
    white-space: nowrap;
}

.org-inline-time { width: 110px; }

/* ── Contact ──────────────────────────────────────────────────────────── */
.org-profile__contact-list {
    list-style: none;
    padding: 0; margin: 0 0 .75rem;
    display: flex; flex-direction: column; gap: .5rem;
}
.org-profile__contact-list li {
    display: flex; align-items: center; gap: .7rem;
    font-size: .9rem; color: var(--org-text-muted);
}
.org-profile__contact-list li i { color: var(--org-accent); flex-shrink: 0; font-size: 1rem; }
.org-profile__contact-list a { color: inherit; text-decoration: none; }
.org-profile__contact-list a:hover { color: var(--org-accent); }
.org-profile__contact-list--social li { gap: 8px; }
.org-social-edit__title {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #9ca3af;
    margin-bottom: 6px;
}
.org-inline-social { font-size: .875rem !important; }

/* ── Contact block edit/view toggle ─────────────────────────────────── */
.org-contact-edit-wrap  { display: none; }
body.org-editing .org-contact-edit-wrap  { display: block; }
body.org-editing .org-contact-view-wrap  { display: none; }
body.org-editing .org-social-list        { display: none; }

.org-profile__social-links { display: flex; gap: .5rem; flex-wrap: wrap; }
.org-profile__social-icon {
    width: 36px; height: 36px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    font-size: 1rem;
    transition: transform .15s, opacity .15s;
    color: #fff;
}
.org-profile__social-icon:hover { transform: scale(1.12); opacity: .9; }
.org-profile__social-icon--fb { background: #1877f2; }
.org-profile__social-icon--ig { background: linear-gradient(135deg,#e1306c,#fd1d1d,#833ab4); }
.org-profile__social-icon--tg { background: #2aabee; }
.org-profile__social-icon--yt { background: #ff0000; }
.org-profile__social-icon--tw { background: #000; }

/* ── Social list (contact block) — @handle style ─────────────────────── */
.org-social-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .85rem;
    width: 100%;
}
/* Social item styled like org-contact-item */
.org-social-list__item {
    display: flex;
    align-items: flex-start;
    gap: .9rem;
    padding: .95rem 1.1rem;
    background: transparent;
    border: 1px solid var(--org-border);
    border-radius: var(--org-radius-sm);
    transition: box-shadow .15s, border-color .15s;
    flex: 0 0 260px;
    width: 260px;
    text-decoration: none !important;
    color: inherit;
}
.org-social-list__item:hover {
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
    border-color: var(--org-accent);
    text-decoration: none !important;
}
.org-social-list__icon {
    width: 38px; height: 38px;
    border-radius: 9px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
    color: #fff;
}
.org-social-list__info { display: flex; flex-direction: column; min-width: 0; }
.org-social-list__label {
    font-size: .67rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--org-text-muted);
    margin-bottom: .2rem;
}
.org-social-list__handle {
    font-size: .9rem;
    font-weight: 500;
    color: var(--org-accent);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
/* Icon colors */
.org-social-list__item--ig .org-social-list__icon { background: linear-gradient(135deg,#e1306c,#fd1d1d,#833ab4); }
.org-social-list__item--tg .org-social-list__icon { background: #2aabee; }
.org-social-list__item--tt .org-social-list__icon { background: #010101; }
.org-social-list__item--fb .org-social-list__icon { background: #1877f2; }
.org-social-list__item--yt .org-social-list__icon { background: #ff0000; }
.org-social-list__item--tw .org-social-list__icon { background: #000; }

/* ── Map ──────────────────────────────────────────────────────────────── */
.org-profile__map {
    width: 100%;
    height: 540px;
    min-height: 420px;
    border-radius: 0;
    background: #f3f4f6;
    border: none;
    display: block;
}

/* ── Breeds ──────────────────────────────────────────────────────────── */
.org-profile__breeds-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: .65rem;
}
.org-profile__breed-item {
    display: flex;
    align-items: flex-start;
    gap: .7rem;
    background: #fff;
    border: 1.5px solid var(--org-border);
    border-radius: 10px;
    padding: .7rem .85rem;
    transition: border-color .15s, box-shadow .15s;
    position: relative;
}
.org-profile__breed-item:hover {
    border-color: var(--org-accent);
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.org-profile__breed-icon {
    width: 32px; height: 32px;
    flex-shrink: 0;
    background: var(--org-accent-light);
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    color: var(--org-accent);
    font-size: 1rem;
}
.org-profile__breed-info { flex: 1; min-width: 0; }
.org-profile__breed-tag {
    display: block;
    font-weight: 600;
    font-size: .88rem;
    color: var(--org-text);
    line-height: 1.3;
}
.org-profile__breed-desc {
    display: block;
    font-size: .77rem;
    color: var(--org-text-muted);
    margin-top: .15rem;
    line-height: 1.4;
}

/* ── Available Animals grid ──────────────────────────────────────────── */
/* ── Animals slider ── */
/* ── Animals carousel ── */
/* ── Animals carousel ── */
/* ── Animals carousel — overlay arrows ── */
.org-animals-carousel {
    position: relative;
}

/* Overlay arrow buttons */
.org-carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 48px; height: 48px;
    border: none;
    background: rgba(255,255,255,.92);
    border-radius: 50%;
    cursor: pointer;
    font-size: 1.6rem;
    line-height: 1;
    display: flex; align-items: center; justify-content: center;
    transition: background .15s, box-shadow .15s, opacity .2s, transform .15s;
    color: var(--org-text);
    padding: 0;
    box-shadow: 0 4px 18px rgba(0,0,0,.28), 0 1px 4px rgba(0,0,0,.12);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.org-carousel-btn[data-dir="-1"] { left: 10px; }
.org-carousel-btn[data-dir="1"]  { right: 10px; }

.org-carousel-btn:hover {
    background: #fff;
    box-shadow: 0 6px 24px rgba(0,0,0,.32), 0 2px 6px rgba(0,0,0,.15);
    transform: translateY(-50%) scale(1.08);
}
.org-carousel-btn.is-hidden {
    opacity: 0;
    pointer-events: none;
    visibility: hidden; /* disables backdrop-filter so it doesn't clip first card */
}

/* Slider — full width, scrollable */
.org-animals-slider {
    overflow-x: auto;
    overflow-y: visible;
    width: 100%;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    min-height: 300px; /* prevents layout shift while card photos lazy-load */
}
.org-animals-slider::-webkit-scrollbar { display: none; }

.org-animals-grid {
    display: grid;
    grid-template-rows: 1fr;
    grid-auto-flow: column;
    grid-auto-columns: 220px;
    gap: 1rem;
    justify-content: center;
    padding: .25rem 0 .5rem; /* breathing room for box-shadow on cards */
}
.org-animals-grid > * { scroll-snap-align: start; }

/* ── Mobile ── */
@media (max-width: 767px) {
    .org-carousel-btn { width: 38px; height: 38px; font-size: 1.3rem; }
    .org-carousel-btn[data-dir="-1"] { left: 4px; }
    .org-carousel-btn[data-dir="1"]  { right: 4px; }
    .org-animals-grid { grid-auto-columns: calc(50vw - 2.5rem); gap: .75rem; justify-content: start; }
}
.org-animal-card {
    background: #fff;
    border: 1px solid var(--org-border);
    border-radius: var(--org-radius-sm);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: box-shadow .15s, transform .15s;
    display: flex;
    flex-direction: column;
}
.org-animal-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,.1);
    transform: translateY(-2px);
    text-decoration: none;
    color: inherit;
}
.org-animal-card__photo {
    position: relative;
    aspect-ratio: 1 / 1;
    background: #f3f4f6;
    overflow: hidden;
}
.org-animal-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.org-animal-card__no-photo {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    font-size: 2.5rem;
    color: #d1d5db;
}
/* Monogram fallback: deterministic hue tile with first letter of nickname */
.org-animal-card__monogram {
    --mh: 210;
    position: absolute; inset: 0;
    display: grid; place-items: center;
    background:
        radial-gradient(circle at 30% 20%, hsla(var(--mh),70%,88%,1) 0%, hsla(var(--mh),55%,72%,1) 70%, hsla(var(--mh),55%,60%,1) 100%);
    overflow: hidden;
}
.org-animal-card__monogram::after {
    /* subtle noise-free texture to avoid flat look */
    content: '';
    position: absolute; inset: -20%;
    background:
        radial-gradient(circle at 80% 85%, hsla(var(--mh),80%,85%,.55) 0%, transparent 45%),
        radial-gradient(circle at 15% 90%, hsla(var(--mh),70%,50%,.25) 0%, transparent 55%);
    pointer-events: none;
}
.org-animal-card__monogram-letter {
    font-family: ui-sans-serif, system-ui, -apple-system, sans-serif;
    font-size: 3.4rem;
    font-weight: 700;
    line-height: 1;
    color: #fff;
    text-shadow: 0 2px 6px hsla(var(--mh),50%,25%,.25);
    letter-spacing: -.02em;
    z-index: 1;
}
.org-animal-card__monogram-emoji {
    position: absolute;
    right: .5rem; bottom: .4rem;
    font-size: 1.05rem;
    opacity: .85;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,.15));
    z-index: 1;
}
.org-animal-card__badge {
    position: absolute;
    top: 8px; left: 8px;
    font-size: .68rem;
    font-weight: 700;
    border-radius: 999px;
    padding: 3px 9px;
    letter-spacing: .02em;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    box-shadow: 0 1px 4px rgba(0,0,0,.08);
    z-index: 2;
}
.org-animal-card__badge--adoption {
    background: rgba(220, 252, 231, .94);
    color: #15803d;
}
.org-animal-card__badge--baby {
    background: rgba(254, 249, 195, .94);
    color: #a16207;
}
.org-animal-card__info {
    padding: .5rem .65rem .6rem;
    display: flex;
    flex-direction: column;
    gap: .15rem;
}
.org-animal-card__name {
    font-size: .88rem;
    font-weight: 600;
    color: var(--org-text);
    /* 2-line clamp: kennel names like "KING OF FLOWERS IZ VERSAVII" mustn't truncate mid-word */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.2;
    min-height: calc(.88rem * 1.2 * 2); /* reserve 2 lines → prevents card height jitter */
    word-break: break-word;
}
.org-animal-card__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .25rem;
}
.org-animal-card__breed {
    font-size: .75rem;
    color: var(--org-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
    /* normalize inconsistent source casing: "GERMAN SPITZ TOY" / "german spitz toy" */
    text-transform: lowercase;
}
.org-animal-card__breed::first-letter {
    text-transform: uppercase;
}
.org-animal-card__age {
    font-size: .72rem;
    color: #9ca3af;
    flex-shrink: 0;
    white-space: nowrap;
}
@media (max-width: 480px) {
    /* tablet handled by mobile block above */
}

/* ── Breadcrumbs mobile overflow fix ── */
@media (max-width: 575px) {
    .breadcrumb {
        flex-wrap: nowrap;
        overflow: hidden;
        font-size: .8rem;
    }
    .breadcrumb .breadcrumb-item {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        min-width: 0;
    }
    .breadcrumb .breadcrumb-item:last-child {
        flex: 1 1 auto;
        max-width: 60vw;
    }
    .breadcrumb .breadcrumb-item:not(:last-child) {
        flex-shrink: 0;
    }
}

/* ── Events — calendar-icon style ── */
.org-profile__events-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.org-profile__event-card {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1rem 0;
    border-bottom: 1px solid var(--org-border);
    background: none;
    border-radius: 0;
}
.org-profile__event-card:first-child { padding-top: .25rem; }
.org-profile__event-card:last-child  { border-bottom: none; padding-bottom: .25rem; }

/* Calendar icon block */
.org-profile__event-icon {
    width: 52px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    background: #fff;
    border: 1.5px solid var(--org-border);
    border-radius: 10px;
    overflow: hidden;
    text-align: center;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.org-profile__event-icon__month {
    background: var(--org-accent);
    color: #fff;
    font-size: .6rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    width: 100%;
    padding: 2px 0;
}
.org-profile__event-icon__day {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--org-text);
    line-height: 1;
    padding: 4px 0 5px;
    font-family: var(--org-serif);
}

.org-profile__event-body      { flex: 1; min-width: 0; }
.org-profile__event-title     { font-weight: 600; font-size: .93rem; color: var(--org-text); margin-bottom: .15rem; line-height: 1.35; }
.org-profile__event-location  { font-size: .8rem; color: var(--org-text-muted); margin-top: .1rem; display: flex; align-items: center; gap: .3rem; }
.org-profile__event-desc      { font-size: .82rem; color: var(--org-text-muted); margin-top: .3rem; line-height: 1.5; }
.org-profile__event-date-full { font-size: .78rem; color: var(--org-text-muted); margin-bottom: .2rem; }

/* ── Certifications — card grid with top accent ── */
.org-profile__certs-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}
.org-profile__cert-card {
    position: relative;
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1.1rem 1.1rem 1rem;
    background: #fff;
    border: 1px solid var(--org-border);
    border-top: 3px solid var(--org-accent);
    border-radius: 10px;
    box-shadow: 0 1px 2px rgba(15,23,42,.04);
    transition: box-shadow .15s, transform .15s;
}
.org-profile__cert-card:hover {
    box-shadow: 0 6px 18px rgba(15,23,42,.07);
    transform: translateY(-1px);
}
.org-profile__cert-card--soon    { border-top-color: #d97706; }
.org-profile__cert-card--expired { border-top-color: #dc2626; opacity: .75; }

.org-profile__cert-icon {
    width: 46px; height: 46px;
    flex-shrink: 0;
    background: #ecfdf5;
    border: 1px solid #bbf7d0;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: #059669;
    font-size: 1.4rem;
}
.org-profile__cert-card--soon .org-profile__cert-icon    { background: #fffbeb; border-color: #fde68a; color: #d97706; }
.org-profile__cert-card--expired .org-profile__cert-icon { background: #fef2f2; border-color: #fecaca; color: #dc2626; }

.org-profile__cert-body { flex: 1; min-width: 0; }
.org-profile__cert-title {
    font-weight: 700;
    font-size: .95rem;
    color: var(--org-text);
    margin-bottom: .2rem;
    line-height: 1.35;
}
.org-profile__cert-issuer {
    font-size: .82rem;
    color: var(--org-text-muted);
    margin-bottom: .55rem;
}
.org-profile__cert-dates {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    margin-bottom: .5rem;
}
.org-profile__cert-date-pill {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: 2px 9px;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 600;
    background: #f1f5f9;
    color: #475569;
    border: 1px solid #e2e8f0;
}
.org-profile__cert-date-pill i { font-size: .72rem; }
.org-profile__cert-date-pill--ok      { background: #ecfdf5; color: #047857; border-color: #bbf7d0; }
.org-profile__cert-date-pill--soon    { background: #fffbeb; color: #92400e; border-color: #fde68a; }
.org-profile__cert-date-pill--expired { background: #fef2f2; color: #991b1b; border-color: #fecaca; }

.org-profile__cert-link {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: .8rem; font-weight: 500;
    color: var(--org-accent);
    text-decoration: none;
    border: 1px solid var(--org-accent);
    border-radius: 20px;
    padding: .2rem .65rem;
    transition: background .15s, color .15s;
}
.org-profile__cert-link:hover {
    background: var(--org-accent);
    color: #fff;
    text-decoration: none;
}

.org-profile__animals-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: .75rem;
}
.org-profile__animal-card {
    text-decoration: none; color: inherit;
    background: #f9fafb; border: 1px solid var(--org-border);
    border-radius: var(--org-radius-sm); overflow: hidden;
    transition: box-shadow .15s;
}
.org-profile__animal-card:hover { box-shadow: var(--org-shadow-hover); }
.org-profile__animal-photo img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; }
.org-profile__animal-info { padding: .5rem .75rem; }
.org-profile__animal-name  { font-weight: 600; font-size: .88rem; }
.org-profile__animal-breed { font-size: .75rem; color: var(--org-text-muted); }

/* ── Promos ───────────────────────────────────────────────────────────── */
.org-promos-grid {
    display: flex;
    flex-direction: column;
    gap: .85rem;
}

.org-promo-card {
    display: grid;
    grid-template-columns: 96px 1fr;
    gap: 1.1rem;
    background: linear-gradient(135deg, #fffbeb 0%, #fff9f0 100%);
    border: 1px solid #fde68a;
    border-radius: 12px;
    padding: 1.1rem 1.25rem 1rem;
    position: relative;
    overflow: hidden;
    transition: box-shadow .15s, border-color .15s;
}
@media (max-width: 575.98px) {
    .org-promo-card { grid-template-columns: 64px 1fr; gap: .85rem; padding: .9rem 1rem; }
}
.org-promo-card__pic {
    position: relative;
    width: 80px; height: 80px;
    border-radius: 10px;
    background: #fff;
    border: 1px solid #fde68a;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #d97706;
    font-size: 2rem;
    flex-shrink: 0;
    align-self: start;
}
@media (max-width: 575.98px) {
    .org-promo-card__pic { width: 56px; height: 56px; font-size: 1.5rem; }
}
.org-promo-card__percent {
    position: absolute;
    bottom: -8px; right: -8px;
    background: linear-gradient(135deg, #f59e0b, #ea580c);
    color: #fff;
    font-size: .72rem;
    font-weight: 800;
    padding: 3px 8px;
    border-radius: 999px;
    box-shadow: 0 2px 6px rgba(234,88,12,.3);
    border: 2px solid #fff;
    letter-spacing: .02em;
}
.org-promo-card__main { min-width: 0; }
.org-promo-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 4px; height: 100%;
    background: linear-gradient(180deg, #f59e0b, #f97316);
    border-radius: 4px 0 0 4px;
}
.org-promo-card:hover {
    box-shadow: 0 4px 18px rgba(245,158,11,.15);
    border-color: #fbbf24;
}
.org-promo-card--expired {
    opacity: .6;
    filter: grayscale(.35);
}

.org-promo-card__badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    background: linear-gradient(90deg, #f59e0b, #f97316);
    color: #fff;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    padding: 2px 10px;
    border-radius: 20px;
    margin-bottom: .6rem;
}

.org-promo-card__title {
    font-weight: 700;
    font-size: 1rem;
    color: var(--org-text);
    line-height: 1.3;
    margin-bottom: .55rem;
}

.org-promo-card__dates {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .4rem;
    margin-bottom: .65rem;
}

.org-promo-date-pill {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: .75rem;
    font-weight: 600;
    background: rgba(255,255,255,.65);
    color: #78350f;
    border: 1px solid rgba(217,119,6,.25);
}
/* Legacy variants kept for back-compat */
.org-promo-date-pill--from { background: #e0f2fe; color: #0369a1; }
.org-promo-date-pill--to   { background: #dcfce7; color: #15803d; }

.org-promo-arrow {
    color: #9ca3af;
    font-size: .75rem;
}

.org-promo-urgency {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    background: #fee2e2;
    color: #dc2626;
    font-size: .72rem;
    font-weight: 700;
    padding: 3px 9px;
    border-radius: 20px;
    animation: pulse-urgency 1.8s ease-in-out infinite;
}
@keyframes pulse-urgency {
    0%, 100% { opacity: 1; }
    50%       { opacity: .7; }
}

.org-promo-card__desc {
    font-size: .87rem;
    color: #4b4b4b;
    line-height: 1.65;
}

/* ── Pet links ────────────────────────────────────────────────────────── */
.org-profile__pet-links-section { padding: 0; }
.org-profile__pet-links-section .org-profile__section { padding: 1.5rem 1.75rem; }
.org-profile__pet-link-card {
    background: var(--org-card-bg);
    border: 1px solid var(--org-border);
    border-radius: var(--org-radius-sm);
    padding: .85rem 1rem;
    box-shadow: var(--org-shadow);
}

/* ── Inline edit ──────────────────────────────────────────────────────── */
.org-inline-input,
.org-inline-textarea {
    display: none;
    border: 1.5px dashed #adb5bd;
    border-radius: 6px;
    padding: 5px 10px;
    background: #f8f9fa;
    width: 100%;
    font-size: inherit;
    font-family: inherit;
    color: inherit;
    transition: border-color .2s, background .2s;
}
.org-inline-input:focus,
.org-inline-textarea:focus { outline: none; border-color: var(--org-accent); background: #fff; }
.org-inline-title {
    font-size: 1.6rem; font-weight: 700;
    color: var(--org-text);
    background: #f3f4f6;
    border-color: var(--org-border);
}
.org-inline-title:focus { background: #fff; border-color: var(--org-accent); }
.org-inline-textarea { min-height: 100px; resize: vertical; }
body.org-editing .org-inline-input,
body.org-editing .org-inline-textarea { display: block; }
body.org-editing .org-view-placeholder { display: none !important; }

/* ── Inline validation feedback ────────────────────────────────────────
   .is-invalid is applied client-side when a contact field fails the
   pre-save check. The error blurb renders right under the input so the
   owner sees both the wrong field and the reason without scrolling. */
.org-inline-input.is-invalid,
.org-inline-textarea.is-invalid {
    border-color: #dc2626 !important;
    background: #fef2f2;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12);
}
.org-field-error {
    display: block;
    color: #dc2626;
    font-size: 12px;
    line-height: 1.35;
    margin: 4px 0 2px 28px;
}

/* ── Save bar ─────────────────────────────────────────────────────────── */
.org-inline-save-bar {
    display: none;
    position: fixed; bottom: 0; left: 0; right: 0;
    background: rgba(255,255,255,.96);
    border-top: 1px solid var(--org-border);
    padding: 10px 0;
    z-index: 1050;
    box-shadow: 0 -4px 20px rgba(0,0,0,.08);
    backdrop-filter: blur(6px);
}
body.org-editing .org-inline-save-bar { display: block; }

/* Mobile: save bar crowds the floating chat widget at bottom-right.
   Instead of trying to pad around the widget, pull the save bar's right
   edge inward by 84px so its background and content both stop before the
   widget column — chat bubble sits cleanly in that right gutter. Stack
   action/save groups vertically for tap comfort and allow horizontal
   scroll if the action row overflows. */
@media (max-width: 767.98px) {
    .org-inline-save-bar {
        right: 84px;           /* 84px gutter on the right for the chat widget */
        padding: 8px 10px 10px 0;
        border-top-right-radius: 10px;
    }
    .org-inline-save-bar .container {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 8px;
    }
    .org-inline-save-bar .container > div {
        display: flex !important;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }
    .org-inline-save-bar .container > div::-webkit-scrollbar { display: none; }
    .org-inline-save-bar .container > div > * { flex-shrink: 0; }
}

/* ── Lightbox ─────────────────────────────────────────────────────────── */
#org-lb { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.9); z-index: 9000; align-items: center; justify-content: center; flex-direction: column; }
#org-lb.active { display: flex; }
#org-lb img { max-width: 90vw; max-height: 82vh; object-fit: contain; border-radius: 8px; box-shadow: 0 4px 32px rgba(0,0,0,.6); }
#org-lb-caption { color: rgba(255,255,255,.75); font-size: .9rem; margin-top: .6rem; text-align: center; max-width: 80vw; }
.org-lb-close { position: fixed; top: 16px; right: 20px; background: none; border: none; color: #fff; font-size: 2rem; line-height: 1; cursor: pointer; opacity: .8; z-index: 9010; }
.org-lb-close:hover { opacity: 1; }
.org-lb-arrow { position: fixed; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,.15); border: none; color: #fff; font-size: 2rem; line-height: 1; cursor: pointer; padding: 12px 18px; border-radius: 6px; z-index: 9010; transition: background .15s; }
.org-lb-arrow:hover { background: rgba(255,255,255,.3); }
#org-lb-prev { left: 10px; }
#org-lb-next { right: 10px; }
.org-lb-trigger { cursor: pointer; }
.org-lb-trigger img { transition: opacity .15s; }
.org-lb-trigger:hover img { opacity: .85; }

/* ── Map wrapper: full-width breakout ──────────────────────────────────── */
.org-map-wrapper {
    position: relative;
    margin-left: -3rem;
    margin-right: -3rem;
    margin-bottom: 0;
}
@media (max-width: 575.98px) {
    .org-map-wrapper { margin-left: -1rem; margin-right: -1rem; margin-bottom: 0; }
}

/* ── Map location search (edit mode only, owner) ───────────────────────── */
.org-map-location-search {
    margin-top: 14px;
    padding: 0 2px;
}
.org-map-location-search__field {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #f8f9fa;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: 10px 14px;
    transition: border-color .15s, background .15s;
}
.org-map-location-search__field:focus-within {
    background: #fff;
    border-color: var(--org-accent, #57B262);
    box-shadow: 0 0 0 3px rgba(87,178,98,.12);
}
.org-map-location-search__field i {
    color: #6b7280;
    flex-shrink: 0;
    font-size: 16px;
}
.org-map-location-search__input {
    border: 0;
    background: transparent;
    outline: none;
    flex: 1;
    font-size: 14px;
    color: #374151;
}
.org-map-location-search__btn {
    flex-shrink: 0;
    background: var(--org-accent, #57B262);
    color: #fff;
    border: 0;
    border-radius: 6px;
    padding: 6px 16px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s;
}
.org-map-location-search__btn:hover { background: #4a9e54; }
.org-map-location-search__label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    margin-bottom: 6px;
    padding: 0 4px;
}
.org-map-location-search__hint {
    font-size: 12px;
    color: #6b7280;
    margin-top: 6px;
    min-height: 16px;
    padding: 0 4px;
}

.org-map-infocard {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 10;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(0,0,0,.22);
    padding: .7rem .85rem .65rem;
    min-width: 200px;
    max-width: 260px;
    pointer-events: auto;
}

.org-map-infocard__name {
    font-weight: 700;
    font-size: .88rem;
    color: var(--org-text);
    line-height: 1.3;
    margin-bottom: .2rem;
}

.org-map-infocard__addr {
    font-size: .75rem;
    color: var(--org-text-muted);
    line-height: 1.35;
    margin-bottom: .3rem;
}

.org-map-infocard__rating {
    display: flex;
    align-items: center;
    gap: .25rem;
    margin-bottom: .35rem;
}

.org-map-infocard__stars {
    color: #f59e0b;
    font-size: .85rem;
    letter-spacing: .5px;
}

.org-map-infocard__score {
    font-size: .8rem;
    font-weight: 700;
    color: var(--org-text);
}

.org-map-infocard__count {
    font-size: .75rem;
    color: var(--org-text-muted);
}

.org-map-infocard__actions {
    display: flex;
    gap: .4rem;
    margin-top: .1rem;
}

.org-map-infocard__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--org-bg);
    border: 1px solid var(--org-border);
    color: var(--org-text-muted);
    font-size: .8rem;
    transition: background .15s, color .15s, border-color .15s;
    text-decoration: none;
}

.org-map-infocard__link:hover {
    background: var(--org-accent-light);
    color: var(--org-accent);
    border-color: var(--org-accent);
}

.org-map-infocard__link--dir {
    background: var(--org-accent);
    border-color: var(--org-accent);
    color: #fff;
}

.org-map-infocard__link--dir:hover {
    background: var(--org-accent-dark, #3b5fc0);
    border-color: var(--org-accent-dark, #3b5fc0);
    color: #fff;
}

/* ── Sticky section nav ───────────────────────────────────────────────── */
#org-page-nav {
    position: sticky;
    top: 0;
    z-index: 200;
    background: var(--org-card-bg);
    border-bottom: 1px solid var(--org-border);
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
    margin: 0 calc(-1 * var(--org-gutter, 0px));
}

.org-page-nav__inner {
    display: flex;
    align-items: center;
    gap: 0;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1rem;
}
.org-page-nav__inner::-webkit-scrollbar { display: none; }

.org-page-nav__item {
    display: inline-flex;
    align-items: center;
    gap: .38rem;
    padding: .78rem 1rem;
    font-size: .82rem;
    font-weight: 500;
    color: var(--org-text-muted);
    white-space: nowrap;
    text-decoration: none;
    border-bottom: 2.5px solid transparent;
    transition: color .15s, border-color .15s;
    flex-shrink: 0;
    position: relative;
}
.org-page-nav__item i {
    font-size: .85rem;
    opacity: .75;
}
.org-page-nav__item:hover {
    color: var(--org-accent);
    text-decoration: none;
}
.org-page-nav__item:hover i { opacity: 1; }

.org-page-nav__item.is-active {
    color: var(--org-accent);
    border-bottom-color: var(--org-accent);
    font-weight: 600;
}
.org-page-nav__item.is-active i { opacity: 1; }

/* ── Mobile responsive ────────────────────────────────────────────────── */
@media (max-width: 991.98px) {
    .org-reviews-cards-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 767.98px) {
    .org-profile__hero     { border-radius: 0; margin-bottom: 0; }
    .org-profile__cover    { height: 150px; }
    .org-profile__hero-content { padding: .6rem .9rem; gap: .6rem; }
    .org-profile__logo     { width: 58px; height: 58px; border-width: 2px; border-radius: 9px; }
    .org-profile__name     { font-size: 1rem; }

    .org-profile__actions-row {
        flex-direction: column;
        align-items: flex-start;
        gap: .5rem;
        padding: .6rem .9rem;
    }
    .org-profile__actions {
        flex-direction: row;
        flex-wrap: wrap;
        gap: .35rem;
    }
    .org-profile__actions .btn {
        padding: .3rem .7rem;
        font-size: .77rem;
        border-radius: 18px;
        flex: 0 0 auto;
    }

    .org-profile__section        { padding: 1.75rem 1.5rem; }
    .org-profile__section-title  { font-size: 1.4rem; }
    .org-profile__gallery-grid   { grid-template-columns: repeat(3, 1fr); }
    .org-profile__services-grid  { grid-template-columns: 1fr 1fr; }
    .org-profile__team-grid      { grid-template-columns: repeat(3, 1fr); }
    .org-hours-list              { max-width: 100%; }
    .org-hours-row__day          { width: 36px; }
    .org-profile__map            { height: 380px; min-height: 360px; }
    .org-reviews-cards-grid      { grid-template-columns: 1fr; }

    .org-block__bar-label { display: none; }
}

@media (max-width: 480px) {
    .org-profile__cover { height: 120px; }
    .org-profile__logo  { width: 50px; height: 50px; }
    .org-profile__name  { font-size: .9rem; }
    .org-profile__actions .btn     { font-size: .73rem; padding: .28rem .55rem; }
    .org-profile__services-grid    { grid-template-columns: 1fr; }
    .org-profile__gallery-grid     { grid-template-columns: repeat(2, 1fr); }
    .org-profile__team-grid        { grid-template-columns: repeat(2, 1fr); }
    .org-profile__section-title    { font-size: 1.25rem; }
}

/* ═══════════════════════════════════════════════════════════════════════
   MOBILE REDESIGN — phones (≤ 575px)
   ═══════════════════════════════════════════════════════════════════════ */
@media (max-width: 575.98px) {

    /* Prevent horizontal overflow */
    .org-profile-wrap { overflow-x: hidden; }

    /* ── Profile bar — overlay on photo (mobile) ── */
    .org-profile__profile-bar {
        position: absolute;
        bottom: 0; left: 0; right: 0;
        background: transparent;
        padding: .75rem 1rem .9rem;
        gap: 0;
        flex-direction: column;   /* stack logo + info vertically */
        align-items: flex-start;
    }
    /* Logo: small, top-left as badge */
    .org-profile__logo-col {
        display: block;
        margin-top: 0;
        margin-bottom: .5rem;
        flex-shrink: 0;
    }
    .org-profile__logo,
    .org-logo-placeholder {
        width: 40px;
        height: 40px;
        border: 2px solid rgba(255,255,255,.7);
        box-shadow: 0 2px 6px rgba(0,0,0,.4);
    }
    /* Profile info: full width */
    .org-profile__profile-info { width: 100%; padding-top: 0; }
    /* Name inline with badge */
    .org-profile__name {
        font-size: 1.1rem;
        color: #fff;
        text-shadow: 0 1px 5px rgba(0,0,0,.55);
        display: inline;       /* inline so badge stays on same line */
    }
    .org-profile__verified-badge {
        color: #7dd3fc;
        display: inline;
        font-size: 1rem;
        margin-left: 4px;
    }
    .org-profile__stars { color: #fbbf24; }
    .org-profile__rating-text { color: rgba(255,255,255,.85); }
    .org-profile__google-rating {
        background: rgba(255,255,255,.18);
        color: rgba(255,255,255,.9);
        backdrop-filter: blur(4px);
    }

    /* Hide "See all photos" button on mobile */
    .org-hero-carousel__all-btn { display: none !important; }

    /* ── Smaller action buttons on mobile ── */
    .org-btn-cta { font-size: .78rem; padding: .38rem .9rem; }
    .org-btn-icon { font-size: .74rem; padding: .3rem .65rem; }
    .org-btn-cta-call { padding: .38rem 1rem; }

    /* ── Actions bar — grid 2×2 CTA on mobile ── */
    .org-actions-bar {
        padding: .75rem 1rem;
        flex-direction: column;
        gap: .6rem;
        align-items: stretch;
    }
    .org-actions-main {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: .5rem;
        width: 100%;
    }
    .org-actions-main .org-btn-cta,
    .org-actions-main .org-btn-icon {
        width: 100%;
        min-height: 40px;
        justify-content: center;
        font-size: .82rem;
        padding: .5rem .6rem;
    }
    .org-actions-owner {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: .4rem;
        width: 100%;
    }
    .org-actions-owner .btn,
    .org-actions-owner .org-btn-icon {
        min-height: 40px;
        flex: 1 1 calc(50% - .4rem);
    }
    .org-actions-sep { display: none; }
    .org-btn-cta-book--disabled { display: none; } /* hide disabled booking on mobile */

    /* ── Sections ── */
    .org-profile__section { padding: 1.5rem 1rem; }
    .org-section-h { font-size: 1.2rem; margin-bottom: 1rem; }

    /* ── Contact cards ── */
    .org-contact-grid {
        grid-template-columns: 1fr;
        gap: .75rem;
    }
    .org-contact-item { padding: 1.5rem 1rem 1.4rem; min-height: 0; }
    .org-contact-icon { width: 52px; height: 52px; font-size: 1.15rem; }
    .org-contact-item__label { font-size: 1rem; }
    .org-contact-item__value { font-size: .88rem; }
    .org-social-list {
        flex-direction: column;
        align-items: stretch;
        max-width: 100%;
        margin: 0;
    }
    .org-social-list__item {
        flex: 1 1 auto;
        width: 100%;
        max-width: 100%;
    }

    /* ── Map full-width on mobile too ── */
    .org-map-wrapper {
        margin-left: -1rem;
        width: calc(100% + 2rem);
        left: 0;
        transform: none;
    }
    .org-profile__map { height: 340px; min-height: 320px; }

    /* ── Reviews ── */
    .org-reviews-cards-grid { grid-template-columns: 1fr; }

    /* ── Hours ── */
    .org-hours-row { font-size: .85rem; }
    .org-hours-row__day { width: 32px; font-size: .82rem; }

    /* ── Carousel single on mobile ── */
    .org-hero-carousel__slide {
        flex: 0 0 100%;
    }
    .org-hero-carousel__arrow--prev { left: 8px; width: 36px; height: 36px; font-size: 1.2rem; }
    .org-hero-carousel__arrow--next { right: 8px; width: 36px; height: 36px; font-size: 1.2rem; }
    .org-hero-carousel__all-btn { font-size: .75rem; padding: 4px 10px; }

    /* ── Breeds/Events/Certs ── */
    .org-profile__breeds-list { gap: .5rem; }
    .org-profile__breed-item { padding: .6rem .75rem; }
    .org-profile__event-item, .org-profile__cert-item { gap: .75rem; }
    .org-profile__event-icon { width: 44px; min-width: 44px; }
    .org-profile__event-icon__day { font-size: 1.3rem; }

    /* ── Animals grid ── */
    /* mobile scroll handled by org-animals-slider block */

    /* ── Photos modal ── */
    .org-photos-modal__grid { grid-template-columns: repeat(2, 1fr); gap: 4px; }
    .org-photos-modal.modal-dialog { max-width: 100vw; margin: 0; height: 100%; border-radius: 0; }
    .org-photos-modal .modal-content { border-radius: 0; }

    /* ── Tap targets: 40px minimum for all interactive chrome ── */
    .org-btn-cta,
    .org-btn-icon,
    .org-profile__actions .btn,
    .org-contact-item__value a,
    .org-social-list__item a,
    .org-page-nav__item,
    .org-readmore-btn,
    .org-review-notice__login,
    .org-animal-card__btn,
    .org-hero-carousel__arrow {
        min-height: 40px;
    }
    /* Increase comfortable padding for section-level links */
    .org-section-h { line-height: 1.3; }
}

/* ── Inline-edit delete buttons ── */

/* Team / Event / Cert: absolute overlay on card */
.org-team-delete-btn,
.org-event-delete-btn,
.org-cert-delete-btn {
    position: absolute; top: 6px; right: 8px;
    background: none; border: none; color: #ef4444;
    font-size: 1.1rem; cursor: pointer; display: none;
    line-height: 1; padding: 0;
    opacity: .6; transition: opacity .15s;
}
body.org-editing .org-team-delete-btn,
body.org-editing .org-event-delete-btn,
body.org-editing .org-cert-delete-btn { display: flex; }
.org-team-delete-btn:hover,
.org-event-delete-btn:hover,
.org-cert-delete-btn:hover { opacity: 1; }

/* Breed: × button positioned top-right of the card */
.org-breed-delete-btn {
    display: none;
    position: absolute; top: 6px; right: 8px;
    background: none; border: none;
    color: #ef4444; font-size: 1rem;
    cursor: pointer; line-height: 1;
    padding: 0;
    opacity: .6; transition: opacity .15s;
}
body.org-editing .org-breed-delete-btn { display: flex; }
.org-breed-delete-btn:hover { opacity: 1; }

/* ── Add-form panels (shared style for all blocks) ── */
.org-team-add-form,
.org-breed-add-form,
.org-event-add-form,
.org-cert-add-form { margin-top: .75rem; }
.org-team-add-form__inner,
.org-breed-add-form__inner,
.org-event-add-form__inner,
.org-cert-add-form__inner {
    background: #f9fafb;
    border: 1px dashed var(--org-border);
    border-radius: var(--org-radius-sm);
    padding: 1rem;
}

/* Ensure relative positioning for cards that have delete buttons */
.org-profile__team-member,
.org-profile__breed-item,
.org-profile__event-card,
.org-profile__cert-card { position: relative; }

/* Add buttons only visible in edit mode */
#org-team-add-btn,
#org-breed-add-btn,
#org-event-add-btn,
#org-cert-add-btn { display: none !important; }
body.org-editing #org-team-add-btn,
body.org-editing #org-breed-add-btn,
body.org-editing #org-event-add-btn,
body.org-editing #org-cert-add-btn { display: inline-flex !important; }

/* ── Breeder animal badge variants (top-left pill, status-colored) ── */
.org-animal-card__badge--sale     { background: rgba(220, 252, 231, .94); color: #15803d; }
.org-animal-card__badge--reserved { background: rgba(254, 243, 199, .94); color: #b45309; }
.org-animal-card__badge--sold     { background: rgba(243, 244, 246, .94); color: #4b5563; }
