/* =====================================================
   KAVO Public Profile — kavo-pp-*
   Design System: DM Sans, Bootstrap 5 base, mobile-first
   ===================================================== */

/* ── Design Tokens ── */
:root {
  color-scheme: light;
  --kavo-pp-bg:           #f4f5f7;
  --kavo-pp-surface:      #ffffff;
  --kavo-pp-border:       #e6e8ec;
  --kavo-pp-text-1:       #111827;
  --kavo-pp-text-2:       #6b7280;
  --kavo-pp-text-3:       #9ca3af;
  --kavo-pp-tab-active:   #ffffff;
  --kavo-pp-tab-pill:     #e9eaee;
  --kavo-pp-badge-bg:     rgba(18,18,18,0.68);
  --kavo-pp-red:          #ef4444;
  --kavo-pp-red-soft:     #fef2f2;
  --kavo-pp-blue:         #2563eb;
  --kavo-pp-blue-soft:    #eff6ff;
  --kavo-pp-green:        #047857;
  --kavo-pp-orange:       #ea580c;
  --kavo-pp-radius-card:  16px;
  --kavo-pp-radius-pill:  50px;
  --kavo-pp-shadow-card:  0 1px 3px rgba(0,0,0,0.06), 0 4px 14px rgba(0,0,0,0.06);
  --kavo-pp-shadow-surf:  0 1px 3px rgba(0,0,0,0.05), 0 2px 8px rgba(0,0,0,0.04);
  --kavo-pp-txt-xs:       clamp(10px,  1.1vw, 11.5px);
  --kavo-pp-txt-sm:       clamp(11.5px,1.3vw, 13px);
  --kavo-pp-txt-base:     clamp(13px,  1.5vw, 14px);
  --kavo-pp-txt-lg:       clamp(18px,  2.2vw, 22px);
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .kavo-pp-card,
  .kavo-pp-btn-action,
  .kavo-pp-hero-btn,
  .kavo-pp-tab-btn,
  .kavo-pp-tour-root,
  .kavo-pp-tour-card,
  .kavo-pp-tour-btn,
  .kavo-pp-tour-close,
  .kavo-pp-tour-target::after { transition: none !important; animation: none !important; }
}

/* ── Body override ── */
body {
  background: var(--kavo-pp-bg) !important;
  font-family: 'DM Sans', 'Inter', sans-serif;
  min-block-size: 100dvh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ── PAGE WRAP ── */
.kavo-pp-page {
  max-inline-size: 1040px;
  margin-inline: auto;
  padding-block-start: 24px;
  padding-block-end: 32px;
}
@media (min-width: 720px) {
  .kavo-pp-page { padding-block-start: 32px; }
}

/* ════════════════════════
   COVER
════════════════════════ */
.kavo-pp-cover {
  position: relative;
  inline-size: 100%;
  block-size: clamp(160px, 22vw, 260px);
  overflow: hidden;
  border-radius: 16px;
  background: linear-gradient(135deg, #1a2a1e 0%, #0f2318 50%, #0d1f15 100%);
}
.kavo-pp-cover img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  display: block;
}
.kavo-pp-cover-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 50%, rgba(0,0,0,0.20));
  pointer-events: none;
}
.kavo-pp-cover-camera {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 14px;
  min-height: 36px;
  border-radius: var(--kavo-pp-radius-pill);
  border: 1px solid rgba(255,255,255,0.22);
  background: rgba(17,24,39,0.72);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: background 0.15s, border-color 0.15s;
}
.kavo-pp-cover-camera:hover {
  background: rgba(17,24,39,0.84);
  border-color: rgba(255,255,255,0.34);
}

/* ════════════════════════
   INNER LAYOUT — mobile first
════════════════════════ */
.kavo-pp-inner { padding: 0; }

/* ── Profile Card ── */
.kavo-pp-profile-card {
  background: var(--kavo-pp-surface);
  border-end-start-radius: 20px;
  border-end-end-radius: 20px;
  padding: 0 16px 20px;
  box-shadow: var(--kavo-pp-shadow-surf);
}

