/* =========================================================================
 * Roll&Comb · Pack Pádel (141 E + 502 E)
 * Estilos para la tarjeta del pack en la tienda (.rc-pack*) y la ficha
 * dedicada /pack-padel/ (.pf-*). Reutiliza los tokens de design-system.css.
 * Se encola en is_shop() y en is_page('pack-padel').
 * ========================================================================= */

/* ---------- Tarjeta destacada en la tienda (debajo del grid) ---------- */
.rc-pack { max-width: 1200px; margin: 0 auto; padding: 8px 24px 0; }
.rc-pack .section-title { margin-bottom: 20px; }
.rc-pack__card {
    background: var(--rc-white); border: 2px solid var(--rc-amber);
    border-radius: var(--rc-radius-xl); padding: 28px;
    display: grid; grid-template-columns: 1.35fr 1fr; gap: 32px; align-items: center;
    box-shadow: var(--rc-shadow-lg); position: relative; overflow: hidden;
}
.rc-pack__ribbon {
    position: absolute; top: 16px; left: 16px; z-index: 3;
    background: var(--rc-amber); color: var(--rc-black); font-size: 12px; font-weight: 800;
    letter-spacing: .3px; padding: 6px 14px; border-radius: var(--rc-radius-pill);
}
.rc-pack__machines { display: flex; align-items: center; justify-content: center; }
.rc-pack__machine {
    flex: 1 1 0; background: var(--rc-bg-light); border-radius: var(--rc-radius-lg);
    aspect-ratio: 1 / 1; overflow: hidden; display: flex; align-items: center; justify-content: center; position: relative;
}
.rc-pack__machine img { width: 100%; height: 100%; object-fit: cover; }
.rc-pack__plus {
    flex: 0 0 auto; width: 58px; height: 58px; margin: 0 -16px; z-index: 2;
    border-radius: 999px; background: var(--rc-amber); color: var(--rc-black);
    display: flex; align-items: center; justify-content: center; font-size: 36px; font-weight: 800;
    line-height: 1; box-shadow: 0 6px 16px rgba(0,0,0,.18); border: 3px solid var(--rc-white);
}
.rc-pack__machine-label {
    position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%);
    background: rgba(17,17,17,.78); color: #fff; font-size: 11px; font-weight: 700;
    padding: 3px 9px; border-radius: 999px; white-space: nowrap;
}
.rc-pack__title { font-size: 26px; font-weight: 800; color: var(--rc-black); margin: 0 0 6px; }
.rc-pack__subtitle { font-size: 14px; color: var(--rc-gray-500); line-height: 1.55; margin: 0 0 16px; }
.rc-pack__specs { list-style: none; padding: 0; margin: 0 0 16px; font-size: 13px; color: var(--rc-black-soft); }
.rc-pack__specs li { padding: 4px 0; display: flex; gap: 8px; align-items: flex-start; }
.rc-pack__specs li::before { content: '\2022'; color: var(--rc-amber); font-weight: 800; }
.rc-pack__shipping {
    display: inline-flex; align-items: center; gap: 6px; margin: 0 0 16px;
    padding: 5px 12px; background: rgba(22,163,74,.10); color: #15803d;
    border-radius: 999px; font-size: 12px; font-weight: 700;
}
.rc-pack__price-row { padding-top: 14px; border-top: 1px solid var(--rc-gray-200); margin-bottom: 16px; }
.rc-pack__price { font-size: 30px; font-weight: 800; color: var(--rc-black); }
.rc-pack__price-original { font-size: 14px; color: var(--rc-gray-400); text-decoration: line-through; margin-left: 10px; }
.rc-pack__save {
    display: inline-block; margin-left: 4px; margin-top: 6px; background: var(--rc-amber); color: var(--rc-black);
    font-size: 12px; font-weight: 800; padding: 3px 10px; border-radius: var(--rc-radius-pill);
}
.rc-pack__cta { width: 100%; text-align: center; }
.rc-pack__details {
    display: block; text-align: center; margin-top: 10px; font-size: 13px; font-weight: 600;
    color: var(--rc-gray-500); text-decoration: underline; text-underline-offset: 3px;
}
.rc-pack__details:hover { color: var(--rc-black); }

@media (max-width: 820px) {
    .rc-pack__card { grid-template-columns: 1fr; gap: 22px; padding: 22px; }
    .rc-pack__title { font-size: 22px; }
}

