/* MyRentalHost · Actividades en Barcelona */
:root{--act-max:1280px}
*{box-sizing:border-box;margin:0;padding:0;min-width:0}
html,body{overflow-x:hidden}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.65}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,p{overflow-wrap:break-word}

.act-bc{max-width:var(--act-max);margin:24px auto 0;padding:0 var(--pad);font-size:.78rem;color:var(--muted)}
.act-bc a{color:var(--muted);text-decoration:none}
.act-bc a:hover{color:var(--star)}

/* ── HERO ── */
.act-hero{max-width:none;margin:0 auto;padding:0;text-align:center;position:relative;overflow:hidden;background:var(--bg)}
.act-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.82;z-index:0;pointer-events:none}
.act-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(244,241,236,.18) 0%,rgba(244,241,236,.55) 100%);pointer-events:none;z-index:0}
.act-hero-inner{position:relative;z-index:1;max-width:var(--act-max);margin:0 auto;padding:clamp(32px,3.5vw,56px) var(--pad) clamp(28px,3vw,44px)}
@media(prefers-reduced-motion:reduce){.act-hero-video{display:none}}
.act-tag{display:inline-flex;align-items:center;gap:10px;font-size:.62rem;letter-spacing:var(--track-eyebrow);text-transform:uppercase;color:var(--star);font-weight:600;margin-bottom:18px}
.act-tag::before,.act-tag::after{content:'';width:22px;height:1px;background:var(--star)}
.act-h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3.4rem);font-weight:400;line-height:1.08;letter-spacing:-.012em;color:var(--ink);margin-bottom:16px}
.act-h1 em{font-style:italic;color:var(--star)}
.act-sub{font-size:clamp(1rem,1.15vw,1.14rem);color:var(--ink-4);max-width:780px;margin:0 auto 24px;line-height:1.6}
.act-sub strong{color:var(--ink);font-weight:500}
.act-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:8px}
.act-badge{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:500;color:var(--ink-4);background:#fff;border:1px solid var(--border);border-radius:999px;padding:7px 14px}

/* ── SHARED SECTION ── */
.act-sec{padding:clamp(32px,3.2vw,56px) var(--pad)}
.act-sec-inner{max-width:var(--act-max);margin:0 auto}
.act-sec-alt{background:var(--bg-2)}
.act-eyebrow{font-size:.62rem;letter-spacing:var(--track-eyebrow);text-transform:uppercase;color:var(--star);font-weight:600;text-align:center;margin-bottom:14px}
.act-h2{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.6rem);font-weight:400;line-height:1.15;text-align:center;margin:0 auto 16px;max-width:760px;color:var(--ink)}
.act-h2 em{font-style:italic;color:var(--star)}
.act-sec-sub{font-size:clamp(.92rem,1vw,1.05rem);color:var(--ink-4);text-align:center;max-width:680px;margin:0 auto 32px;line-height:1.65}