/* ── Avatar Row ── */
.kavo-pp-avatar-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-block-start: -44px;
  position: relative;
  z-index: 2;
}
.kavo-pp-avatar-wrap {
  inline-size: 84px;
  block-size: 84px;
  border-radius: 50%;
  border: 3.5px solid #fff;
  background: #e5e7eb;
  box-shadow: 0 2px 14px rgba(0,0,0,0.18);
  overflow: hidden;
  flex-shrink: 0;
  position: relative;
}
.kavo-pp-avatar-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.kavo-pp-avatar-placeholder {
  font-size: 2.8rem;
  color: #9ca3af;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.kavo-pp-avatar-camera-overlay {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(0,0,0,0.42);
  border: none;
  color: #fff;
  font-size: 1.1rem;
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3;
}
.kavo-pp-avatar-wrap:hover .kavo-pp-avatar-camera-overlay { display: flex; }
.kavo-pp-avatar-upload-spinner {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(0,0,0,0.5);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 4;
}

/* ── Hero Action Buttons ── */
.kavo-pp-hero-actions {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  padding-block-end: 4px;
}
.kavo-pp-hero-btn {
  display: grid;
  place-items: center;
  inline-size: 36px;
  block-size: 36px;
  border-radius: 50%;
  border: 1.5px solid var(--kavo-pp-border);
  background: var(--kavo-pp-surface);
  color: var(--kavo-pp-text-1);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  box-shadow: 0 1px 4px rgba(0,0,0,0.09);
  font-size: 15px;
  text-decoration: none;
}
.kavo-pp-hero-btn:hover {
  background: #f3f4f6;
  border-color: #c5c8ce;
  color: var(--kavo-pp-text-1);
  text-decoration: none;
}
.kavo-pp-hero-btn:active { scale: 0.95; }
.kavo-pp-hero-btn:focus-visible { outline: 2px solid var(--kavo-pp-blue); outline-offset: 2px; }

/* ── Profile Info ── */
.kavo-pp-info { margin-block-start: 12px; }

.kavo-pp-name {
  font-size: clamp(18px, 4vw, 22px);
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--kavo-pp-text-1);
  margin: 0;
  line-height: 1.2;
  text-wrap: balance;
}
.kavo-pp-username {
  font-size: var(--kavo-pp-txt-sm);
  color: var(--kavo-pp-text-3);
  margin-block-start: 1px;
}
.kavo-pp-bio {
  margin-block-start: 9px;
  font-size: var(--kavo-pp-txt-sm);
  line-height: 1.65;
  color: var(--kavo-pp-text-2);
  white-space: pre-line;
  max-inline-size: 100%;
}

