:root{--page-title-display:none;}/* Start custom CSS */:root{
      --brand: #F75D9D;
      --brand-2:#ff86b5;
      --ink:#1d1d1f;
      --muted:#5c5c66;
      --bg:#ffffff;
      --bg-2:#fff5fa;
      --card:#ffffff;
      --line: rgba(29,29,31,.12);
      --shadow: 0 10px 30px rgba(29,29,31,.10);
      --radius: 18px;
      --radius-lg: 26px;
      --container: 1120px;
    }

    *{ box-sizing:border-box; }
    html{ scroll-behavior:smooth; }
    body{
      margin:0;
      font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
      color:var(--ink);
      background:var(--bg);
      line-height:1.45;
    }

    a{ color:inherit; text-decoration:none; }
    a:hover{ text-decoration:underline; text-decoration-thickness:2px; text-underline-offset:3px; }

    /* Accesibilidad */
    .esp-skip{
      position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
    }
    .esp-skip:focus{
      left:12px; top:12px; width:auto; height:auto; padding:10px 12px;
      background:#fff; border:2px solid var(--ink); border-radius:12px; z-index:9999;
    }
    :focus-visible{
      outline:3px solid rgba(247,93,157,.55);
      outline-offset:3px;
      border-radius:12px;
    }

    /* Layout helpers */
    .esp-container{
      max-width:var(--container);
      margin:0 auto;
      padding:0 18px;
    }
    .esp-section{ padding:56px 0; }
    .esp-section--alt{ background:var(--bg-2); }

    .esp-eyebrow{
      display:inline-flex;
      gap:10px;
      align-items:center;
      padding:8px 12px;
      border:1px solid var(--line);
      border-radius:999px;
      background:rgba(255,255,255,.65);
      backdrop-filter:saturate(140%) blur(8px);
      color:var(--muted);
      font-size:14px;
    }
    .esp-h1{
      font-size: clamp(30px, 4vw, 44px);
      line-height:1.1;
      margin:14px 0 10px;
      letter-spacing:-.02em;
    }
    .esp-h2{
      font-size: clamp(22px, 3vw, 30px);
      margin:0 0 12px;
      letter-spacing:-.01em;
    }
    .esp-h3{
      font-size:18px;
      margin:0 0 8px;
      letter-spacing:-.01em;
    }
    .esp-lead{
      font-size: clamp(16px, 2vw, 18px);
      color:var(--muted);
      max-width: 68ch;
      margin:0;
    }
    .esp-text{
      color:var(--muted);
      margin:0;
      max-width: 75ch;
    }

    /* Header / Nav */
    .esp-header{
      position:sticky;
      top:0;
      z-index:50;
      background:rgba(255,255,255,.88);
      backdrop-filter: saturate(140%) blur(10px);
      border-bottom:1px solid rgba(29,29,31,.08);
    }
    .esp-header__inner{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:14px;
      padding:12px 0;
    }
    .esp-brand{
      display:flex;
      align-items:center;
      gap:12px;
      min-width: 220px;
    }
    .esp-brand img{ height:36px; width:auto; display:block; }
    .esp-nav{ display:flex; gap:18px; align-items:center; }
    .esp-nav a{
      font-size:14px;
      color:var(--muted);
      padding:10px 10px;
      border-radius:12px;
    }
    .esp-nav a:hover{
      background:rgba(247,93,157,.08);
      text-decoration:none;
      color:var(--ink);
    }

    .esp-navWrap{
      display:flex;
      gap:14px;
      align-items:center;
    }

    .esp-ctaRow{
      display:flex;
      gap:10px;
      align-items:center;
      flex-wrap:wrap;
      justify-content:flex-end;
    }

    /* Buttons */
    .esp-btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      padding:12px 14px;
      border-radius:14px;
      border:1px solid rgba(29,29,31,.14);
      background:#fff;
      color:var(--ink);
      font-weight:600;
      font-size:14px;
      white-space:nowrap;
      box-shadow: 0 1px 0 rgba(29,29,31,.04);
      transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    }
    .esp-btn:hover{
      transform: translateY(-1px);
      box-shadow: 0 10px 24px rgba(29,29,31,.10);
      border-color: rgba(247,93,157,.35);
      text-decoration:none;
    }
    .esp-btn--primary{
      background: linear-gradient(135deg, var(--brand), var(--brand-2));
      color:#fff;
      border-color: rgba(255,255,255,.0);
    }
    .esp-btn--primary:hover{
      box-shadow: 0 14px 34px rgba(247,93,157,.28);
    }
    .esp-btn--ghost{
      background: rgba(247,93,157,.06);
      border-color: rgba(247,93,157,.25);
    }

    /* Mobile menu button (oculto en desktop) */
    .esp-menuBtn{
      display:none;
      align-items:center;
      justify-content:center;
      width:44px; height:44px;
      border-radius:14px;
      border:1px solid rgba(29,29,31,.14);
      background:#fff;
      cursor:pointer;
    }
    .esp-menuBtn svg{ width:20px; height:20px; }

    /* Mobile panel: se muestra/oculta con [hidden] */
    .esp-mobilePanel{
      border-top:1px solid rgba(29,29,31,.08);
      padding:10px 0 14px;
    }
    .esp-mobilePanel[hidden]{ display:none; }

    .esp-mobilePanel a{
      display:block;
      padding:12px 6px;
      color:var(--muted);
      border-radius:12px;
    }
    .esp-mobilePanel a:hover{
      background:rgba(247,93,157,.08);
      text-decoration:none;
      color:var(--ink);
    }
    .esp-mobilePanel .esp-ctaRow{
      justify-content:flex-start;
      padding-top:10px;
    }

    /* Responsive nav logic */
    @media (max-width: 900px){
      .esp-nav{ display:none; }
      .esp-ctaRow .esp-btn--ghost{ display:none; }
      .esp-brand{ min-width:auto; }
      .esp-menuBtn{ display:inline-flex; }
    }
    @media (min-width: 901px){
      .esp-mobilePanel{ display:none !important; }
    }

    /* Hero */
    .esp-hero{
      padding: 34px 0 56px;
      background:
        radial-gradient(900px 420px at 20% 15%, rgba(247,93,157,.14), transparent 60%),
        radial-gradient(900px 520px at 85% 10%, rgba(29,29,31,.06), transparent 55%),
        var(--bg);
    }
    .esp-heroGrid{
      display:grid;
      grid-template-columns: 1.1fr .9fr;
      gap:18px;
      align-items:stretch;
    }
    @media (max-width: 900px){
      .esp-heroGrid{ grid-template-columns:1fr; }
    }
    .esp-heroCard{
      border:1px solid rgba(29,29,31,.10);
      border-radius: var(--radius-lg);
      overflow:hidden;
      background: #fff;
      box-shadow: var(--shadow);
      position:relative;
      min-height: 340px;
    }
    .esp-heroCard__media{
      position:absolute; inset:0;
      background:
        linear-gradient(180deg, rgba(29,29,31,.10), rgba(29,29,31,.68)),
        url("https://elsoportaldesanpablo.com/wp-content/uploads/2026/03/Entrada-Noche-El-Portal-de-San-Pablo.jpg") center/cover no-repeat;
      transform: scale(1.02);
    }
    .esp-heroCard__content{
      position:relative;
      padding: 22px 22px 18px;
      height:100%;
      display:flex;
      flex-direction:column;
      justify-content:flex-end;
      gap:12px;
      color:#fff;
    }
    .esp-heroCard__content .esp-eyebrow{
      border-color: rgba(255,255,255,.25);
      background: rgba(255,255,255,.10);
      color: rgba(255,255,255,.92);
    }
    .esp-heroChips{
      display:flex;
      gap:8px;
      flex-wrap:wrap;
      margin-top:6px;
    }
    .esp-chip{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding:8px 10px;
      border-radius:999px;
      border:1px solid rgba(255,255,255,.22);
      background: rgba(255,255,255,.10);
      font-size:13px;
      color: rgba(255,255,255,.92);
    }

    .esp-heroCopy{
      padding: 18px 6px;
      display:flex;
      flex-direction:column;
      justify-content:center;
      gap:14px;
    }
    .esp-microcopy{
      font-size:14px;
      color: var(--muted);
      margin:0;
    }

    /* Cards / grids */
    .esp-grid{ display:grid; gap:14px; }
    .esp-grid--3{ grid-template-columns: repeat(3, 1fr); }
    .esp-grid--2{ grid-template-columns: repeat(2, 1fr); }
    @media (max-width: 900px){
      .esp-grid--3{ grid-template-columns: 1fr; }
      .esp-grid--2{ grid-template-columns: 1fr; }
    }

    .esp-card{
      background: var(--card);
      border:1px solid rgba(29,29,31,.10);
      border-radius: var(--radius);
      overflow:hidden;
      box-shadow: 0 1px 0 rgba(29,29,31,.04);
      transition: transform .15s ease, box-shadow .15s ease;
    }
    .esp-card:hover{
      transform: translateY(-2px);
      box-shadow: 0 12px 28px rgba(29,29,31,.10);
    }
    .esp-card__img{
      aspect-ratio: 16/10;
      background: #f2f2f4;
      overflow:hidden;
    }
    .esp-card__img img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
      transform: scale(1.01);
    }
    .esp-card__body{ padding:14px 14px 16px; }

    /* Steps */
    .esp-step{
      display:flex;
      gap:12px;
      align-items:flex-start;
      padding:14px;
      border:1px solid rgba(29,29,31,.10);
      border-radius: var(--radius);
      background:#fff;
    }
    .esp-step__n{
      width:34px; height:34px;
      border-radius: 12px;
      display:grid; place-items:center;
      background: rgba(247,93,157,.12);
      border:1px solid rgba(247,93,157,.25);
      font-weight:800;
      color: var(--ink);
      flex:0 0 auto;
    }
    .esp-step__t{ margin:0 0 4px; font-weight:800; }
    .esp-step__p{ margin:0; color:var(--muted); }

    /* Lists */
    .esp-list{
      margin:10px 0 0;
      padding-left:18px;
      color:var(--muted);
    }
    .esp-list li{ margin:6px 0; }

    /* Gallery */
    .esp-mosaic{
      display:grid;
      grid-template-columns: 1fr 1fr 1fr 1fr;
      grid-auto-rows: 150px;
      gap:10px;
    }
    .esp-mosaic a{
      position:relative;
      border-radius: 18px;
      overflow:hidden;
      border:1px solid rgba(29,29,31,.10);
      background:#f2f2f4;
    }
    .esp-mosaic img{ width:100%; height:100%; object-fit:cover; display:block; }
    .esp-mosaic a:nth-child(1){ grid-column: span 2; grid-row: span 2; }
    .esp-mosaic a:nth-child(4){ grid-column: span 2; }
    @media (max-width: 900px){
      .esp-mosaic{ grid-template-columns:1fr 1fr; grid-auto-rows: 140px; }
      .esp-mosaic a:nth-child(1){ grid-column: span 2; grid-row: span 2; }
      .esp-mosaic a:nth-child(4){ grid-column: span 2; }
    }

    /* Location */
    .esp-loc{
      display:grid;
      grid-template-columns: .95fr 1.05fr;
      gap:14px;
      align-items:stretch;
    }
    @media (max-width: 900px){
      .esp-loc{ grid-template-columns:1fr; }
    }
    .esp-box{
      border:1px solid rgba(29,29,31,.10);
      border-radius: var(--radius);
      background:#fff;
      padding:16px;
      box-shadow: 0 1px 0 rgba(29,29,31,.04);
    }
    .esp-badge{
      display:inline-flex;
      align-items:center;
      gap:8px;
      padding:8px 10px;
      border-radius:999px;
      border:1px solid rgba(29,29,31,.10);
      background: rgba(29,29,31,.03);
      color: var(--muted);
      font-size: 13px;
    }
    .esp-map{
      border-radius: var(--radius);
      overflow:hidden;
      border:1px solid rgba(29,29,31,.10);
      background:#f2f2f4;
      min-height: 320px;
    }
    .esp-map iframe{
      width:100%;
      height:100%;
      border:0;
      display:block;
    }

    /* FAQ */
    .esp-faq details{
      border:1px solid rgba(29,29,31,.10);
      border-radius: var(--radius);
      background:#fff;
      padding:14px 14px;
    }
    .esp-faq summary{
      cursor:pointer;
      font-weight:800;
      list-style:none;
    }
    .esp-faq summary::-webkit-details-marker{ display:none; }
    .esp-faq p{
      margin:10px 0 0;
      color:var(--muted);
    }

    /* Footer */
    .esp-footer{
      padding:26px 0 34px;
      border-top: 1px solid rgba(29,29,31,.08);
      background: #fff;
    }
    .esp-footerRow{
      display:flex;
      flex-wrap:wrap;
      gap:12px;
      justify-content:space-between;
      align-items:flex-start;
      color:var(--muted);
      font-size:14px;
    }
    .esp-legal{
      display:flex;
      flex-direction:column;
      gap:8px;
      max-width: 520px;
    }
    .esp-legal__title{
      font-weight:800;
      color:var(--ink);
      margin:0;
      font-size:14px;
    }
    .esp-legal__links{
      display:flex;
      flex-wrap:wrap;
      gap:10px 14px;
    }
    .esp-legal__links a{
      color:var(--muted);
      padding:6px 10px;
      border-radius: 12px;
      border:1px solid rgba(29,29,31,.10);
      background: rgba(29,29,31,.02);
    }
    .esp-legal__links a:hover{
      text-decoration:none;
      border-color: rgba(247,93,157,.35);
      background: rgba(247,93,157,.06);
      color: var(--ink);
    }
    @media (max-width: 900px){
      .esp-legal{ width:100%; }
    }

    /* Simple reveal on scroll */
    .esp-reveal{ opacity:0; transform: translateY(10px); transition: opacity .55s ease, transform .55s ease; }
    .esp-reveal.is-in{ opacity:1; transform: translateY(0); }

    @media (prefers-reduced-motion: reduce){
      html{ scroll-behavior:auto; }
      .esp-btn, .esp-card, .esp-reveal{ transition:none !important; }
      .esp-btn:hover, .esp-card:hover{ transform:none; }
    }/* End custom CSS */