/*
 * RPM UI Components v1 — canonical shared layer
 * Scope: reusable primitives only. Page CSS keeps layout/context.
 * Contract: badge = state, signal = icon text, chip = taxonomy/meta,
 * button = action, card = rpmx_render_listing_card(), rail = data-rpmx-rail.
 */

.rpmx-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:14px 22px;font-weight:700;line-height:1;transition:.2s ease;text-decoration:none!important;border:1px solid transparent}
.rpmx-btn--solid{background:var(--rpmx-brand);color:#fff}
.rpmx-btn--solid:hover{background:var(--rpmx-brand-dark, #d73539);color:#fff}
.rpmx-btn--ghost{background:#fff;color:var(--rpmx-text);border-color:var(--rpmx-line)}
.rpmx-btn--ghost:hover{border-color:rgba(22,34,54,.2);color:var(--rpmx-text)}
.rpmx-btn--inline{padding:0;background:transparent;color:var(--rpmx-brand);border:none}
.rpmx-btn--block{width:100%;margin-top:14px}

.rpmx-badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:8px 11px;font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;background:rgba(22,34,54,.82);color:#fff}
.rpmx-badge--open{background:rgba(10,138,97,.9)}
.rpmx-badge--closed{background:rgba(131,29,29,.88)}
.rpmx-badge--unknown{background:rgba(95,111,133,.82)}
.rpmx-badge--live{background:rgba(235,70,74,.92)}
.rpmx-badge--delivery{background:rgba(63,88,214,.92)}
.rpmx-badge--pickup{background:rgba(118,78,194,.9)}
.rpmx-badge--verified{background:rgba(10,138,97,.12);color:var(--rpmx-success);border:1px solid rgba(10,138,97,.18)}
.rpmx-badge--verified i{margin-right:6px}

.rpmx-signal-row{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:center}
.rpmx-signal{display:inline-flex;align-items:center;gap:6px;line-height:1.2}
.rpmx-signal i{color:inherit}
.rpmx-signal--verified{color:var(--rpmx-success)}
.rpmx-signal--live{color:#2563eb}
.rpmx-signal--delivery{color:#7c3aed}
.rpmx-signal--pickup{color:#d97706}

.rpmx-card-grid{display:grid;gap:18px}
.rpmx-card-grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}
.rpmx-card-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.rpmx-card{position:relative;width:100%;min-width:0;border-radius:18px;padding:0;background:#fff;border:1px solid var(--rpmx-line);box-shadow:0 10px 24px rgba(11,18,32,.06);overflow:hidden}
.rpmx-card__media{position:relative;display:block;width:100%;max-width:none;height:116px;border-radius:18px 18px 0 0;overflow:hidden;background:#eef2f7}
.rpmx-card__media img{width:100%!important;height:100%!important;object-fit:cover;object-position:center center;display:block}
.rpmx-card__media-placeholder{position:absolute;inset:0;display:grid;place-items:center;color:#95a3b8;font-size:1.9rem}
.rpmx-card__flag{position:absolute;top:10px;left:10px;z-index:2;display:inline-flex;align-items:center;min-height:24px;padding:5px 11px;border-radius:999px;font-size:.69rem;font-weight:900;letter-spacing:.01em;text-transform:uppercase;color:#fff;box-shadow:0 8px 18px rgba(11,18,32,.18)}
.rpmx-card__flag--open{background:#16a34a}
.rpmx-card__flag--closed{background:#b91c1c}
.rpmx-card__flag--unknown{background:#475569}
.rpmx-card__logo-wrap{position:absolute;top:80px;left:14px;z-index:3;width:58px;height:58px;border-radius:999px;padding:3px;background:#fff;border:2px solid #fff;box-shadow:0 8px 18px rgba(11,18,32,.14);overflow:hidden}
.rpmx-card__logo{width:100%;height:100%;object-fit:cover;border-radius:999px;display:block;background:#fff}
.rpmx-card__body{padding:12px}
.rpmx-card__body--compact{padding:12px 12px 12px}
.rpmx-card__header{padding-left:66px;min-height:46px;margin-bottom:8px}
.rpmx-card__title{margin:0 0 6px;font-size:1rem;line-height:1.14;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rpmx-card__title a{text-decoration:none!important;color:var(--rpmx-text)}
.rpmx-card__title a:hover{color:var(--rpmx-brand)}
.rpmx-card__chips{display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;scrollbar-width:none;padding-bottom:2px;margin-bottom:12px;min-height:0}
.rpmx-card__chips::-webkit-scrollbar{display:none}
.rpmx-card__chips--inline{display:flex;flex-wrap:wrap;gap:5px;margin:0;overflow:visible;padding-bottom:0}
.rpmx-card__chip{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-height:22px;padding:4px 9px;border-radius:999px;border:1px solid #e4ebf5;background:#eef2f7;color:#607089;font-size:.7rem;font-weight:700;line-height:1;white-space:nowrap;scroll-snap-align:start}
.rpmx-card__chip--more{background:#e2e8f0;color:var(--rpmx-muted)}
.rpmx-card__rating{display:flex;align-items:center;gap:6px;font-size:.9rem;margin:0 0 8px;color:var(--rpmx-muted)}
.rpmx-stars{color:#ffb547;display:inline-flex;gap:2px}
.rpmx-card__summary,.rpmx-card__status-chips{display:none}
.rpmx-card__signals{display:flex;flex-wrap:wrap;gap:8px 10px;margin-bottom:8px}
.rpmx-card__signal{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;font-weight:700;color:#1f7a37}
.rpmx-card__signal i{color:inherit}
.rpmx-card__signal--verified{color:#1f7a37}
.rpmx-card__signal--live{color:#2563eb}
.rpmx-card__signal--delivery{color:#7c3aed}
.rpmx-card__signal--pickup{color:#d97706}
.rpmx-card__meta--stacked{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;font-size:.84rem;color:var(--rpmx-muted)}
.rpmx-card__meta--stacked span{display:flex;gap:8px;align-items:flex-start;line-height:1.45}
.rpmx-card__meta--stacked span:last-child{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rpmx-card__actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.rpmx-card__actions--split{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:stretch}
.rpmx-card__actions--split .rpmx-btn{width:100%;justify-content:center;min-height:40px;padding:10px 12px;border-radius:11px;font-size:.92rem}

.rpmx-rail-wrap{position:relative}
.rpmx-card-grid--rail{display:flex;gap:18px;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:2px 2px 8px}
.rpmx-card-grid--rail::-webkit-scrollbar{display:none}
.rpmx-card-grid--rail>[data-rpmx-rail-slide]{flex:0 0 min(268px,calc(100vw - 46px));min-width:min(268px,calc(100vw - 46px));scroll-snap-align:start}
.rpmx-card-grid--rail>[data-rpmx-rail-slide]>*{height:100%}
.rpmx-rail-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:42px;height:42px;border:none;border-radius:999px;background:#10203c;color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(11,18,32,.18);transition:opacity .2s ease,background .2s ease,transform .2s ease}
.rpmx-rail-nav:hover{background:#162b50;color:#fff}
.rpmx-rail-nav[disabled],.rpmx-rail-nav.is-disabled{opacity:.35;pointer-events:none}
.rpmx-rail-nav.is-hidden{opacity:0;pointer-events:none}
.rpmx-rail-nav--prev{left:-12px}
.rpmx-rail-nav--next{right:-12px}

@media (min-width:768px){
  .rpmx-card-grid--rail>[data-rpmx-rail-slide]{min-width:0;flex:initial}
  .rpmx-card__media{height:106px}
  .rpmx-card__logo-wrap{top:74px;width:54px;height:54px}
  .rpmx-card__body--compact{padding:11px 11px 12px}
  .rpmx-card__header{padding-left:60px;min-height:42px}
  .rpmx-card__title{font-size:.96rem}
  .rpmx-card__signals{gap:6px 8px}
  .rpmx-card__signal{font-size:.76rem}
  .rpmx-card__meta--stacked{font-size:.8rem}
  .rpmx-card__actions--split .rpmx-btn{min-height:36px;font-size:.86rem;padding:9px 10px}
}

@media (max-width:767px){
  .rpmx-card{min-width:0}
  .rpmx-card__media{height:144px}
  .rpmx-card__logo-wrap{top:102px;width:68px;height:68px}
  .rpmx-card__body--compact{padding:16px 14px 14px}
  .rpmx-card__header{padding-left:76px;min-height:52px}
  .rpmx-card__actions--split{grid-template-columns:1fr}
  .rpmx-rail-nav{display:none}
}