/* ── Badges ── */
.kavo-pp-badges {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-block-start: 8px;
}
.kavo-pp-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--kavo-pp-radius-pill);
  line-height: 1.4;
}
.kavo-pp-badge--dealer   { background: #ECFDF5; color: #047857; border: 1px solid #A7F3D0; }
.kavo-pp-badge--verified { background: #EFF6FF; color: #1D4ED8; border: 1px solid #BFDBFE; }
.kavo-pp-badge--member {
  font-size: 11px;
  color: var(--kavo-pp-text-3);
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ── Stats Row ── */
.kavo-pp-stats {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-block-start: 12px;
  flex-wrap: wrap;
}
.kavo-pp-stat {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: var(--kavo-pp-txt-sm);
  font-weight: 500;
  color: var(--kavo-pp-text-1);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-family: inherit;
}
.kavo-pp-stat:hover { text-decoration: underline; }
.kavo-pp-stat--plain { cursor: default; }
.kavo-pp-stat--plain:hover { text-decoration: none; }
.kavo-pp-stat-divider {
  inline-size: 1px;
  block-size: 13px;
  background: var(--kavo-pp-border);
  flex-shrink: 0;
}

/* ── Location ── */
.kavo-pp-location {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-block-start: 9px;
  font-size: var(--kavo-pp-txt-sm);
  color: var(--kavo-pp-text-2);
}

/* ── Social Links ── */
.kavo-pp-social-links {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-block-start: 10px;
}
.kavo-pp-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 30px;
  block-size: 30px;
  border-radius: 8px;
  border: 1px solid var(--kavo-pp-border);
  background: var(--kavo-pp-surface);
  color: var(--kavo-pp-text-2);
  font-size: 15px;
  text-decoration: none;
  transition: color 0.15s, border-color 0.15s;
}
.kavo-pp-social-link:hover            { color: #1F2937; border-color: #1F2937; text-decoration: none; }
.kavo-pp-social-link--instagram:hover { color: #e1306c; border-color: #e1306c; }
.kavo-pp-social-link--facebook:hover  { color: #1877f2; border-color: #1877f2; }

/* ── Action Buttons ── */
.kavo-pp-action-buttons {
  display: flex;
  gap: 6px;
  margin-block-start: 16px;
  flex-wrap: wrap;
}
.kavo-pp-btn-action {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 8px 12px;
  border: 1.5px solid var(--kavo-pp-border);
  border-radius: var(--kavo-pp-radius-pill);
  background: var(--kavo-pp-surface);
  font-family: 'DM Sans', 'Inter', sans-serif;
  font-size: var(--kavo-pp-txt-sm);
  font-weight: 500;
  color: var(--kavo-pp-text-1);
  cursor: pointer;
  white-space: nowrap;
  flex: 1;
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  min-height: 36px;
}
.kavo-pp-btn-action:hover {
  background: var(--kavo-pp-bg);
  border-color: #c5c8ce;
  color: var(--kavo-pp-text-1);
  text-decoration: none;
}
.kavo-pp-btn-action:active { transform: scale(0.97); }
.kavo-pp-btn-action:focus-visible { outline: 2px solid var(--kavo-pp-blue); outline-offset: 2px; }

.kavo-pp-btn-action--primary {
  background: var(--kavo-pp-text-1);
  border-color: var(--kavo-pp-text-1);
  color: #fff;
}
.kavo-pp-btn-action--primary:hover {
  background: #1f2937;
  border-color: #1f2937;
  color: #fff;
}
.kavo-pp-btn-action--follow {
  background: var(--kavo-pp-text-1);
  border-color: var(--kavo-pp-text-1);
  color: #fff;
}
.kavo-pp-btn-action--follow:hover {
  background: #1f2937;
  border-color: #1f2937;
  color: #fff;
}
.kavo-pp-btn-action--following {
  background: var(--kavo-pp-surface);
  border-color: var(--kavo-pp-border);
  color: var(--kavo-pp-text-1);
}
.kavo-pp-btn-action.is-loading {
  opacity: 0.7;
  pointer-events: none;
}
.kavo-pp-follow-spinner {
  display: none;
  inline-size: 14px;
  block-size: 14px;
  border: 2px solid rgba(255,255,255,0.35);
  border-top-color: currentColor;
  border-radius: 50%;
  animation: kavo-pp-spin 0.6s linear infinite;
  flex-shrink: 0;
}
.kavo-pp-btn-action.is-loading .kavo-pp-follow-spinner { display: inline-block; }

@keyframes kavo-pp-spin { to { transform: rotate(360deg); } }

/* ── Main Column ── */
.kavo-pp-main {
  margin-block-start: 10px;
  padding-inline: 14px;
}

/* ════════════════════════
   DESKTOP ≥ 720px
════════════════════════ */
@media (min-width: 720px) {
  .kavo-pp-inner {
    display: grid;
    grid-template-columns: 290px 1fr;
    gap: 20px;
    padding: 20px 24px 0;
    align-items: start;
  }
  .kavo-pp-profile-card {
    border-radius: 16px;
    padding: 20px;
    position: sticky;
    top: 80px;
  }
  .kavo-pp-avatar-row { margin-block-start: 0; }
  .kavo-pp-main { margin-block-start: 0; padding-inline: 0; }
}

/* ════════════════════════
   TABS — Pill style
════════════════════════ */
.kavo-pp-tabs { margin-block-end: 16px; }
.kavo-pp-tabs-pill {
  display: flex;
  background: #e9eaee;
  border-radius: 50px;
  padding: 4px;
  gap: 3px;
  inline-size: 100%;
}
.kavo-pp-tab-btn {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 12px;
  border-radius: 50px;
  border: 1.5px solid transparent;
  background: transparent;
  font-family: 'DM Sans', 'Inter', sans-serif;
  font-size: var(--kavo-pp-txt-base);
  font-weight: 500;
  color: var(--kavo-pp-text-3);
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.18s, color 0.18s, box-shadow 0.18s, border-color 0.18s;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  line-height: 1;
}
.kavo-pp-tab-btn i {
  font-size: 13px;
  line-height: 1;
}
.kavo-pp-tab-btn.is-active {
  background: #ffffff;
  color: var(--kavo-pp-text-1);
  border-color: rgba(0,0,0,0.08);
  box-shadow: 0 1px 4px rgba(0,0,0,0.10), 0 0 0 0.5px rgba(0,0,0,0.04);
  font-weight: 600;
}
.kavo-pp-tab-btn:not(.is-active):hover {
  background: rgba(255,255,255,0.55);
  color: var(--kavo-pp-text-2);
}
.kavo-pp-tab-panel { display: none; }
.kavo-pp-tab-panel.is-active { display: block; }

/* ════════════════════════
   VEHICLE GRID
════════════════════════ */
.kavo-pp-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(10px, 1.5vw, 14px);
}
@media (min-width: 900px) {
  .kavo-pp-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ── Card ── */
.kavo-pp-card {
  background: var(--kavo-pp-surface);
  border-radius: var(--kavo-pp-radius-card);
  overflow: hidden;
  box-shadow: var(--kavo-pp-shadow-card);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.kavo-pp-card:hover {
  text-decoration: none;
  color: inherit;
}
.kavo-pp-card:focus-visible { outline: 2px solid var(--kavo-pp-blue); outline-offset: 2px; }

.kavo-pp-card-media {
  position: relative;
  aspect-ratio: 4 / 3;
  background: #f0f0f2;
  overflow: hidden;
}
.kavo-pp-card-media img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  display: block;
}
.kavo-pp-card-placeholder {
  inline-size: 100%;
  block-size: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #d1d5db;
  font-size: 2.5rem;
}

/* ── Status Badge ── */
.kavo-pp-card-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--kavo-pp-badge-bg);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.8px;
  padding: 3px 8px;
  border-radius: var(--kavo-pp-radius-pill);
  text-transform: uppercase;
  z-index: 2;
}
.kavo-pp-card-badge--success { background: var(--kavo-pp-green); }
.kavo-pp-card-badge--warning { background: var(--kavo-pp-orange); }
.kavo-pp-card-badge--danger  { background: var(--kavo-pp-red); }
.kavo-pp-card-badge--neutral { background: #6b7280; }

/* ── NEW Badge ── */
.kavo-pp-card-badge--new {
  position: absolute;
  top: 8px;
  left: 8px;
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  color: #fff;
  font-size: 9.5px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--kavo-pp-radius-pill);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  z-index: 2;
  box-shadow: 0 2px 6px rgba(99,102,241,0.35);
}

/* ── Like Button (card footer) ── */
.kavo-pp-card-like {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px 8px;
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: var(--kavo-pp-txt-xs);
  font-weight: 500;
  color: var(--kavo-pp-text-3);
  transition: color 0.15s;
}
.kavo-pp-card-like:hover { color: var(--kavo-pp-red); }
.kavo-pp-card-like i { font-size: 14px; transition: transform 0.2s; }
.kavo-pp-card-like:active i { transform: scale(1.3); }
.kavo-pp-card-like--active { color: var(--kavo-pp-red); }
.kavo-pp-card-like--active i { font-weight: 900; }

/* ── Card Body ── */
.kavo-pp-card-body { padding: 10px 11px 0; flex: 1; }
.kavo-pp-card-title {
  font-size: var(--kavo-pp-txt-sm);
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -0.1px;
  color: var(--kavo-pp-text-1);
  margin: 0;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
}
.kavo-pp-card-meta  { font-size: var(--kavo-pp-txt-xs); color: var(--kavo-pp-text-3); margin-block-start: 2px; }
.kavo-pp-card-price {
  font-size: 15px;
  font-weight: 700;
  color: var(--kavo-pp-green);
  margin-block-start: 4px;
  letter-spacing: -0.01em;
  padding-block-end: 4px;
}

/* ── 🧍 PF ONLY — Fase 4: validade + ticket da licença avulsa ── */
.kavo-pp-card-license {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-block-start: 6px;
  padding-block-start: 6px;
  border-top: 1px dashed var(--kavo-pp-border);
  font-size: var(--kavo-pp-txt-xs);
  color: var(--kavo-pp-text-2);
}
.kavo-pp-card-license__expiry,
.kavo-pp-card-license__code {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  line-height: 1.25;
}
.kavo-pp-card-license__expiry i,
.kavo-pp-card-license__code i {
  font-size: 12px;
  opacity: 0.8;
}
.kavo-pp-card-license__expiry {
  color: var(--kavo-pp-green);
  font-weight: 600;
}
.kavo-pp-card-license__code {
  align-self: flex-start;
  background: rgba(0,0,0,0.04);
  border: 1px solid var(--kavo-pp-border);
  border-radius: 4px;
  padding: 2px 6px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 10.5px;
  letter-spacing: 0.02em;
  color: var(--kavo-pp-text-2);
}

/* ── Card Actions (owner) ── */
.kavo-pp-card-actions {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 9px 10px 11px;
  margin-block-start: 8px;
  border-top: 1px solid var(--kavo-pp-border);
}
.kavo-pp-card-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex: 1;
  padding: 6px;
  border-radius: 8px;
  border: 1.5px solid var(--kavo-pp-border);
  background: transparent;
  font-family: 'DM Sans', 'Inter', sans-serif;
  font-size: var(--kavo-pp-txt-xs);
  font-weight: 500;
  color: var(--kavo-pp-text-2);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  white-space: nowrap;
  touch-action: manipulation;
  text-decoration: none;
  min-height: 30px;
}
.kavo-pp-card-btn:hover {
  background: var(--kavo-pp-bg);
  color: var(--kavo-pp-text-1);
  text-decoration: none;
}
.kavo-pp-card-btn:focus-visible { outline: 2px solid var(--kavo-pp-blue); outline-offset: 2px; }

.kavo-pp-card-btn--pay {
  border-color: rgba(37,99,235,0.18);
  color: var(--kavo-pp-blue);
  background: var(--kavo-pp-blue-soft);
}
.kavo-pp-card-btn--pay:hover {
  background: #dbeafe;
  border-color: rgba(37,99,235,0.4);
  color: var(--kavo-pp-blue);
}
.kavo-pp-card-btn--del {
  flex: none;
  inline-size: 30px;
  padding: 6px;
  border-color: var(--kavo-pp-red);
  color: #fff;
  background: var(--kavo-pp-red);
}
.kavo-pp-card-btn--del:hover { background: #dc2626; border-color: #dc2626; color: #fff; }

/* ── Owner menu trigger ── */
.kavo-pp-card-menu-trigger {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 3;
  inline-size: 30px;
  block-size: 30px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,0.45);
  color: #fff;
  display: grid;
  place-items: center;
  cursor: pointer;
  font-size: 14px;
  transition: background 0.15s;
}
.kavo-pp-card-menu-trigger:hover { background: rgba(0,0,0,0.65); }

/* ── Saved wrapper ── */
.kavo-pp-saved-wrap { position: relative; }
.kavo-pp-unsave-btn {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 3;
  inline-size: 30px;
  block-size: 30px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,0.45);
  color: #fff;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background 0.15s;
}
.kavo-pp-unsave-btn:hover { background: var(--kavo-pp-red); }

/* ── Owner card ── */
.kavo-pp-card--owner { position: relative; }

/* ── Reduced motion — also covers card transitions ── */
@media (prefers-reduced-motion: reduce) {
  .kavo-pp-card, .kavo-pp-card--owner { transition: none !important; }
}

/* ════════════════════════
   EMPTY STATE
════════════════════════ */
.kavo-pp-empty {
  text-align: center;
  padding: 52px 24px;
  color: var(--kavo-pp-text-3);
  font-size: var(--kavo-pp-txt-base);
  border: 1px solid var(--kavo-pp-border);
  border-radius: var(--kavo-pp-radius-card);
  background: var(--kavo-pp-surface);
}
.kavo-pp-empty i {
  font-size: 2.5rem;
  display: block;
  margin-block-end: 12px;
  opacity: 0.4;
}
.kavo-pp-empty-btn-hidden {
  display: none;
  align-items: center;
  gap: 6px;
  margin-block-start: 14px;
  padding: 8px 18px;
  border-radius: var(--kavo-pp-radius-pill);
  border: 1.5px solid var(--kavo-pp-text-1);
  background: var(--kavo-pp-text-1);
  color: #fff;
  font-size: var(--kavo-pp-txt-sm);
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s;
}
.kavo-pp-empty-btn:hover { background: #1f2937; color: #fff; text-decoration: none; }

/* ════════════════════════
   MODAL SYSTEM
════════════════════════ */
.kavo-pp-modal-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.38);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  align-items: center;
  justify-content: center;
  z-index: 1060;
  padding-inline: 16px;
}
.kavo-pp-modal-backdrop.is-open { display: flex; }

