/* ═══════════════════════════════════════════════════════════════════════
   PARTNERS — adaptive section + archive + single
   Design: medical-grade professional, brand-blue→green gradient accents,
   high contrast, subtle motion, WCAG-friendly focus states.
   ═══════════════════════════════════════════════════════════════════════ */

.partners-section {
    position: relative;
    padding: 70px 0 80px;
    background: var(--bg, #F8FAFC);
    overflow: hidden;
    isolation: isolate;
}

/* Faint blue medical-cross motif tile for texture. */
.partners-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='90' height='90' viewBox='0 0 90 90'><g fill='%2348BCE4' fill-opacity='0.05'><path d='M39 14h12v15h15v12H51v15H39V41H24V29h15z'/></g></svg>");
    background-size: 90px 90px;
    mask-image: radial-gradient(ellipse 90% 75% at 50% 50%, #000 30%, transparent 90%);
    -webkit-mask-image: radial-gradient(ellipse 90% 75% at 50% 50%, #000 30%, transparent 90%);
    pointer-events: none;
    z-index: 0;
}

.partners-section > .container { position: relative; z-index: 2; }

/* ── Floating blobs (mouse-parallax + slow autonomous drift) ─────────── */
.partners-blobs {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
}

.partners-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(40px);
    will-change: transform;
    transform: translate3d(0, 0, 0);
}

.partners-blob--1 {
    top:  6%;
    left: 8%;
    width: 320px; height: 320px;
    background: radial-gradient(circle, rgba(72, 188, 228, 0.42) 0%, rgba(72, 188, 228, 0) 65%);
    animation: partnersBlobDrift1 18s ease-in-out infinite alternate;
    --depth: 0.45;
}
.partners-blob--2 {
    top:  62%;
    left: 78%;
    width: 280px; height: 280px;
    background: radial-gradient(circle, rgba(115, 190, 66, 0.36) 0%, rgba(115, 190, 66, 0) 65%);
    animation: partnersBlobDrift2 22s ease-in-out infinite alternate;
    --depth: 0.55;
}
.partners-blob--3 {
    top:  20%;
    left: 70%;
    width: 220px; height: 220px;
    background: radial-gradient(circle, rgba(42, 156, 194, 0.32) 0%, rgba(42, 156, 194, 0) 65%);
    animation: partnersBlobDrift3 16s ease-in-out infinite alternate;
    --depth: 0.7;
}
.partners-blob--4 {
    top:  72%;
    left: 12%;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(72, 188, 228, 0.30) 0%, rgba(72, 188, 228, 0) 65%);
    animation: partnersBlobDrift4 20s ease-in-out infinite alternate;
    --depth: 0.6;
}
.partners-blob--5 {
    top:  4%;
    left: 50%;
    width: 160px; height: 160px;
    background: radial-gradient(circle, rgba(79, 143, 44, 0.26) 0%, rgba(79, 143, 44, 0) 65%);
    animation: partnersBlobDrift5 14s ease-in-out infinite alternate;
    --depth: 0.85;
}

/* JS sets transform for mouse-parallax; CSS animates the `translate` property
   for autonomous drift. The two compose (translate runs before transform). */
@keyframes partnersBlobDrift1 {
    0%   { translate: 0    0;   }
    50%  { translate: 3%  -2%; }
    100% { translate: -2%  3%; }
}
@keyframes partnersBlobDrift2 {
    0%   { translate: 0    0;   }
    50%  { translate: -3%  2%; }
    100% { translate: 2%  -3%; }
}
@keyframes partnersBlobDrift3 {
    0%   { translate: 0    0;   }
    50%  { translate: 2%   3%; }
    100% { translate: -3% -2%; }
}
@keyframes partnersBlobDrift4 {
    0%   { translate: 0    0;   }
    50%  { translate: -2% -3%; }
    100% { translate: 3%   2%; }
}
@keyframes partnersBlobDrift5 {
    0%   { translate: 0    0;   }
    50%  { translate: 4%   1%; }
    100% { translate: -3%  2%; }
}

/* ── Header ───────────────────────────────────────────────── */
.partners-header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 32px;
}