/* ── CATEGORIES grid ── */
.act-cats{display:grid;grid-template-columns:1fr;gap:18px;max-width:1180px;margin:0 auto}
@media(min-width:560px){.act-cats{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.act-cats{grid-template-columns:repeat(3,1fr)}}
.act-cat{background:#fff;border:1px solid var(--border);border-radius:14px;padding:28px 26px;text-decoration:none;color:var(--ink);transition:transform var(--tx-fast),box-shadow var(--tx-fast),border-color var(--tx-fast);display:flex;flex-direction:column;gap:10px;position:relative}
.act-cat:hover{border-color:var(--star-l);transform:translateY(-3px);box-shadow:0 12px 32px rgba(26,30,44,.08)}
.act-cat-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:var(--star-dim);color:var(--star);transition:background var(--tx-med),color var(--tx-med)}
.act-cat:hover .act-cat-icon{background:var(--star);color:#fff}
.act-cat-icon svg{width:24px;height:24px}
.act-cat h3{font-family:var(--serif);font-size:1.2rem;font-weight:400;color:var(--ink);line-height:1.25}
.act-cat p{font-size:.88rem;color:var(--ink-4);line-height:1.6;flex-grow:1}
.act-cat-cta{font-size:.7rem;letter-spacing:var(--track-eyebrow);text-transform:uppercase;color:var(--star);font-weight:600;margin-top:6px}

/* ── CIVITATIS widget embed ── */
.act-widget-wrap{max-width:1080px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 6px 20px rgba(26,30,44,.05)}
.act-widget{width:100%;border:0;display:block;min-height:780px;background:#fff}
@media(min-width:960px){.act-widget{min-height:920px}}
.act-widget-foot{text-align:center;margin-top:20px;font-size:.86rem}
.act-link{color:var(--star);text-decoration:none;font-weight:600;letter-spacing:.02em}
.act-link:hover{color:var(--ink);text-decoration:underline}

/* ── COMO FUNCIONA · 3 steps ── */
.act-how{display:grid;grid-template-columns:1fr;gap:18px;max-width:980px;margin:0 auto}
@media(min-width:760px){.act-how{grid-template-columns:repeat(3,1fr)}}
.act-how-step{background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px 22px;position:relative}
.act-how-n{position:absolute;top:18px;right:22px;font-family:var(--serif);font-style:italic;font-size:1.6rem;color:var(--star);opacity:.35;line-height:1}
.act-how-step h3{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--ink);margin-bottom:8px;line-height:1.25}
.act-how-step p{font-size:.88rem;color:var(--ink-4);line-height:1.6}

/* ── FOODIE GUIDE block (Sprint 2.19) · asymmetric photo+text · variation from card grid ── */
.act-foodie{padding:clamp(40px,4vw,72px) var(--pad);background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.act-foodie-inner{max-width:var(--act-max);margin:0 auto;display:grid;grid-template-columns:1fr;gap:clamp(22px,3vw,48px);align-items:center}
@media(min-width:880px){.act-foodie-inner{grid-template-columns:1.1fr 1fr}}
.act-foodie-photo{margin:0;position:relative;border-radius:6px;overflow:hidden;aspect-ratio:5/3;background:var(--bg-2)}
@media(min-width:880px){.act-foodie-photo{aspect-ratio:4/3}}
.act-foodie-photo img{width:100%;height:100%;object-fit:cover;display:block}
.act-foodie-photo figcaption{position:absolute;left:14px;bottom:12px;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(26,30,44,.62);padding:6px 11px;border-radius:3px;font-weight:600}
.act-foodie-text{padding:0}
.act-foodie-eb{font-size:.66rem;letter-spacing:var(--track-eyebrow);text-transform:uppercase;color:var(--star);font-weight:600;margin-bottom:14px;text-align:left}
.act-foodie-h{font-family:var(--serif);font-size:clamp(1.7rem,2.6vw,2.3rem);font-weight:400;line-height:1.18;color:var(--ink);margin:0 0 18px;text-align:left}
.act-foodie-p{font-size:1rem;color:var(--ink-3);line-height:1.7;margin:0 0 22px;max-width:520px}
.act-foodie-link{display:inline-flex;align-items:center;gap:8px;font-size:.86rem;font-weight:600;color:var(--ink);text-decoration:none;border-bottom:1.5px solid var(--star);padding:0 0 4px;transition:color .2s,border-color .2s}
.act-foodie-link:hover{color:var(--star);border-bottom-color:var(--ink)}
.act-foodie-link span{transition:transform .2s}
.act-foodie-link:hover span{transform:translateX(3px)}

/* ── CTA cierre ── */
.act-cta{background:var(--ink);color:#F4F1EC;padding:clamp(48px,5vw,80px) var(--pad);text-align:center}
.act-cta-inner{max-width:760px;margin:0 auto}
.act-cta-h{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.3rem);font-weight:400;line-height:1.15;color:#F4F1EC;margin-bottom:16px}
.act-cta-h em{font-style:italic;color:var(--star-l)}
.act-cta-t{font-size:1rem;color:rgba(255,255,255,.7);max-width:540px;margin:0 auto 24px;line-height:1.6}
.act-cta-t strong{color:#F4F1EC;font-weight:500}
.act-cta-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:24px}
.act-btn-primary,.act-btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:8px;font-size:.74rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;transition:.2s}
.act-btn-primary{background:#25d366;color:#fff;box-shadow:0 4px 18px rgba(37,211,102,.3)}
.act-btn-primary:hover{background:#1ebe5a;transform:translateY(-1px);color:#fff}
.act-btn-ghost{background:transparent;color:#F4F1EC;border:1px solid rgba(255,255,255,.25)}
.act-btn-ghost:hover{border-color:#F4F1EC;background:rgba(255,255,255,.06);color:#F4F1EC}
.act-cta-disclaimer{font-size:.7rem;color:rgba(255,255,255,.4);line-height:1.6;max-width:560px;margin:0 auto}
