/* ═══════════════════════════════════════════════════════════════════
   Partner Subpage Styles — shared across all /partner/*.html pages
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Hero ─── */
.pp-hero {
  min-height: 520px; position: relative; overflow: hidden;
  display: flex; align-items: flex-end;
  padding: 0 0 0;
}
.pp-hero-bg {
  position: absolute; inset: 0; z-index: 0;
}
.pp-hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(to bottom, rgba(26,20,24,.15) 0%, rgba(26,20,24,.65) 100%);
}
.pp-hero-content {
  position: relative; z-index: 2; color: #fff;
  padding: 140px 0 56px; width: 100%;
}
.pp-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: "Geist Mono", monospace; font-size: 11px;
  letter-spacing: .14em; color: rgba(255,255,255,.7);
  text-transform: uppercase; margin-bottom: 32px;
  transition: color .2s;
}
.pp-back:hover { color: #fff; }
.pp-back svg { transition: transform .2s; }
.pp-back:hover svg { transform: translateX(-3px); }

.pp-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 7px 14px; border-radius: 999px;
  background: rgba(255,255,255,.15); backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-family: "Geist Mono", monospace; font-size: 11px;
  letter-spacing: .18em; color: rgba(255,255,255,.9);
  text-transform: uppercase; margin-bottom: 20px;
}
.pp-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: #7dd07d; }

.pp-hero-name {
  font-family: "Instrument Serif", serif; font-size: clamp(42px, 6vw, 80px);
  line-height: 1.04; letter-spacing: -.025em; text-wrap: balance;
  margin-bottom: 16px;
}
.pp-hero-meta {
  display: flex; flex-wrap: wrap; gap: 20px;
  font-family: "Geist Mono", monospace; font-size: 12px;
  letter-spacing: .1em; color: rgba(255,255,255,.75); text-transform: uppercase;
}
.pp-hero-meta span { display: flex; align-items: center; gap: 8px; }