/* ---------- Ficha dedicada /pack-padel/ ---------- */
.pf-wrap { max-width: 1120px; margin: 0 auto; padding: 28px 24px 0; }
.pf-breadcrumb { font-size: 13px; color: var(--rc-gray-500); margin-bottom: 18px; }
.pf-breadcrumb a { color: var(--rc-gray-500); text-decoration: none; }
.pf-breadcrumb a:hover { color: var(--rc-black); }
.pf-top { display: grid; grid-template-columns: 1.05fr 1fr; gap: 40px; align-items: start; }
.pf-gallery { background: var(--rc-bg-light); border-radius: var(--rc-radius-xl); padding: 24px; position: relative; border: 1px solid var(--rc-gray-200); }
.pf-ribbon { position: absolute; top: 16px; left: 16px; z-index: 3; background: var(--rc-amber); color: var(--rc-black); font-size: 12px; font-weight: 800; padding: 6px 14px; border-radius: var(--rc-radius-pill); }
.pf-machines { display: flex; align-items: center; justify-content: center; }
.pf-machine { flex: 1 1 0; background: #fff; border-radius: var(--rc-radius-lg); aspect-ratio: 1 / 1; overflow: hidden; display: flex; align-items: center; justify-content: center; position: relative; border: 1px solid var(--rc-gray-200); }
.pf-machine img { width: 100%; height: 100%; object-fit: cover; }
.pf-machine-label { position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%); background: rgba(17,17,17,.8); color: #fff; font-size: 12px; font-weight: 700; padding: 4px 10px; border-radius: 999px; }
.pf-plus { flex: 0 0 auto; width: 64px; height: 64px; margin: 0 -18px; z-index: 2; border-radius: 999px; background: var(--rc-amber); color: var(--rc-black); display: flex; align-items: center; justify-content: center; font-size: 40px; font-weight: 800; line-height: 1; box-shadow: 0 6px 16px rgba(0,0,0,.18); border: 3px solid #fff; }
.pf-title { font-size: 32px; font-weight: 800; color: var(--rc-black); margin: 0 0 6px; }
.pf-sub { font-size: 15px; color: var(--rc-gray-500); line-height: 1.6; margin: 0 0 18px; }
.pf-price-row { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.pf-price { font-size: 36px; font-weight: 800; color: var(--rc-black); }
.pf-price-old { font-size: 16px; color: var(--rc-gray-400); text-decoration: line-through; }
.pf-save { background: var(--rc-amber); color: var(--rc-black); font-size: 13px; font-weight: 800; padding: 4px 12px; border-radius: var(--rc-radius-pill); }
.pf-shipping { display: inline-flex; align-items: center; gap: 6px; margin: 10px 0 18px; padding: 6px 14px; background: rgba(22,163,74,.10); color: #15803d; border-radius: 999px; font-size: 13px; font-weight: 700; }
.pf-includes { list-style: none; padding: 0; margin: 0 0 20px; }
.pf-includes li { display: flex; gap: 10px; align-items: flex-start; padding: 8px 0; border-bottom: 1px solid var(--rc-gray-200); font-size: 14px; color: var(--rc-black-soft); }
.pf-includes li b { color: var(--rc-black); }
.pf-buy { width: 100%; text-align: center; font-size: 16px; padding: 16px; }
.pf-note { font-size: 12px; color: var(--rc-gray-500); text-align: center; margin-top: 10px; line-height: 1.5; }
.pf-section { max-width: 1120px; margin: 48px auto 0; padding: 0 24px; }
.pf-section h2 { font-size: 22px; font-weight: 800; margin: 0 0 16px; }
.pf-how { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.pf-step { background: #fff; border: 1px solid var(--rc-gray-200); border-radius: var(--rc-radius-lg); padding: 20px; }
.pf-step__n { width: 34px; height: 34px; border-radius: 999px; background: var(--rc-amber); color: var(--rc-black); font-weight: 800; display: flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.pf-step p { margin: 0; font-size: 14px; color: var(--rc-black-soft); line-height: 1.5; }
.pf-coupon { background: #fff8e1; border: 1px solid var(--rc-amber); border-radius: var(--rc-radius-lg); padding: 18px 20px; font-size: 14px; color: var(--rc-black-soft); line-height: 1.6; }
.pf-coupon code { background: var(--rc-black); color: var(--rc-amber); padding: 2px 8px; border-radius: 6px; font-weight: 700; }

@media (max-width: 860px) {
    .pf-top { grid-template-columns: 1fr; gap: 24px; }
    .pf-how { grid-template-columns: 1fr; }
}
