/*
 * 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}
}


/* v8.3.29 compact promoted badge contract
 * Keep card state and promoted badges readable inside compact rails.
 * Scope is only promoted cards; regular cards keep their current hierarchy.
 */
.rpm-os-promoted-real .rpmx-card__flag{
  top:8px!important;
  left:8px!important;
  min-height:20px!important;
  padding:4px 8px!important;
  font-size:.57rem!important;
  line-height:1!important;
  letter-spacing:.005em!important;
  white-space:nowrap!important;
}
.rpm-os-promoted-real__badge{
  right:8px!important;
  top:8px!important;
}
.rpm-os-promoted-real__badge .rpm-os-chip,
.rpm-os-promoted-real__badge .rpm-os-chip--gold{
  min-height:20px!important;
  padding:4px 8px!important;
  font-size:.625rem!important;
  line-height:1!important;
  font-weight:800!important;
  letter-spacing:.005em!important;
  gap:4px!important;
  white-space:nowrap!important;
}
@media (max-width:767px){
  .rpm-os-promoted-real .rpmx-card__flag{
    top:7px!important;
    left:7px!important;
    min-height:19px!important;
    padding:4px 7px!important;
    font-size:.54rem!important;
  }
  .rpm-os-promoted-real__badge{
    right:7px!important;
    top:7px!important;
  }
  .rpm-os-promoted-real__badge .rpm-os-chip,
  .rpm-os-promoted-real__badge .rpm-os-chip--gold{
    min-height:19px!important;
    padding:4px 7px!important;
    font-size:.58rem!important;
  }
}


/* AdSense soft placement component: editorial pause, not a card or local promoted slot */
.rpmx-adsense-slot {
  display: block;
  width: 100%;
  margin: 28px 0;
  padding: 10px 12px 12px;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  background: rgba(255,255,255,.82);
  box-shadow: 0 10px 30px rgba(15,23,42,.05);
  clear: both;
  overflow: hidden;
}
.rpmx-adsense-slot__label {
  display: block;
  margin: 0 0 8px;
  color: rgba(71,85,105,.72);
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.rpmx-adsense-slot ins.adsbygoogle {
  max-width: 100%;
  min-height: 90px;
}
.rpmx-adsense-slot__frame {
  display: block;
  width: 100%;
  min-height: 90px;
}
.rpmx-adsense-slot--single_intermedio_fichas_rest {
  margin-top: 24px;
}
.rpmx-adsense-slot--home_before_footer,
.rpmx-adsense-slot--taxonomy_before_footer {
  margin-top: 34px;
}
@media (max-width: 767px) {
  .rpmx-adsense-slot {
    margin: 22px 0;
    padding: 8px 10px 10px;
    border-radius: 16px;
    box-shadow: 0 8px 22px rgba(15,23,42,.045);
  }
  .rpmx-adsense-slot ins.adsbygoogle {
    min-height: 72px;
  }
}


/* Canon v8.6.59: stable third-party mobile ad slot; wrapper reserves space even if AdSense mutates the ins. */
.rpmx-adsense-slot.rpmx-mobile-third-party-ad {
  display: none;
}
@media (max-width: 767px) {
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad {
    display: block;
    width: 100%;
    max-width: 412px;
    min-height: 110px;
    max-height: 128px;
    margin: 14px auto 52px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    box-sizing: border-box;
    overflow: hidden;
    contain: layout paint;
  }
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad::after {
    content: none;
    display: none;
  }
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad .rpmx-adsense-slot__label {
    display: block;
    height: 12px;
    margin: 0 0 6px;
    color: rgba(15, 23, 42, .44);
    font-size: 10px;
    font-weight: 800;
    line-height: 12px;
    letter-spacing: .09em;
    text-transform: uppercase;
  }
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad .rpmx-adsense-slot__frame {
    display: block;
    width: 412px;
    max-width: 100%;
    height: 90px;
    min-height: 90px;
    max-height: 90px;
    margin: 0 auto;
    overflow: hidden;
  }
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad ins.adsbygoogle {
    display: block;
    width: 412px !important;
    max-width: 100%;
    height: 90px !important;
    min-height: 90px !important;
    max-height: 90px !important;
    margin: 0 auto;
    overflow: hidden;
  }
}



/* Canon v8.6.61: mobile AdSense sits as a compact intersection between the map artifact and Services. */
@media (max-width: 767px) {
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad--section-intersection {
    display: block;
    width: calc(100% - 32px);
    max-width: 412px;
    min-height: 108px;
    max-height: 116px;
    margin: 12px auto 22px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    box-sizing: border-box;
    overflow: hidden;
    contain: layout paint;
  }
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad--section-intersection .rpmx-adsense-slot__label {
    display: block;
    height: 12px;
    margin: 0 0 6px;
    color: rgba(15, 23, 42, .42);
    font-size: 9px;
    font-weight: 800;
    line-height: 12px;
    letter-spacing: .09em;
    text-transform: uppercase;
  }
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad--section-intersection .rpmx-adsense-slot__frame {
    display: block;
    width: 412px;
    max-width: 100%;
    height: 90px;
    min-height: 90px;
    max-height: 90px;
    margin: 0 auto;
    overflow: hidden;
  }
  .rpmx-adsense-slot.rpmx-mobile-third-party-ad--section-intersection ins.adsbygoogle {
    display: block;
    width: 412px !important;
    max-width: 100%;
    height: 90px !important;
    min-height: 90px !important;
    max-height: 90px !important;
    margin: 0 auto;
    overflow: hidden;
  }
}
