/* RP Rentals v1.0.1 — unified stylesheet with UI fixes */

/* design tokens */
:root{ --rp-radius:16px; --rp-shadow:0 4px 12px rgba(0,0,0,.15); --rp-grad:linear-gradient(180deg,#fff,#fafafa); }

.rp-wrap{ max-width:1440px;margin:0 auto;padding:0; }
.rp-empty{padding:24px;text-align:center;opacity:.7}

/* ===== GRID ===== */
.rp-grid { display: flex; gap: 30px; justify-content: center; flex-direction: row; flex-wrap: wrap; }
.rp-grid--featured, .rp-grid--catalog {  }

/* ===== CARD (fixed size 290x520) ===== */
.rp-card{
  display:block;background:var(--rp-grad);border-radius:var(--rp-radius);box-shadow:var(--rp-shadow);
  text-decoration:none;color:#111;overflow:hidden;width:290px;height:500px
}
.rp-card:hover { text-decoration: none; }
/* принудительно задаем цвет всему содержимому карточек (чтобы не зависеть от темы) */
.rp-card, .rp-card *{ color:#111; }

/* card inner: top content + bottom footer */
.rp-card__inner{display:grid;grid-template-rows:1fr auto;height:100%}

/* top row: media (120px) + body */
.rp-card__content{
  display:grid;grid-template-columns:86px 1fr;gap:10px;padding:0;align-items:start;min-height:0; margin: 20px 20px 0 0; }
.rp-card__media{display:flex;align-items:center;justify-content:center}
.rp-card__media img{max-width:100%;max-height:100%;object-fit:cover;display:block}

/* Отдельные позиции */
.rp-card--item { flex: 0 1 290px; }
.rp-card--item .rp-card__media img.rp-item-thumb{max-width:250px;max-height:250px;width:auto;height:auto}
/* === Unique container for item cards (stack as column) === */
.rp-card--item .rp-item__content { margin: 20px; gap: 20px; }
.rp-card__media > img { border-radius: 20px; margin: 20px 0; }
.rp-split .rp-article__media > img { border-radius: 20px; max-height: 350px !important; }

/* text column */
.rp-card__body{min-width:0}
.rp-card__title{ margin:0 0 10px 0; font-size: 16pt; }
.rp-card__summary { opacity: .85; margin: 0 0 20px 0; line-height: 1.2; font-size: 12pt; }
.rp-composition{margin:6px 0 0;padding:0;list-style:none;max-height:180px;overflow:auto}
.rp-composition__item{display:flex;align-items:center;gap:8px;margin:0 0 4px}
.rp-composition__icon{width:18px;height:18px;object-fit:contain;flex:0 0 18px}

/* bottom row: price + button */
.rp-card__footer{
  display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;
  padding:12px;border-top:1px solid #eee
}
.rp-price{font-weight:700;font-size:20px}
.rp-price::before{content:"от ";font-weight:400;font-size:16px;color:#333}

/* buttons */
.rp-btn { appearance: none; border: 2px solid #fff; border-radius:999px; padding:10px 16px; color:#fff !important; cursor: pointer; box-shadow:var(--rp-shadow); text-decoration: none; text-transform: uppercase; background: #0085ff; }
.rp-btn:hover{opacity:.9}
.rp-card__cta .rp-btn { border: none; }

/* ===== TABS ===== */
.rp-tabs{ display: flex; gap: 8px; margin: 0 0 40px 0; }
.rp-tab{ padding: 10px 16px; border-radius:999px; border:1px solid #0085ff; cursor:pointer; color: #0085ff; background: transparent; }
.rp-tab[aria-selected="true"] { background: #0085ff; color: #fff; }
.rp-tabpanel[hidden]{display:none}

/* ===== MODAL ===== */
.rp-grid--time { grid-template-columns: 1fr 1fr; }
.rp-modal[aria-hidden="false"]{position:fixed;inset:0;z-index:9999}
.rp-modal__overlay{position:absolute;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(2px)}
.rp-modal__dialog{position:relative;max-width:520px;margin:10vh auto;background:#fff;border-radius:var(--rp-radius);box-shadow:var(--rp-shadow);padding:20px}
.rp-modal__close{position:absolute;top:8px;right:10px;border:0;background:transparent;font-size:24px;cursor:pointer}
.rp-modal__title{margin:0 0 12px;font-size:20px;font-weight:700;color:#111}

/* Big inputs with rounded corners + light border; force text color in modal */
.rp-modal, .rp-modal *{ color:#111; }
.rp-form .rp-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.rp-form .rp-field input,
.rp-form .rp-field select,
.rp-form .rp-field textarea{
  height:48px;border:1px solid #e5e7eb;border-radius:12px;padding:10px 14px;
  font-size:16px;line-height:1.4;background:#fff;color:#111;box-shadow:inset 0 1px 2px rgba(0,0,0,.02)
}
.rp-form .rp-field textarea{height:auto;min-height:120px;resize:vertical}
.rp-form .rp-field input::placeholder, .rp-form .rp-field textarea::placeholder{color:#6b7280}
.rp-form .rp-field input:focus, .rp-form .rp-field select:focus, .rp-form .rp-field textarea:focus{
  outline:none;border-color:#94a3b8;box-shadow:0 0 0 3px rgba(148,163,184,.25)
}
.rp-form__actions .rp-btn{height:48px;font-weight:600}

/* Consent alignment */
.rp-field.rp-consent{flex-direction:row;align-items:center;gap:10px;margin-top:6px}
.rp-field.rp-consent input[type="checkbox"]{width:18px;height:18px;border-radius:4px}

/* visually hidden honeypot */
.rp-hp{position:absolute!important;left:-9999px!important;opacity:0!important;height:0!important}

/* ===== SINGLE PAGES ===== */
.rp-single .rp-top{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start;margin-bottom:16px}
.rp-single .rp-article__price{font-size:22px;font-weight:700}
.rp-single .rp-split { display: grid; grid-template-columns: auto 1fr; gap: 40px; }
.rp-single .rp-article__media img { max-width: 100%; max-height: 520px; display: block; }
@media (max-width:768px){ .rp-single .rp-split{grid-template-columns:1fr} }
.rp-top__cta { display: flex; flex-direction: row; gap: 30px; }
.rp-top__cta span { font-weight: normal; }