.partners-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--blue-dark, #2A9CC2);
    margin: 0 0 16px;
}

.partners-eyebrow-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--blue, #48BCE4), var(--green, #73BE42));
    box-shadow: 0 0 0 4px rgba(72, 188, 228, 0.15);
}

.partners-title {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: clamp(28px, 3.6vw, 40px);
    font-weight: 800;
    line-height: 1.15;
    margin: 0 0 10px;
    color: var(--text-primary, #1F2937);
    letter-spacing: -0.02em;
}

.partners-subtitle {
    font-size: 15px;
    line-height: 1.6;
    color: var(--text-secondary, #6B7280);
    margin: 0;
}

/* ── Shared accent line (blue → green) ────────────────────── */
.partner-accent-line {
    display: block;
    width: 56px;
    height: 3px;
    border-radius: 3px;
    background: linear-gradient(90deg, var(--blue, #48BCE4), var(--green, #73BE42));
    margin: 14px 0 16px;
}
.partner-accent-line-large { width: 80px; height: 4px; margin-top: 18px; margin-bottom: 22px; }

/* ── HERO VARIANT (1 partner) ─────────────────────────────── */
/* Slim horizontal strip — logo + content + actions in one row. */
.partner-hero {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 22px;
    align-items: center;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #E5E7EB);
    border-radius: 16px;
    padding: 18px 22px;
    max-width: 820px;
    margin: 0 auto;
    box-shadow: 0 4px 14px rgba(72, 188, 228, 0.07);
    transition: box-shadow 0.25s, transform 0.25s, border-color 0.25s;
}

.partner-hero:hover {
    transform: translateY(-2px);
    border-color: var(--blue, #48BCE4);
    box-shadow: 0 14px 30px -10px rgba(72, 188, 228, 0.25);
}

/* Bottom gradient bar appears on hover */
.partner-hero::after {
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--blue, #48BCE4), var(--green, #73BE42));
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
    border-radius: 0 0 16px 16px;
}

.partner-hero:hover::after { transform: scaleX(1); }

.partner-hero-logo-wrap {
    background: linear-gradient(135deg, var(--blue-light, #E6F6FD), #fff);
    border: 1px solid var(--border, #E5E7EB);
    border-radius: 12px;
    padding: 10px;
    width: 96px;
    height: 96px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.partner-hero-logo {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.partner-hero-body {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.partner-hero-name {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 19px;
    font-weight: 700;
    line-height: 1.25;
    color: var(--text-primary, #1F2937);
    margin: 0;
}

.partner-hero-name a {
    color: inherit;
    text-decoration: none;
    transition: color 0.2s;
}

.partner-hero-name a:hover { color: var(--blue-dark, #2A9CC2); }

.partner-hero-location {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin: 4px 0 6px;
    color: var(--blue-dark, #2A9CC2);
    font-weight: 600;
    font-size: 12px;
}

.partner-hero-location svg { flex-shrink: 0; }

.partner-hero-desc {
    font-size: 13.5px;
    line-height: 1.5;
    color: var(--text-secondary, #6B7280);
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.partner-hero-cta {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.partner-btn-mini { padding: 9px 16px; font-size: 13px; }

.partner-hero-details {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 13px;
    font-weight: 700;
    color: var(--blue-dark, #2A9CC2);
    text-decoration: none;
    transition: gap 0.2s;
    white-space: nowrap;
}

.partner-hero-details:hover { color: var(--blue, #48BCE4); gap: 8px; }

/* ── Credential Card extras (verified stamp, chip, stat grid) ── */

/* Corner stamp ribbon ("◢ VERIFIED") in the top-right of the hero card. */
.partner-hero-stamp {
    position: absolute;
    top: 16px;
    right: -38px;
    transform: rotate(35deg);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 38px;
    background: linear-gradient(135deg, var(--green, #73BE42), #4F8F2C);
    color: #fff;
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    box-shadow: 0 4px 10px rgba(79, 143, 44, 0.35);
    z-index: 2;
    pointer-events: none;
}

.partner-hero-stamp svg {
    flex-shrink: 0;
    margin-right: 2px;
}

/* Meta row: verified chip + location side by side. */
.partner-hero-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 14px;
    margin: 0 0 12px;
}

.partner-verified-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(115, 190, 66, 0.12), rgba(72, 188, 228, 0.10));
    color: #35611D;
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.3px;
    border: 1px solid rgba(115, 190, 66, 0.25);
}

.partner-verified-chip svg { color: var(--green, #73BE42); flex-shrink: 0; }

.partner-hero-meta .partner-hero-location { margin: 0; }

/* Stats grid: up to 3 chips side-by-side */
.partner-hero-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
    gap: 10px;
    margin: 0 0 16px;
    padding: 0;
    max-width: 420px;
}

.partner-hero-stat {
    background: linear-gradient(135deg, var(--blue-light, #E6F6FD), #fff);
    border: 1px solid rgba(72, 188, 228, 0.2);
    border-radius: 10px;
    padding: 10px 12px;
    margin: 0;
    text-align: center;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.partner-hero-stat:hover {
    transform: translateY(-2px);
    border-color: var(--blue, #48BCE4);
    box-shadow: 0 6px 14px -4px rgba(72, 188, 228, 0.3);
}

.partner-hero-stat-value {
    display: block;
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 16px;
    font-weight: 800;
    line-height: 1.1;
    color: var(--blue-dark, #2A9CC2);
    background: linear-gradient(135deg, var(--blue-dark, #2A9CC2), var(--green, #73BE42));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: 0 0 2px;
    letter-spacing: -0.01em;
}

.partner-hero-stat-label {
    display: block;
    font-size: 10.5px;
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    color: var(--text-secondary, #6B7280);
    margin: 0;
}

@media (max-width: 700px) {
    .partner-hero-stamp { right: -42px; top: 14px; padding: 4px 42px; font-size: 9px; }
    .partner-hero-stats { max-width: 100%; }
    .partner-hero-meta { justify-content: center; }
}

/* ── SOLO VARIANT (1 partner) — single centered card ──────── */
.partner-list {
    display: grid;
    gap: 24px;
}

.partners-section--solo .partner-slider,
.partners-section--solo .partner-list {
    display: block;
}
.partners-section--solo .partner-card {
    width: 100%;
    max-width: 340px;
    margin: 0 auto;
}

/* Archive page still uses a grid. */
.partner-list--archive {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

/* ── SLIDER VARIANT (2+ partners) — one card at a time, centered ── */
.partners-section--slider .partner-slider {
    position: relative;
    max-width: 460px;
    margin: 0 auto;
    padding: 0 60px; /* room for arrows just outside the card */
}

.partners-section--slider .partner-slider-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 100%;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding: 8px 0 28px;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.partners-section--slider .partner-slider-track::-webkit-scrollbar { display: none; }

.partners-section--slider .partner-card {
    scroll-snap-align: center;
    width: 100%;
    max-width: 340px;
    justify-self: center;
}

/* ── Slider arrows ────────────────────────────────────────── */
.partner-slider-arrow {
    position: absolute;
    top: calc(50% - 14px); /* small offset for the dots row beneath */
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--border, #E5E7EB);
    color: var(--blue-dark, #2A9CC2);
    box-shadow: 0 6px 18px -4px rgba(72, 188, 228, 0.25);
    cursor: pointer;
    transition: background 0.25s, color 0.25s, transform 0.25s, box-shadow 0.25s, border-color 0.25s;
    z-index: 2;
}

.partner-slider-arrow--prev { left: 0; }
.partner-slider-arrow--next { right: 0; }

.partner-slider-arrow:hover {
    background: linear-gradient(135deg, var(--blue, #48BCE4), var(--blue-dark, #2A9CC2));
    color: #fff;
    border-color: transparent;
    transform: translateY(-50%) scale(1.06);
    box-shadow: 0 12px 26px -6px rgba(72, 188, 228, 0.55);
}

.partner-slider-arrow:focus-visible {
    outline: 3px solid var(--blue, #48BCE4);
    outline-offset: 3px;
}

.partner-slider-arrow:disabled {
    opacity: 0.35;
    cursor: not-allowed;
    transform: translateY(-50%);
    box-shadow: none;
}

/* ── Slider dots ──────────────────────────────────────────── */
.partner-slider-dots {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 6px;
}

.partner-slider-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    background: rgba(72, 188, 228, 0.35);
    cursor: pointer;
    padding: 0;
    transition: background 0.25s, transform 0.25s, width 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.partner-slider-dot:hover {
    background: var(--blue, #48BCE4);
    transform: scale(1.2);
}

.partner-slider-dot.is-active {
    width: 28px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--blue, #48BCE4), var(--green, #73BE42));
}

.partner-slider-dot:focus-visible {
    outline: 2px solid var(--blue, #48BCE4);
    outline-offset: 3px;
}

@media (max-width: 600px) {
    .partners-section--slider .partner-slider { padding: 0 16px; }
    .partner-slider-arrow { width: 38px; height: 38px; }
    .partner-slider-arrow--prev { left: -10px; }
    .partner-slider-arrow--next { right: -10px; }
}

/* ── Card — flip business card ────────────────────────────── */
.partner-card {
    display: block;
    position: relative;
    aspect-ratio: 4 / 5;
    text-decoration: none;
    color: inherit;
    perspective: 1400px;
    border-radius: var(--radius, 20px);
    /* No background here — the faces own the surface. */
    background: transparent;
    -webkit-tap-highlight-color: transparent;
}

.partner-card-flipper {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    transition: transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
}

/* Hover flips on devices that actually have a hover state (avoids sticky flip on touch). */
@media (hover: hover) {
    .partner-card:hover .partner-card-flipper { transform: rotateY(180deg); }
}

/* Keyboard focus also flips, so tab-users see the back. The focusable element
   is the front-face <a>, but we style the parent ring + flip via :focus-within. */
.partner-card-face--front:focus-visible {
    outline: 3px solid var(--blue, #48BCE4);
    outline-offset: 3px;
    border-radius: var(--radius, 20px);
}
.partner-card:focus-within .partner-card-flipper { transform: rotateY(180deg); }

/* Touch toggle (set by JS). */
.partner-card.is-flipped .partner-card-flipper { transform: rotateY(180deg); }

.partner-card-face {
    position: absolute;
    inset: 0;
    border-radius: var(--radius, 20px);
    overflow: hidden;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    box-shadow: 0 8px 24px rgba(72, 188, 228, 0.10);
    border: 1px solid var(--border, #E5E7EB);
    display: flex;
    flex-direction: column;
}

/* ── FRONT face ─────────────────────────────────────────── */
.partner-card-face--front {
    background: var(--surface, #fff);
    padding: 18px 18px 20px;
    align-items: center;
    text-align: center;
    transition: box-shadow 0.4s, border-color 0.25s;
    color: inherit;
    text-decoration: none;
}

.partner-card:hover .partner-card-face--front {
    border-color: rgba(72, 188, 228, 0.4);
    box-shadow: 0 18px 40px rgba(72, 188, 228, 0.18);
}

/* Diagonal moving foil sheen across the front. */
.partner-card-foil {
    position: absolute;
    inset: -2px;
    pointer-events: none;
    background:
        linear-gradient(135deg,
            transparent 30%,
            rgba(72, 188, 228, 0.08) 45%,
            rgba(115, 190, 66, 0.08) 55%,
            transparent 70%);
    background-size: 220% 220%;
    background-position: 100% 100%;
    transition: background-position 0.9s cubic-bezier(0.22, 1, 0.36, 1);
    border-radius: var(--radius, 20px);
}

.partner-card:hover .partner-card-foil { background-position: 0% 0%; }

/* Verified check in the top-right corner of the front face. */
.partner-card-corner {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--green, #73BE42), #4F8F2C);
    color: #fff;
    box-shadow: 0 4px 10px rgba(79, 143, 44, 0.4);
    z-index: 2;
}

.partner-card-logo {
    flex: 1;
    width: 100%;
    background: linear-gradient(135deg, var(--blue-light, #E6F6FD), #fff);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    position: relative;
    overflow: hidden;
}

.partner-card-logo::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 20% 10%, rgba(115, 190, 66, 0.10), transparent 50%),
        radial-gradient(circle at 90% 90%, rgba(72, 188, 228, 0.10), transparent 50%);
    pointer-events: none;
}

.partner-card-img {
    max-width: 94%;
    max-height: 90%;
    width: auto;
    height: auto;
    object-fit: contain;
    position: relative;
    z-index: 1;
    transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.partner-card:hover .partner-card-img { transform: scale(1.05); }

.partner-card-front-info {
    width: 100%;
    padding-top: 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.partner-card-front-info .partner-accent-line {
    margin: 8px 0 6px;
    width: 40px;
    height: 3px;
}

.partner-card-name {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 19px;
    font-weight: 700;
    line-height: 1.25;
    color: var(--text-primary, #1F2937);
    margin: 0;
    letter-spacing: -0.01em;
}

.partner-card-flip-hint {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--blue-dark, #2A9CC2);
    opacity: 0.55;
    transition: opacity 0.3s, transform 0.4s;
}

.partner-card:hover .partner-card-flip-hint {
    opacity: 1;
    transform: rotate(45deg);
}

/* ── BACK face ──────────────────────────────────────────── */
.partner-card-face--back {
    transform: rotateY(180deg);
    background:
        linear-gradient(135deg, var(--blue-darker, #1C6F8A) 0%, var(--blue-dark, #2A9CC2) 55%, var(--green-dark, #4F8F2C) 100%);
    color: #fff;
    padding: 24px 22px 22px;
    border-color: transparent;
}

.partner-card-back-pattern {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.35;
    background-image:
        radial-gradient(circle at 18% 22%, rgba(255, 255, 255, 0.18) 0, transparent 35%),
        radial-gradient(circle at 88% 84%, rgba(115, 190, 66, 0.28) 0, transparent 40%),
        repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.04) 0 1px, transparent 1px 14px);
}

.partner-card-back-head {
    position: relative;
    z-index: 1;
    margin-bottom: 10px;
}

.partner-card-back-name {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 22px;
    font-weight: 800;
    line-height: 1.2;
    margin: 0 0 6px;
    letter-spacing: -0.01em;
    color: #fff;
}

/* Short description shown above the address. */
.partner-card-back-desc {
    position: relative;
    z-index: 1;
    font-size: 13.5px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.92);
    margin: 0 0 12px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Full street address shown under the description. */
.partner-card-back-address {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    margin: 0;
    font-size: 13.5px;
    line-height: 1.4;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.92);
    letter-spacing: 0.1px;
}

.partner-card-back-address svg {
    flex-shrink: 0;
    margin-top: 3px;
    opacity: 0.95;
}

.partner-card-back-address span {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Compact map embedded in the back face. Leaflet renders inside this. */
.partner-card-back-map {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100px;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.25);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
    margin: 0 0 12px;
    background: rgba(255, 255, 255, 0.06);
    cursor: grab;
}

/* Tame Leaflet chrome inside the small card map. */
.partner-card-back-map .leaflet-control-attribution {
    font-size: 9px;
    padding: 1px 4px;
    background: rgba(255, 255, 255, 0.8);
}
.partner-card-back-map .leaflet-control-zoom { display: none; }

/* Phone + email tappable rows. */
.partner-card-back-contact {
    position: relative;
    z-index: 1;
    list-style: none;
    padding: 0;
    margin: 0 0 14px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.partner-card-back-contact a {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 4px 0;
    font-size: 13px;
    line-height: 1.3;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.95);
    text-decoration: none;
    word-break: break-all;
    transition: color 0.2s;
}

.partner-card-back-contact a:hover { color: #fff; text-decoration: underline; text-underline-offset: 3px; }

.partner-card-back-contact svg {
    flex-shrink: 0;
    opacity: 0.8;
    color: #fff;
}

/* Compact icon row: website + LINE + Facebook. */
.partner-card-back-social {
    position: relative;
    z-index: 1;
    list-style: none;
    padding: 0;
    margin: 0 0 14px;
    display: flex;
    gap: 8px;
}

.partner-card-back-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.22);
    color: #fff;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    transition: background 0.2s, transform 0.2s, border-color 0.2s;
}

.partner-card-back-social a:hover {
    background: rgba(255, 255, 255, 0.28);
    border-color: rgba(255, 255, 255, 0.4);
    transform: translateY(-2px);
}

.partner-card-back-cta {
    position: relative;
    z-index: 1;
    margin-top: auto;
    display: inline-flex;
    align-self: flex-start;
    align-items: center;
    gap: 7px;
    padding: 11px 18px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.20);
    border: 1px solid rgba(255, 255, 255, 0.28);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.3px;
    transition: background 0.25s, gap 0.25s, transform 0.25s;
}

.partner-card:hover .partner-card-back-cta,
.partner-card.is-flipped .partner-card-back-cta {
    background: rgba(255, 255, 255, 0.28);
    gap: 10px;
}

/* ── Section footer ('View all') ──────────────────────────── */
.partners-section-footer {
    text-align: center;
    margin-top: 48px;
}

/* ── Buttons ──────────────────────────────────────────────── */
.partner-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border-radius: 999px;
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.3px;
    text-decoration: none;
    transition:
        transform 0.2s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.2s,
        background 0.2s,
        color 0.2s;
    border: none;
    cursor: pointer;
}

.partner-btn-primary {
    background: linear-gradient(135deg, var(--blue, #48BCE4), var(--blue-dark, #2A9CC2));
    color: #fff;
    box-shadow: 0 6px 18px -4px rgba(72, 188, 228, 0.55);
}

.partner-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 26px -6px rgba(72, 188, 228, 0.65);
    color: #fff;
}

.partner-btn-primary:focus-visible {
    outline: 3px solid #fff;
    outline-offset: 2px;
    box-shadow: 0 0 0 5px rgba(72, 188, 228, 0.5), 0 6px 18px -4px rgba(72, 188, 228, 0.55);
}

.partner-btn-secondary {
    background: transparent;
    color: var(--blue-dark, #2A9CC2);
    border: 1.5px solid var(--blue, #48BCE4);
}

.partner-btn-secondary:hover {
    background: var(--blue-light, #E6F6FD);
    transform: translateY(-2px);
    color: var(--blue-dark, #2A9CC2);
}

.partner-btn-large { padding: 14px 28px; font-size: 15px; }

/* ═══════════════════════════════════════════════════════════
   ARCHIVE PAGE
   ═══════════════════════════════════════════════════════════ */
.partners-archive {
    padding: 140px 0 90px;
    background: var(--bg, #F8FAFC);
    min-height: 60vh;
    position: relative;
}

.partners-archive::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 700px 500px at 50% 0%, rgba(72, 188, 228, 0.07), transparent 60%);
    pointer-events: none;
}

.partners-archive .container { position: relative; }

.partners-archive-header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 50px;
}

.partners-archive-header h1 {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: clamp(34px, 4.8vw, 52px);
    font-weight: 800;
    line-height: 1.15;
    color: var(--text-primary, #1F2937);
    margin: 0 0 14px;
    letter-spacing: -0.02em;
}

.partners-archive-desc {
    font-size: 17px;
    line-height: 1.7;
    color: var(--text-secondary, #6B7280);
    margin: 0;
}

.partners-empty {
    text-align: center;
    max-width: 480px;
    margin: 60px auto;
    padding: 60px 30px;
    background: var(--surface, #fff);
    border: 2px dashed var(--border, #E5E7EB);
    border-radius: var(--radius, 20px);
    color: var(--text-secondary, #6B7280);
}

.partners-empty svg { color: var(--blue, #48BCE4); margin-bottom: 14px; }

/* ═══════════════════════════════════════════════════════════
   SINGLE PARTNER
   ═══════════════════════════════════════════════════════════ */
.partner-single {
    padding: 130px 0 100px;
    background: var(--bg, #F8FAFC);
    position: relative;
}

.partner-single::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 700px 500px at 50% 0%, rgba(72, 188, 228, 0.07), transparent 60%);
    pointer-events: none;
}

.partner-single .container { position: relative; max-width: 1100px; }

.partner-breadcrumb {
    font-size: 14px;
    color: var(--text-secondary, #6B7280);
    margin-bottom: 32px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}

.partner-breadcrumb a {
    color: var(--blue-dark, #2A9CC2);
    font-weight: 500;
    text-decoration: none;
}

.partner-breadcrumb a:hover { color: var(--blue, #48BCE4); }
.partner-breadcrumb .sep { color: var(--border, #E5E7EB); margin: 0 4px; }

.partner-single-header {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 36px;
    align-items: center;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #E5E7EB);
    border-radius: var(--radius, 20px);
    padding: 36px;
    box-shadow: 0 8px 24px rgba(72, 188, 228, 0.08);
    margin-bottom: 36px;
}

.partner-single-logo-wrap {
    aspect-ratio: 1;
    background: linear-gradient(135deg, var(--blue-light, #E6F6FD), #fff);
    border-radius: 16px;
    border: 1px solid var(--border, #E5E7EB);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.partner-single-logo {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.partner-single-eyebrow {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--green, #73BE42);
    margin: 0 0 8px;
}

.partner-single-name {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 800;
    line-height: 1.15;
    color: var(--text-primary, #1F2937);
    margin: 0;
    letter-spacing: -0.02em;
}

.partner-single-location {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 22px;
    color: var(--blue-dark, #2A9CC2);
    font-weight: 600;
    font-size: 16px;
}

.partner-single-cta { margin: 0; }

.partner-single-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    gap: 36px;
    margin-bottom: 40px;
}

.partner-single-map-wrap {
    position: sticky;
    top: 100px;
    align-self: start;
}

.partner-single-map {
    width: 100%;
    height: 420px;
    border-radius: var(--radius, 20px);
    border: 1px solid var(--border, #E5E7EB);
    background: var(--blue-light, #E6F6FD);
    box-shadow: 0 8px 24px rgba(72, 188, 228, 0.10);
    overflow: hidden;
}

.partner-single-content-wrap {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.partner-single-content,
.partner-single-contact {
    background: var(--surface, #fff);
    border: 1px solid var(--border, #E5E7EB);
    border-radius: var(--radius, 20px);
    padding: 32px;
    box-shadow: 0 4px 14px rgba(72, 188, 228, 0.06);
}

.partner-single-section-title {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-size: 22px;
    font-weight: 700;
    color: var(--text-primary, #1F2937);
    margin: 0;
}

.partner-single-content > *:not(.partner-accent-line):not(.partner-single-section-title) { margin-top: 14px; }

.partner-single-content p {
    font-size: 16px;
    line-height: 1.8;
    color: var(--text-primary, #1F2937);
    margin: 0 0 14px;
}

.partner-single-content a {
    color: var(--blue-dark, #2A9CC2);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.partner-single-content ul,
.partner-single-content ol { padding-left: 24px; line-height: 1.8; }
.partner-single-content li + li { margin-top: 6px; }

.partner-single-address {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 16px;
    line-height: 1.6;
    color: var(--text-primary, #1F2937);
    margin: 14px 0 0;
}

.partner-single-address svg {
    flex-shrink: 0;
    color: var(--blue, #48BCE4);
    margin-top: 3px;
}

.partner-contact-list {
    list-style: none;
    padding: 0;
    margin: 14px 0 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.partner-contact-list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 15px;
    line-height: 1.55;
    color: var(--text-primary, #1F2937);
}

.partner-contact-list li svg {
    flex-shrink: 0;
    color: var(--blue, #48BCE4);
    margin-top: 2px;
}

.partner-contact-list a {
    color: var(--blue-dark, #2A9CC2);
    text-decoration: none;
    transition: color 0.15s;
}

.partner-contact-list a:hover { color: var(--blue, #48BCE4); }

.partner-single-back {
    margin: 40px 0 0;
    text-align: center;
}

.partner-single-back a {
    font-family: var(--fh, 'Barlow', sans-serif);
    font-weight: 700;
    color: var(--blue-dark, #2A9CC2);
    text-decoration: none;
}

.partner-single-back a:hover { color: var(--blue, #48BCE4); }

/* ── Logo placeholder ─────────────────────────────────────── */
.partner-logo-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--blue, #48BCE4);
    opacity: 0.55;
}

/* ── Leaflet branded marker pulse (used by partners-map.js) ── */
.partner-map-pulse {
    width: 18px;
    height: 18px;
    background: var(--blue, #48BCE4);
    border: 3px solid #fff;
    border-radius: 50%;
    box-shadow:
        0 0 0 0 rgba(72, 188, 228, 0.6),
        0 4px 12px rgba(0, 0, 0, 0.25);
    animation: partnerPinPulse 2s cubic-bezier(0.66, 0, 0, 1) infinite;
}

@keyframes partnerPinPulse {
    0%   { box-shadow: 0 0 0 0   rgba(72, 188, 228, 0.55), 0 4px 12px rgba(0, 0, 0, 0.25); }
    70%  { box-shadow: 0 0 0 18px rgba(72, 188, 228, 0),    0 4px 12px rgba(0, 0, 0, 0.25); }
    100% { box-shadow: 0 0 0 0   rgba(72, 188, 228, 0),    0 4px 12px rgba(0, 0, 0, 0.25); }
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 700px) {
    .partner-hero {
        grid-template-columns: auto minmax(0, 1fr);
        grid-template-rows: auto auto;
        gap: 16px 16px;
        padding: 16px 18px;
    }
    .partner-hero-logo-wrap {
        width: 72px;
        height: 72px;
        padding: 8px;
    }
    .partner-hero-name { font-size: 17px; }
    .partner-hero-desc { -webkit-line-clamp: 2; }
    .partner-hero-cta {
        grid-column: 1 / -1;
        justify-content: flex-start;
        gap: 14px;
    }
}

@media (max-width: 900px) {
    .partner-single-header {
        grid-template-columns: 1fr;
        text-align: center;
    }
    .partner-single-logo-wrap { max-width: 200px; margin: 0 auto; }
    .partner-single-location { justify-content: center; }
    .partner-accent-line { margin-left: auto; margin-right: auto; }
    .partner-single-grid {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    .partner-single-map-wrap { position: static; }
    .partner-single-map { height: 320px; }
}

@media (max-width: 600px) {
    .partners-section { padding: 70px 0 80px; }
    .partner-hero { padding: 24px 20px; }
    .partner-hero-logo-wrap { padding: 18px; }
    .partner-hero-name { font-size: 26px; }
    .partner-hero-cta .partner-btn { padding: 12px 18px; }
    .partner-single-header { padding: 28px 22px; }
    .partner-single-content,
    .partner-single-contact { padding: 22px; }
}

/* ── Touch devices: swap 3D flip for opacity crossfade ─────
   iOS Safari and several Android browsers do not reliably respect
   backface-visibility on absolutely-positioned faces inside a
   preserve-3d parent, causing the front face to bleed through the
   back after .is-flipped is toggled. The crossfade is bullet-proof
   and indistinguishable visually for the user. */
@media (hover: none) {
    .partner-card-flipper {
        transform: none !important;
        transform-style: flat;
    }
    .partner-card-face {
        transition: opacity 0.35s ease, visibility 0.35s ease;
    }
    .partner-card-face--back {
        transform: none;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
    }
    .partner-card.is-flipped .partner-card-face--front {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
    }
    .partner-card.is-flipped .partner-card-face--back {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }
}

/* ── Reduced motion ───────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .partner-hero-shimmer,
    .partner-map-pulse,
    .partners-section::after,
    .partners-blob {
        animation: none !important;
    }
    .partner-card,
    .partner-card-flipper,
    .partner-card-foil,
    .partner-card-img,
    .partner-card-back-cta,
    .partner-card-flip-hint { transition: none !important; }
    /* Skip the 3D flip — show the back face directly on hover/focus instead. */
    .partner-card-flipper { transform: none !important; }
    .partner-card-face--back { transform: none; opacity: 0; pointer-events: none; transition: opacity 0.2s !important; }
    .partner-card:hover .partner-card-face--back,
    .partner-card:focus-visible .partner-card-face--back,
    .partner-card.is-flipped .partner-card-face--back { opacity: 1; pointer-events: auto; }
}