@media (max-width: 479px) {
  .kavo-pp-modal-backdrop {
    align-items: flex-end;
    padding-inline: 0;
  }
}
.kavo-pp-modal-box {
  background: var(--kavo-pp-surface);
  border-radius: 20px;
  padding: 28px 24px 20px;
  max-inline-size: 340px;
  inline-size: 100%;
  box-shadow: 0 24px 64px rgba(0,0,0,0.18);
  animation: kavo-pp-modal-in 0.22s cubic-bezier(.34,1.56,.64,1);
}
@media (max-width: 479px) {
  .kavo-pp-modal-box {
    border-radius: 20px 20px 0 0;
    max-inline-size: 100%;
    padding-bottom: max(20px, env(safe-area-inset-bottom));
  }
}
@keyframes kavo-pp-modal-in {
  from { opacity: 0; transform: scale(0.90) translateY(10px); }
  to   { opacity: 1; transform: none; }
}

/* @starting-style: animate modal-box on first paint (Chrome 117+, Firefox 129+) */
@supports (animation-timeline: scroll()) {
  .kavo-pp-modal-backdrop.is-open .kavo-pp-modal-box {
    @starting-style {
      opacity: 0;
      transform: scale(0.90) translateY(10px);
    }
    transition: opacity 0.22s cubic-bezier(.34,1.56,.64,1),
                transform 0.22s cubic-bezier(.34,1.56,.64,1);
  }
}
.kavo-pp-modal-icon  { text-align: center; margin-block-end: 12px; }
.kavo-pp-modal-title { font-size: 17px; font-weight: 600; text-align: center; color: var(--kavo-pp-text-1); margin: 0; }
.kavo-pp-modal-desc  {
  font-size: 13px;
  color: var(--kavo-pp-text-2);
  text-align: center;
  margin-block-start: 7px;
  line-height: 1.65;
}
.kavo-pp-modal-actions {
  display: flex;
  gap: 8px;
  margin-block-start: 20px;
}
.kavo-pp-modal-btn {
  flex: 1;
  padding: 11px;
  border-radius: 11px;
  border: none;
  font-family: 'DM Sans', 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: opacity 0.15s;
  touch-action: manipulation;
}
.kavo-pp-modal-btn:hover { opacity: 0.85; }
.kavo-pp-modal-btn--cancel  { background: var(--kavo-pp-bg); color: var(--kavo-pp-text-1); }
.kavo-pp-modal-btn--confirm { background: var(--kavo-pp-red); color: #fff; }
.kavo-pp-modal-btn--primary { background: var(--kavo-pp-text-1); color: #fff; }

/* Share modal */
.kavo-pp-share-url-box {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--kavo-pp-bg);
  border: 1px solid var(--kavo-pp-border);
  border-radius: 10px;
  padding: 10px 14px;
  margin-block-start: 14px;
}
.kavo-pp-share-url-box span {
  flex: 1;
  font-size: 12px;
  color: var(--kavo-pp-text-2);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

/* Quick Edit Modal form */
.kavo-pp-qe-form  { display: flex; flex-direction: column; gap: 12px; margin-block-start: 16px; }
.kavo-pp-qe-label { font-size: 12px; font-weight: 600; color: var(--kavo-pp-text-1); display: block; margin-block-end: 4px; }
.kavo-pp-qe-input {
  inline-size: 100%;
  padding: 9px 12px;
  border: 1.5px solid var(--kavo-pp-border);
  border-radius: 10px;
  font-family: 'DM Sans', 'Inter', sans-serif;
  font-size: 13px;
  color: var(--kavo-pp-text-1);
  background: var(--kavo-pp-surface);
  transition: border-color 0.15s;
  box-sizing: border-box;
}
.kavo-pp-qe-input:focus { outline: none; border-color: var(--kavo-pp-text-1); }
.kavo-pp-qe-textarea { resize: vertical; min-block-size: 80px; }
.kavo-pp-qe-tour-note {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-block-end: 16px;
  padding: 14px 15px;
  border: 1px solid rgba(4, 120, 87, 0.16);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(236, 253, 245, 0.96), rgba(240, 253, 244, 0.92));
  color: var(--kavo-pp-text-1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}
.kavo-pp-qe-tour-note[hidden] { display: none !important; }
.kavo-pp-qe-tour-note p {
  margin: 0;
  font-size: 13px;
  line-height: 1.6;
  color: var(--kavo-pp-text-2);
}
.kavo-pp-qe-tour-note .kavo-pp-tour-btn {
  align-self: flex-end;
}

/* ════════════════════════
   PROFILE ONBOARDING TOUR
════════════════════════ */
.kavo-pp-tour-root {
  position: fixed;
  inset: 0;
  z-index: 20000;
  display: none;
  isolation: isolate;
}
.kavo-pp-tour-root.is-open {
  display: block;
}
.kavo-pp-tour-veil,
.kavo-pp-tour-catcher,
.kavo-pp-tour-card {
  position: fixed;
  inset: 0;
}
.kavo-pp-tour-veil {
  background: rgba(9, 15, 25, 0.72);
  backdrop-filter: blur(2px) saturate(90%);
  -webkit-backdrop-filter: blur(2px) saturate(90%);
}
.kavo-pp-tour-catcher {
  background: transparent;
  cursor: pointer;
  z-index: 2;
}
.kavo-pp-tour-card {
  z-index: 3;
  inline-size: min(360px, calc(100vw - 24px));
  max-inline-size: min(360px, calc(100vw - 24px));
  padding: 18px 18px 16px;
  border: 1px solid rgba(148, 163, 184, 0.28);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.98));
  box-shadow: 0 32px 80px rgba(2, 6, 23, 0.35);
  color: var(--kavo-pp-text-1);
  display: flex;
  flex-direction: column;
  gap: 10px;
  animation: kavo-pp-tour-card-in 240ms cubic-bezier(.22, 1, .36, 1);
  will-change: transform, opacity;
}
.kavo-pp-tour-card--center {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  inline-size: min(440px, calc(100vw - 24px));
  max-inline-size: min(440px, calc(100vw - 24px));
  text-align: center;
}
.kavo-pp-tour-card--center .kavo-pp-tour-footer {
  justify-content: center;
}
.kavo-pp-tour-card--mobile {
  left: 12px;
  right: 12px;
  top: auto !important;
  bottom: 12px;
  inline-size: auto;
  max-inline-size: none;
  max-block-size: calc(100dvh - 24px);
  overflow: auto;
}
.kavo-pp-tour-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kavo-pp-green);
}
.kavo-pp-tour-title {
  margin: 0;
  font-size: 20px;
  line-height: 1.15;
  font-weight: 700;
  text-wrap: balance;
}
.kavo-pp-tour-copy {
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
  color: var(--kavo-pp-text-2);
  text-wrap: pretty;
}
.kavo-pp-tour-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-block-start: 2px;
}
.kavo-pp-tour-btn {
  appearance: none;
  border: none;
  font: inherit;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-decoration: none;
  transition: background-color 0.18s ease, color 0.18s ease, opacity 0.18s ease, transform 0.18s ease;
}
.kavo-pp-tour-btn:hover { opacity: 0.95; }
.kavo-pp-tour-btn:active { transform: translateY(1px); }
.kavo-pp-tour-btn--primary {
  background: var(--kavo-pp-text-1);
  color: #fff;
}
.kavo-pp-tour-btn--primary:hover { background: #1f2937; }
.kavo-pp-tour-btn--ghost {
  background: var(--kavo-pp-bg);
  color: var(--kavo-pp-text-1);
}
.kavo-pp-tour-btn--ghost:hover { background: #e5e7eb; }
.kavo-pp-tour-close {
  align-self: flex-end;
  inline-size: 34px;
  block-size: 34px;
  display: grid;
  place-items: center;
  border: none;
  border-radius: 50%;
  background: rgba(17, 24, 39, 0.06);
  color: var(--kavo-pp-text-2);
  cursor: pointer;
  transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}
.kavo-pp-tour-close:hover {
  background: rgba(17, 24, 39, 0.1);
  color: var(--kavo-pp-text-1);
}
.kavo-pp-tour-target {
  position: relative !important;
  z-index: 20005 !important;
  pointer-events: none !important;
  isolation: isolate;
}
.kavo-pp-tour-target::after {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: inherit;
  border: 2px solid rgba(34, 197, 94, 0.95);
  box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.28);
  animation: kavo-pp-tour-pulse 1.4s cubic-bezier(.22, 1, .36, 1) infinite;
  pointer-events: none;
}

@keyframes kavo-pp-tour-card-in {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes kavo-pp-tour-pulse {
  0% {
    opacity: 0.28;
    transform: scale(0.98);
  }
  70% {
    opacity: 0;
    transform: scale(1.09);
  }
  100% {
    opacity: 0;
    transform: scale(1.09);
  }
}

/* ── Quick edit spinner ── */
.kavo-pp-btn-spinner {
  display: none;
  inline-size: 14px;
  block-size: 14px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: currentColor;
  border-radius: 50%;
  animation: kavo-pp-spin 0.6s linear infinite;
}

/* ════════════════════════
   FOLLOW LIST MODAL
════════════════════════ */
.kavo-pp-fl-backdrop {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,0.5); z-index: 10000;
  align-items: flex-end; justify-content: center;
}
.kavo-pp-fl-backdrop.is-open { display: flex; }
@media (min-width: 480px) { .kavo-pp-fl-backdrop { align-items: center; } }

.kavo-pp-fl-modal {
  background: var(--kavo-pp-surface);
  border-radius: 20px 20px 0 0;
  inline-size: 100%; max-inline-size: 460px;
  max-block-size: 80vh; display: flex; flex-direction: column; overflow: hidden;
}
@media (min-width: 480px) { .kavo-pp-fl-modal { border-radius: 20px; max-block-size: 70vh; } }

.kavo-pp-fl-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1rem 0.75rem;
  border-bottom: 1px solid var(--kavo-pp-border);
}
.kavo-pp-fl-title { font-size: 1rem; font-weight: 700; color: var(--kavo-pp-text-1); }
.kavo-pp-fl-close { background: none; border: none; font-size: 1.125rem; color: var(--kavo-pp-text-3); cursor: pointer; padding: 0.25rem; }
.kavo-pp-fl-tabs  { display: flex; border-bottom: 1px solid var(--kavo-pp-border); }
.kavo-pp-fl-tab   {
  flex: 1; padding: 0.625rem; font-size: 0.8125rem; font-weight: 600;
  background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--kavo-pp-text-3); cursor: pointer;
}
.kavo-pp-fl-tab.is-active { color: var(--kavo-pp-text-1); border-bottom-color: var(--kavo-pp-text-1); }
.kavo-pp-fl-tab span { font-size: 0.75rem; color: var(--kavo-pp-text-3); margin-left: 0.25rem; }
.kavo-pp-fl-body   { flex: 1; overflow-y: auto; padding: 0.5rem 0; }
.kavo-pp-fl-spinner {
  inline-size: 28px; block-size: 28px;
  border: 3px solid var(--kavo-pp-border); border-top-color: var(--kavo-pp-text-1);
  border-radius: 50%; animation: kavo-pp-spin 0.6s linear infinite; margin: 2rem auto;
}
.kavo-pp-fl-item   { display: flex; align-items: center; gap: 0.75rem; padding: 0.625rem 1rem; }
.kavo-pp-fl-avatar { inline-size: 44px; block-size: 44px; border-radius: 50%; background: var(--kavo-pp-bg); overflow: hidden; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; color: var(--kavo-pp-text-3); }
.kavo-pp-fl-avatar img { inline-size: 100%; block-size: 100%; object-fit: cover; }
.kavo-pp-fl-info   { flex: 1; min-inline-size: 0; }
.kavo-pp-fl-name   { font-size: 0.875rem; font-weight: 600; color: var(--kavo-pp-text-1); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.kavo-pp-fl-btn    { padding: 0.25rem 0.75rem; border-radius: 6px; font-size: 0.75rem; font-weight: 600; border: 1px solid var(--kavo-pp-border); background: var(--kavo-pp-surface); color: var(--kavo-pp-text-1); cursor: pointer; text-decoration: none; }
.kavo-pp-fl-empty  { text-align: center; padding: 2rem; color: var(--kavo-pp-text-3); font-size: 0.875rem; }

/* ════════════════════════
   OWNER ACTIONS SHEET
════════════════════════ */
.kavo-pp-owner-sheet-backdrop {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,0.5); z-index: 10001;
  align-items: flex-end; justify-content: center;
}
.kavo-pp-owner-sheet-backdrop.is-open { display: flex; }
.kavo-pp-owner-sheet {
  background: var(--kavo-pp-surface);
  border-radius: 22px 22px 0 0;
  inline-size: 100%; max-inline-size: 460px;
  padding: 0.75rem 1rem max(1rem, env(safe-area-inset-bottom));
  box-shadow: 0 24px 48px rgba(0,0,0,0.18);
}
.kavo-pp-owner-sheet-handle {
  inline-size: 44px; block-size: 5px;
  border-radius: 999px; background: #d0d5dd; margin: 0 auto 0.875rem;
}
.kavo-pp-owner-sheet-actions { display: flex; flex-direction: column; gap: 0.5rem; }
.kavo-pp-owner-sheet-actions .kavo-pp-btn-action {
  justify-content: flex-start;
  inline-size: 100%;
  padding: 0.875rem 1rem;
  font-size: 0.875rem;
  flex: none;
  border-radius: 12px;
}
.kavo-pp-owner-sheet-actions .kavo-pp-btn-action--danger {
  justify-content: center;
  background: var(--kavo-pp-red);
  border-color: var(--kavo-pp-red);
  color: #fff;
}