/* ─── Info Strip ─── */
.pp-info-strip {
  background: var(--ink); color: var(--paper);
  padding: 28px 0;
}
.pp-info-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: rgba(255,255,255,.08);
  border-radius: 0; overflow: hidden;
}
@media (max-width: 780px) { .pp-info-grid { grid-template-columns: repeat(2, 1fr); } }
.pp-info-cell { padding: 20px 24px; }
.pp-info-label { font-family: "Geist Mono", monospace; font-size: 10px; letter-spacing: .18em; color: #7a6f76; text-transform: uppercase; margin-bottom: 6px; }
.pp-info-value { font-family: "Instrument Serif", serif; font-size: 20px; line-height: 1.2; }

/* ─── Main Content ─── */
.pp-main { padding: 80px 0; }
.pp-grid { display: grid; grid-template-columns: 1fr 380px; gap: 64px; align-items: start; }
@media (max-width: 1024px) { .pp-grid { grid-template-columns: 1fr; } }

.pp-body h2 { font-family: "Instrument Serif", serif; font-size: clamp(32px, 3.5vw, 48px); line-height: 1.1; letter-spacing: -.02em; margin-bottom: 20px; }
.pp-body h2 em { font-style: italic; color: var(--accent); }
.pp-body p { font-size: 16px; line-height: 1.75; color: var(--ink-2); margin-bottom: 18px; }

.pp-services { margin-top: 40px; }
.pp-services-title { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: .18em; color: var(--accent); text-transform: uppercase; margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.pp-services-title::before { content: ""; width: 20px; height: 1px; background: var(--accent); }
.pp-service-list { display: flex; flex-direction: column; gap: 12px; }
.pp-service-item { display: grid; grid-template-columns: auto 1fr; gap: 16px; padding: 18px; border: 1px solid var(--line-2); border-radius: 16px; transition: border-color .3s, background .3s; align-items: start; }
.pp-service-item:hover { border-color: color-mix(in srgb, var(--accent) 30%, var(--line)); background: color-mix(in srgb, var(--accent) 4%, transparent); }
.pp-service-ic { width: 40px; height: 40px; border-radius: 12px; background: color-mix(in srgb, var(--accent) 10%, var(--warm)); color: var(--accent); display: grid; place-items: center; flex: 0 0 auto; }
.pp-service-name { font-family: "Instrument Serif", serif; font-size: 20px; margin-bottom: 4px; }
.pp-service-desc { font-size: 13.5px; color: var(--ink-2); line-height: 1.5; }

/* ─── Gallery ─── */
.pp-gallery { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-top: 48px; }
@media (max-width: 680px) { .pp-gallery { grid-template-columns: 1fr 1fr; } }
.pp-gallery-item { border-radius: 16px; overflow: hidden; aspect-ratio: 4/3; position: relative; }
.pp-gallery-item:first-child { grid-column: 1 / span 2; aspect-ratio: 16/9; }
.pp-gallery-placeholder { position: absolute; inset: 0; display: flex; align-items: flex-end; padding: 14px; }
.pp-gallery-label { font-family: "Geist Mono", monospace; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.85); background: rgba(0,0,0,.3); backdrop-filter: blur(8px); padding: 5px 10px; border-radius: 999px; }

/* ─── Sidebar ─── */
.pp-sidebar { position: sticky; top: 100px; }
.pp-contact-card {
  background: var(--paper); border: 1px solid var(--line-2); border-radius: 24px;
  overflow: hidden; box-shadow: 0 24px 48px -24px rgba(46,30,40,.12);
}
.pp-contact-head {
  padding: 28px 28px 0;
  border-bottom: 1px solid var(--line-2); padding-bottom: 20px;
}
.pp-contact-logo {
  width: 48px; height: 48px; border-radius: 14px;
  display: grid; place-items: center; margin-bottom: 14px;
  font-family: "Instrument Serif", serif; font-size: 22px; color: #fff;
}
.pp-contact-name { font-family: "Instrument Serif", serif; font-size: 22px; line-height: 1.15; margin-bottom: 4px; }
.pp-contact-city { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: .1em; color: var(--muted); text-transform: uppercase; }

.pp-contact-body { padding: 20px 28px; display: flex; flex-direction: column; gap: 14px; }
.pp-contact-row { display: flex; align-items: center; gap: 12px; font-size: 14px; }
.pp-contact-row svg { color: var(--accent); flex: 0 0 auto; }
.pp-contact-row a { color: var(--ink-2); transition: color .2s; }
.pp-contact-row a:hover { color: var(--accent); }

.pp-contact-actions { padding: 0 28px 28px; display: flex; flex-direction: column; gap: 10px; }
.pp-contact-actions .btn { width: 100%; justify-content: center; }

.pp-mini-map { margin: 20px 28px 0; border-radius: 16px; overflow: hidden; height: 160px; background: var(--warm-2); }
.pp-mini-map iframe { width: 100%; height: 100%; border: 0; }

/* ─── Team Section ─── */
.pp-team { padding: 0 0 80px; }
.pp-team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 40px; }
@media (max-width: 780px) { .pp-team-grid { grid-template-columns: 1fr 1fr; } }
.pp-team-card {
  background: var(--paper); border: 1px solid var(--line-2); border-radius: 20px;
  padding: 24px; text-align: center; transition: transform .35s var(--ease-spring);
}
.pp-team-card:hover { transform: translateY(-4px); }
.pp-team-avatar {
  width: 72px; height: 72px; border-radius: 50%; margin: 0 auto 14px;
  display: grid; place-items: center;
  font-family: "Instrument Serif", serif; font-size: 28px; color: #fff;
}
.pp-team-name { font-family: "Instrument Serif", serif; font-size: 20px; margin-bottom: 4px; }
.pp-team-role { font-family: "Geist Mono", monospace; font-size: 11px; letter-spacing: .1em; color: var(--muted); text-transform: uppercase; }

/* ─── Leaflet Marker (shared on partner subpages) ─── */
.bv-marker {
  width: 36px; height: 36px; border-radius: 50% 50% 50% 0;
  background: var(--accent); border: 2px solid #fff;
  box-shadow: 0 4px 12px rgba(46,30,40,.35);
  transform: rotate(-45deg);
  display: grid; place-items: center;
  transition: transform .2s, box-shadow .2s;
}
.bv-marker svg { transform: rotate(45deg); }

/* ─── Partner Map (mini) ─── */
.pp-location-map { border-radius: 20px; overflow: hidden; height: 280px; margin-top: 48px; border: 1px solid var(--line-2); }
#pp-map { width: 100%; height: 100%; }
