  /* ✅ FIX: scope overflow-x to this landing only (avoid affecting whole WP site) */
  #li-root{ overflow-x:hidden; }

  #li-root{
    --bg: #0b0f14;
    --paper: #ffffff;
    --muted: rgba(255,255,255,.72);
    --text: rgba(255,255,255,.92);
    --ink: #101418;
    --ink2:#2a3138;
    --line: rgba(16,20,24,.10);
    --accent:#0E3A5D;
    --radius: 18px;

    --cardW: 320px;
    --cardImgH: 180px;

    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    color: var(--ink);
    padding-bottom: 110px;
  }
  @media (max-width: 600px){
    #li-root{ --cardW: min(78vw, 320px); --cardImgH: 160px; }
  }

  #li-root *{ box-sizing:border-box; }

  #li-root .li-full{
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
    max-width: 100vw;
  }

  #li-root .li-wrap{
    position: relative;
    z-index: 2;
    width: min(1100px, 100%);
    margin: 0 auto;
  }

  /* generic grid helper */
  #li-root .li-grid{
    display:grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 28px;
    align-items:start;
  }
  @media (max-width: 900px){
    #li-root .li-grid{ grid-template-columns: 1fr; }
  }

  /* Sticky top bar */
  #li-root .li-topbar{
    position: fixed; left:0; right:0; top:0;
    z-index: 9999;
    padding: 10px 14px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    background: rgba(11,15,20,.46);
    border-bottom: 1px solid rgba(255,255,255,.10);
  }
  #li-root .li-topbarInner{
    width: min(1100px, 100%);
    margin: 0 auto;
    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: 12px;
  }
  #li-root .li-nav{
    display:flex;
    align-items:center;
    gap: 14px;
    flex-wrap: wrap;
    justify-content: flex-end;
    margin-left: auto;
  }
  #li-root .li-brand{
    display:flex; align-items:center; gap:10px;
    color: rgba(255,255,255,.92);
    text-decoration:none;
    font-weight: 700;
    letter-spacing: .2px;
    font-size: 14px;
    white-space: nowrap;
  }
  #li-root .li-brandDot{
    width: 10px; height: 10px; border-radius: 999px;
    background: rgba(255,255,255,.70);
    box-shadow: 0 0 0 6px rgba(255,255,255,.08);
  }
  #li-root .li-link{
    color: rgba(255,255,255,.82);
    text-decoration:none;
    font-size: 13px;
    font-weight: 600;
    padding: 8px 10px;
    border-radius: 999px;
    transition: background .15s ease, opacity .15s ease, transform .15s ease;
  }
  #li-root .li-link:hover{ background: rgba(255,255,255,.10); transform: translateY(-1px); }
  #li-root .li-navCta{
    background: rgba(255,255,255,.92);
    color: #0b0f14;
  }
  #li-root .li-navCta:hover{ background: #ffffff; }

  /* Language switcher */
  #li-root .li-langSwitch{
    display:flex;
    align-items:center;
    gap:6px;
    margin-left:14px;
    padding: 6px 8px;
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  #li-root .li-lang{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width: 34px;
    height: 28px;
    border-radius: 999px;
    text-decoration:none;
    font-size: 16px;
    line-height: 1;
    opacity: .85;
    transition: transform .15s ease, opacity .15s ease, background .15s ease;
  }
  #li-root .li-lang:hover{
    opacity: 1;
    transform: translateY(-1px);
    background: rgba(255,255,255,.10);
  }

  /* ==========================================================
     ✅ NEW: Mobile menu button + panel (fixes ugly “grey half screen”)
     ========================================================== */
  #li-root .li-menuBtn{
    display:none;
    border:1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.92);
    padding: 9px 12px;
    border-radius: 999px;
    font-weight: 900;
    cursor: pointer;
    user-select:none;
    white-space: nowrap;
  }
  #li-root .li-mobileMenu{
    display:none;
    width: min(1100px, 100%);
    margin: 10px auto 0;
    padding: 10px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(11,15,20,.72);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  #li-root .li-mobileMenu a{
    display:block;
    padding: 10px 10px;
    border-radius: 12px;
    text-decoration:none;
    color: rgba(255,255,255,.88);
    font-weight: 800;
  }
  #li-root .li-mobileMenu a:hover{
    background: rgba(255,255,255,.10);
  }

  @media (max-width: 900px){
    /* Use sticky instead of fixed on mobile (prevents overlay feel) */
    #li-root .li-topbar{
      position: sticky;
      top: 0;
      padding: 10px 12px;
    }

    /* Hide the desktop nav entirely on mobile */
    #li-root .li-nav{ display:none; }

    /* Show menu button on mobile */
    #li-root .li-menuBtn{ display:inline-flex; }

    /* Keep inner row compact */
    #li-root .li-topbarInner{ flex-wrap: nowrap; }

    /* Remove big left margin on lang switch */
    #li-root .li-langSwitch{ margin-left: 0; }

    /* When open */
    #li-root.isMenuOpen .li-mobileMenu{ display:block; }
  }

  /* Hero */
  #li-root .li-hero{
    position: relative;
    min-height: 88vh;
    display: flex;
    align-items: flex-end;
    padding: 110px 20px 70px;
    color: var(--text);
    overflow: hidden;
    background: #0b0f14;
  }
  #li-root .li-hero::before{
    content:"";
    position:absolute; inset:0;
    background-image: url('https://lakeiseo.info/wp-content/uploads/2026/02/castro.iseo5_.jpeg');
    background-size: cover;
    background-position: center;
    filter: saturate(1.05) contrast(1.03);
    transform: scale(1.03);
    pointer-events:none;
  }
  #li-root .li-hero::after{
    content:"";
    position:absolute; inset:0;
    background:
      radial-gradient(900px 600px at 15% 20%, rgba(255,255,255,.10), transparent 55%),
      radial-gradient(900px 600px at 85% 30%, rgba(14,58,93,.22), transparent 55%),
      linear-gradient(to top, rgba(11,15,20,.92) 0%, rgba(11,15,20,.60) 48%, rgba(11,15,20,.35) 100%);
    pointer-events:none;
  }
  #li-root .li-kicker{
    display:flex; gap:10px; align-items:center;
    font-weight: 500;
    letter-spacing: .3px;
    color: rgba(255,255,255,.80);
    margin-bottom: 14px;
    font-size: 14px;
  }
  #li-root .li-dot{
    width: 8px; height: 8px; border-radius: 99px;
    background: rgba(255,255,255,.65);
    box-shadow: 0 0 0 6px rgba(255,255,255,.08);
  }
  #li-root .li-heroBrand{
    font-family:"Playfair Display", Georgia, serif;
    font-weight:700;
    letter-spacing:-0.8px;
    line-height:1;
    font-size: clamp(44px, 6.2vw, 92px);
    margin: 0 0 12px 0;
  }
  #li-root .li-sub{
    font-size: clamp(16px, 1.35vw, 20px);
    line-height: 1.55;
    color: rgba(255,255,255,.80);
    max-width: 860px;
    margin: 0 0 18px 0;
  }

  /* Buttons */
  #li-root .li-ctaRow{
    display:flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items:center;
    margin-top: 10px;
  }
  #li-root .li-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding: 12px 16px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 14px;
    text-decoration:none;
    transition: transform .15s ease, background .15s ease, border-color .15s ease, opacity .15s ease;
    user-select:none;
    white-space: nowrap;
  }
  #li-root .li-btnPrimary{
    background: rgba(255,255,255,.92);
    color: #0b0f14;
    border: 1px solid rgba(255,255,255,.20);
  }
  #li-root .li-btnPrimary:hover{ transform: translateY(-1px); background: #ffffff; }
  #li-root .li-btnGhost{
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.92);
    border: 1px solid rgba(255,255,255,.18);
  }
  #li-root .li-btnGhost:hover{ transform: translateY(-1px); background: rgba(255,255,255,.10); }

  /* Search */
  #li-root .li-searchRow{
    display:flex;
    gap:10px;
    align-items:center;
    margin-top: 14px;
    flex-wrap: wrap;
  }
  #li-root .li-search{
    flex: 1;
    min-width: 260px;
    display:flex;
    align-items:center;
    gap:10px;
    padding: 12px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  #li-root .li-search input{
    width:100%;
    border:0;
    outline:0;
    background: transparent;
    color: rgba(255,255,255,.92);
    font: inherit;
    font-weight: 500;
  }
  #li-root .li-search input::placeholder{ color: rgba(255,255,255,.65); }
  #li-root .li-searchBtn{
    border: 0;
    border-radius: 999px;
    padding: 10px 14px;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    background: rgba(255,255,255,.92);
    color: #0b0f14;
  }
  #li-root .li-searchBtn:hover{ background:#fff; }

  /* Sticky rail */
  #li-root .li-rail{
    position: fixed;
    left: 0; right: 0;
    bottom: 16px;
    z-index: 9998;
    padding: 0 20px;
    pointer-events: none;
  }
  #li-root .li-railInner{
    width:min(1100px,100%);
    margin: 0 auto;
    display:flex;
    justify-content:center;
    pointer-events: none;
  }
  #li-root .li-railPill{
    pointer-events:auto;
    display:flex;
    gap:6px;
    align-items:center;
    padding: 8px;
    border-radius: 999px;
    background: rgba(11,15,20,.55);
    border: 1px solid rgba(255,255,255,.14);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    overflow-x:auto;
  }
  #li-root .li-railPill::-webkit-scrollbar{ height:0; }
  #li-root .li-railLink{
    text-decoration:none;
    color: rgba(255,255,255,.86);
    font-weight: 700;
    font-size: 12px;
    padding: 9px 12px;
    border-radius: 999px;
    white-space: nowrap;
    transition: background .15s ease, transform .15s ease, opacity .15s ease;
  }
  #li-root .li-railLink:hover{ background: rgba(255,255,255,.10); transform: translateY(-1px); }
  #li-root .li-railLink.isActive{
    background: rgba(255,255,255,.92);
    color:#0b0f14;
  }

  /* Partner strip */
  #li-root .li-strip{
    padding: 18px 20px;
    background: rgba(255,255,255,.06);
    border-top: 1px solid rgba(255,255,255,.10);
    border-bottom: 1px solid rgba(255,255,255,.10);
  }
  #li-root .li-stripInner{
    width:min(1100px,100%);
    margin:0 auto;
    display:flex;
    gap:14px;
    align-items:center;
    flex-wrap: wrap;
    color: rgba(255,255,255,.80);
    font-size: 13px;
  }
  #li-root .li-pill{
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    white-space: nowrap;
  }
  #li-root .li-stripLabel{
    font-weight: 700;
    letter-spacing: .2px;
    opacity: .9;
    margin-right: 6px;
  }

  /* Sections */
  #li-root .li-section{ padding: 84px 20px; }
  #li-root .li-light{ background:#ffffff; color: var(--ink); }
  #li-root .li-dark{ background:#0b0f14; color: rgba(255,255,255,.92); }
  #li-root .li-anchor{ scroll-margin-top: 110px; }

  /* Layout head rows */
  #li-root .li-twoColHead{
    display:flex;
    align-items:flex-end;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 14px;
  }
  #li-root .li-headRight{
    display:flex;
    gap: 10px;
    flex-wrap: wrap;
  }

  /* Type */
  #li-root h2{
    font-family: "Playfair Display", Georgia, serif;
    font-weight: 600;
    letter-spacing: -0.4px;
    margin: 0 0 10px 0;
    font-size: clamp(26px, 2.4vw, 40px);
    line-height: 1.15;
  }
  #li-root .li-lead{
    font-size: 18px;
    line-height: 1.75;
    margin: 0;
    opacity: .92;
    max-width: 860px;
  }

  /* Standard cards */
  #li-root .li-cards{
    display:grid;
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 8px;
  }
  #li-root .li-card{
    border-radius: var(--radius);
    padding: 18px 18px;
    background: rgba(255,255,255,.80);
    border: 1px solid rgba(16,20,24,.10);
    box-shadow: 0 10px 30px rgba(0,0,0,.05);
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  }
  #li-root .li-dark .li-card{
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: none;
  }
  #li-root .li-card:hover{ transform: translateY(-2px); box-shadow: 0 18px 50px rgba(0,0,0,.10); }
  #li-root .li-dark .li-card:hover{ background: rgba(255,255,255,.08); }

  #li-root .li-cardTitle{
    font-weight: 700;
    font-size: 14px;
    letter-spacing: .3px;
    text-transform: uppercase;
    opacity: .85;
    margin: 0 0 6px 0;
  }
  #li-root .li-cardText{
    margin: 0;
    line-height: 1.65;
    font-size: 16px;
    opacity: .90;
  }

  #li-root .li-list{
    margin: 18px 0 0 0;
    padding-left: 18px;
    line-height: 1.75;
  }
  #li-root .li-list li{ margin: 6px 0; }

  /* CTA cards grid */
  #li-root .li-ctaGrid{
    margin-top: 22px;
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
  }
  @media (max-width: 900px){
    #li-root .li-ctaGrid{ grid-template-columns: 1fr; }
  }
  #li-root .li-ctaCard{
    border-radius: 22px;
    padding: 18px;
    border: 1px solid rgba(16,20,24,.10);
    background: #ffffff;
    box-shadow: 0 10px 30px rgba(0,0,0,.05);
    transition: transform .15s ease, box-shadow .15s ease;
  }
  #li-root .li-ctaCard:hover{ transform: translateY(-2px); box-shadow: 0 18px 50px rgba(0,0,0,.10); }
  #li-root .li-ctaTop{ font-weight: 800; letter-spacing: .2px; margin-bottom: 6px; }
  #li-root .li-ctaDesc{ margin: 0 0 12px 0; color: var(--ink2); line-height: 1.6; }
  #li-root .li-ctaAction{
    display:inline-flex;
    align-items:center;
    gap: 8px;
    text-decoration:none;
    font-weight: 700;
    color: var(--accent);
  }
  #li-root .li-ctaAction:hover{ opacity: .85; }

  /* INFO HUB (tiles) */
  #li-root .li-tiles{
    display:grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-top: 16px;
  }
  @media (max-width: 900px){
    #li-root .li-tiles{ grid-template-columns: 1fr; }
  }
  #li-root .li-tile{
    display:flex;
    gap: 14px;
    align-items:flex-start;
    padding: 18px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    text-decoration:none;
    color: rgba(255,255,255,.92);
    transition: transform .15s ease, background .15s ease, opacity .15s ease;
  }
  #li-root .li-tile:hover{
    transform: translateY(-2px);
    background: rgba(255,255,255,.08);
  }
  #li-root .li-tileIcon{
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight: 900;
    letter-spacing: .2px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.14);
    flex: 0 0 auto;
  }
  #li-root .li-tileTitle{ font-weight: 800; margin: 0 0 6px 0; letter-spacing: .2px; }
  #li-root .li-tileText{ margin: 0; opacity: .78; line-height: 1.55; font-size: 14px; }
  #li-root .li-tileHint{
    margin-top: 10px;
    display:inline-flex;
    gap: 8px;
    align-items:center;
    font-weight: 800;
    font-size: 12px;
    opacity: .85;
  }

  /* IMPORTANT: unified horizontal rows and cards (TOWNS + EVENTS) */
  #li-root .li-hRow{
    display:flex;
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scroll-behavior: smooth;
    cursor: grab;
    user-select: none;
    justify-content: flex-start;
    touch-action: pan-x;
  }
  #li-root .li-hRow::-webkit-scrollbar{ height:0; }
  #li-root .li-hRow.isDragging{ cursor: grabbing; }

  #li-root .li-hCard{
    flex: 0 0 var(--cardW);
    scroll-snap-align: start;
    border-radius: 22px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    text-decoration:none;
    color: rgba(255,255,255,.92);
    transition: transform .15s ease, background .15s ease;
    -webkit-user-drag: none;
  }
  #li-root .li-hCard:hover{
    transform: translateY(-2px);
    background: rgba(255,255,255,.08);
  }
  #li-root .li-hImg{
    height: var(--cardImgH);
    background-size: cover;
    background-position: center;
  }
  #li-root .li-hBody{ padding: 14px 14px 16px; }
  #li-root .li-hTitle{ font-weight: 900; letter-spacing: .1px; margin: 0 0 6px 0; }
  #li-root .li-hText{ margin:0; opacity:.80; line-height: 1.5; font-size: 14px; color: rgba(255,255,255,.82); }

  #li-root .li-hMeta{
    display:flex; gap: 8px; flex-wrap: wrap;
    margin-bottom: 8px;
  }
  #li-root .li-tag{
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.16);
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.85);
    font-size: 12px;
    font-weight: 800;
  }

  /* Footer */
  #li-root .li-footer{
    padding: 54px 20px;
    background: #070a0f;
    color: rgba(255,255,255,.86);
    border-top: 1px solid rgba(255,255,255,.10);
  }
  #li-root .li-footerInner{
    width:min(1100px,100%);
    margin:0 auto;
    display:grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 22px;
    align-items:start;
  }
  @media (max-width: 900px){
    #li-root .li-footerInner{ grid-template-columns: 1fr; }
  }
  #li-root .li-footer h3{
    margin: 0 0 10px 0;
    font-family: "Playfair Display", Georgia, serif;
    font-weight: 600;
    letter-spacing: -0.3px;
    font-size: 26px;
    line-height: 1.2;
  }
  #li-root .li-footer p{ margin: 0; line-height: 1.65; color: rgba(255,255,255,.72); }
  #li-root .li-footerSmall{ margin-top: 14px; font-size: 12px; color: rgba(255,255,255,.55); }
  #li-root .li-social{
    display:flex; gap:10px; flex-wrap:wrap; margin-top: 14px;
  }
  #li-root .li-social a{
    color: rgba(255,255,255,.82);
    text-decoration:none;
    font-weight:700;
    font-size:12px;
    padding: 8px 10px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    background: rgba(255,255,255,.06);
  }
  #li-root .li-social a:hover{ opacity:.85; }

  @media (prefers-reduced-motion: reduce){
    #li-root .li-btn, #li-root .li-link, #li-root .li-card, #li-root .li-ctaCard, #li-root .li-railLink, #li-root .li-hCard{
      transition:none !important;
    }
  }

  /* =========================
     CALENDAR (LIGHT THEME)
     ========================= */
  #li-root .li-calWrap{
    margin-top: 16px;
    border-radius: 22px;
    border: 1px solid rgba(16,20,24,.10);
    background: rgba(255,255,255,.92);
    overflow: hidden;
  }
  #li-root .li-calTop{
    display:flex;
    gap: 10px;
    align-items:center;
    justify-content: space-between;
    padding: 14px 14px;
    border-bottom: 1px solid rgba(16,20,24,.10);
  }
  #li-root .li-calTitle{
    display:flex;
    align-items:baseline;
    gap: 10px;
  }
  #li-root .li-calMonth{
    font-weight: 900;
    letter-spacing: .2px;
    font-size: 16px;
    color: var(--ink);
  }
  #li-root .li-calHint{
    opacity: .7;
    font-size: 12px;
    font-weight: 800;
    color: var(--ink2);
  }
  #li-root .li-calBtns{ display:flex; gap:8px; align-items:center; }
  #li-root .li-calBtn{
    border: 1px solid rgba(16,20,24,.14);
    background: rgba(16,20,24,.03);
    color: var(--ink);
    padding: 9px 12px;
    border-radius: 999px;
    font-weight: 900;
    font-size: 12px;
    cursor: pointer;
  }
  #li-root .li-calBtn:hover{ background: rgba(16,20,24,.06); transform: translateY(-1px); }
  #li-root .li-calFilters{
    display:flex;
    gap: 10px;
    align-items:center;
    flex-wrap: wrap;
    padding: 12px 14px;
    border-bottom: 1px solid rgba(16,20,24,.10);
  }
  #li-root .li-calSelect, #li-root .li-calSearch{
    appearance:none;
    border: 1px solid rgba(16,20,24,.14);
    background: rgba(16,20,24,.03);
    color: var(--ink);
    padding: 10px 12px;
    border-radius: 999px;
    font-weight: 900;
    font-size: 12px;
    outline: none;
  }
  #li-root .li-calSearch{
    appearance: none;
    width: min(420px, 100%);
    font-weight: 700;
  }
  #li-root .li-calGrid{
    display:grid;
    grid-template-columns: repeat(7, 1fr);
  }
  #li-root .li-calDow{
    padding: 10px 8px;
    text-align:center;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .4px;
    opacity: .7;
    border-bottom: 1px solid rgba(16,20,24,.10);
    color: var(--ink2);
  }
  #li-root .li-calDay{
    min-height: 92px;
    padding: 10px 10px 12px;
    border-right: 1px solid rgba(16,20,24,.08);
    border-bottom: 1px solid rgba(16,20,24,.08);
    cursor: pointer;
    position: relative;
  }
  #li-root .li-calDay:nth-child(7n){ border-right: none; }
  #li-root .li-calDay:hover{ background: rgba(16,20,24,.03); }
  #li-root .li-calNum{
    font-weight: 900;
    font-size: 12px;
    opacity: .92;
    color: var(--ink);
  }
  #li-root .li-calMuted{ opacity: .35; }
  #li-root .li-calDots{
    display:flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 10px;
  }
  #li-root .li-calDot{
    width: 8px;
    height: 8px;
    border-radius: 99px;
    border: 1px solid rgba(16,20,24,.18);
    background: rgba(16,20,24,.10);
  }
  #li-root .li-calBadge{
    position:absolute;
    top: 10px;
    right: 10px;
    font-size: 11px;
    font-weight: 900;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(16,20,24,.92);
    color:#ffffff;
  }
  #li-root .li-calBottom{
    padding: 14px;
    border-top: 1px solid rgba(16,20,24,.10);
  }
  #li-root .li-calList{
    display:grid;
    gap: 10px;
  }
  #li-root .li-calEmpty{
    opacity: .75;
    font-weight: 800;
    font-size: 13px;
    color: var(--ink2);
  }
  #li-root .li-miniCard{
    display:flex;
    gap: 12px;
    align-items:flex-start;
    border-radius: 18px;
    border: 1px solid rgba(16,20,24,.10);
    background: rgba(16,20,24,.03);
    padding: 12px;
    text-decoration:none;
    color: var(--ink);
  }
  #li-root .li-miniThumb{
    width: 92px;
    height: 64px;
    border-radius: 14px;
    background-size: cover;
    background-position: center;
    border: 1px solid rgba(16,20,24,.10);
    flex: 0 0 auto;
  }
  #li-root .li-miniMeta{
    display:flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 6px;
    opacity: .8;
    font-weight: 900;
    font-size: 11px;
    color: var(--ink2);
  }
  #li-root .li-miniTitle{ font-weight: 900; margin:0; }
  #li-root .li-miniText{ margin:4px 0 0 0; opacity:.78; font-size: 13px; line-height:1.45; color: var(--ink2); }
  #li-root .li-miniActions{ margin-top:8px; display:flex; gap:10px; flex-wrap:wrap; }
  #li-root .li-miniLink{
    font-weight: 900;
    font-size: 12px;
    text-decoration: none;
    color: var(--accent);
  }
  #li-root .li-miniLink:hover{ opacity:.85; }

  /* ✅ Map inside calendar */
  #li-root .li-mapWrap{
    margin-top: 14px;
    border-radius: 22px;
    border: 1px solid rgba(16,20,24,.10);
    background: #f2f3f5;
    overflow:hidden;
  }
  #li-root #li-map{
    width:100%;
    height: 420px;
  }
  @media (max-width: 900px){
    #li-root .li-calDay{ min-height: 72px; padding: 8px; }
    #li-root #li-map{ height: 320px; }
  }

  /* =========================
     ✅ BUSINESSES EMPTY + MOCK
     ========================= */
  #li-root .li-bizEmpty{
    display:none;
    margin-top: 14px;
    border-radius: 22px;
    border: 1px dashed rgba(16,20,24,.22);
    background: rgba(16,20,24,.02);
    padding: 16px;
  }
  #li-root.isBizEmpty .li-bizEmpty{ display:block; }

  #li-root .li-bizEmptyTitle{
    font-weight: 900;
    margin: 0 0 6px 0;
    letter-spacing: .2px;
  }
  #li-root .li-bizEmptyText{
    margin: 0;
    color: var(--ink2);
    line-height: 1.6;
  }
  #li-root .li-bizEmptyActions{
    margin-top: 10px;
    display:flex;
    gap: 10px;
    flex-wrap: wrap;
  }

  /* ✅ Mock business card grid (only shown when empty) */
  #li-root .li-bizMockWrap{
    margin-top: 14px;
  }
  #li-root .li-bizMockGrid{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
  }
  @media (max-width: 980px){
    #li-root .li-bizMockGrid{ grid-template-columns: repeat(2, 1fr); }
  }
  @media (max-width: 650px){
    #li-root .li-bizMockGrid{ grid-template-columns: 1fr; }
  }

  #li-root .li-bizMockCard{
    border-radius: 22px;
    overflow:hidden;
    border: 1px solid rgba(16,20,24,.10);
    background: #ffffff;
    box-shadow: 0 10px 30px rgba(0,0,0,.05);
    transition: transform .15s ease, box-shadow .15s ease;
    text-decoration:none;
    color: var(--ink);
    display:block;
  }
  #li-root .li-bizMockCard:hover{
    transform: translateY(-2px);
    box-shadow: 0 18px 50px rgba(0,0,0,.10);
  }

  #li-root .li-bizMockImg{
    height: 170px;
    background-size: cover;
    background-position: center;
    background-image: url('https://lakeiseo.info/wp-content/uploads/2026/02/castro.iseo5_.jpeg');
  }

  #li-root .li-bizMockBody{ padding: 14px 14px 16px; }
  #li-root .li-bizMockTop{
    display:flex;
    align-items:flex-start;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
  }
  #li-root .li-bizMockTitle{
    font-weight: 900;
    letter-spacing: .1px;
    margin:0;
    font-size: 16px;
    line-height: 1.2;
  }
  #li-root .li-bizMockTown{
    font-size: 12px;
    font-weight: 900;
    color: rgba(16,20,24,.70);
    white-space: nowrap;
  }
  #li-root .li-bizMockMeta{
    display:flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 10px;
  }
  #li-root .li-bizMockTag{
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(16,20,24,.12);
    background: rgba(16,20,24,.03);
    font-size: 12px;
    font-weight: 900;
    color: rgba(16,20,24,.78);
  }
  #li-root .li-bizMockText{
    margin: 0;
    color: var(--ink2);
    line-height: 1.55;
    font-size: 14px;
    opacity: .92;
  }
  #li-root .li-bizMockActions{
    margin-top: 12px;
    display:flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items:center;
  }
  #li-root .li-bizMockLink{
    font-weight: 900;
    font-size: 12px;
    text-decoration:none;
    color: var(--accent);
  }
  #li-root .li-bizMockLink:hover{ opacity:.85; }
  /* Businesses polish */
  #li-root .li-bizWrap{
    background:#fff;
    border:1px solid rgba(16,20,24,.10);
    border-radius:22px;
    padding:18px;
    box-shadow:0 12px 34px rgba(0,0,0,.06);
  }

  #li-root .li-bizWrap input[type="search"],
  #li-root .li-bizWrap select{
    border-radius:999px !important;
    border:1px solid rgba(16,20,24,.14) !important;
    background:rgba(16,20,24,.03) !important;
    padding:10px 12px !important;
  }

  #li-root .li-bizWrap button{
    border-radius:999px !important;
    font-weight:900 !important;
  }
  /* ✅ FIX iPhone: hide the WP header ONLY on landing that has #li-root */
body.li-landing header.wp-block-template-part,
body.li-landing .wp-site-blocks > header,
body.li-landing .wp-site-blocks > .wp-block-template-part{
  display:none !important;
}

/* ✅ remove any top spacing that WP header/blocks might add */
body.li-landing .wp-site-blocks{
  padding-top:0 !important;
  margin-top:0 !important;
}
body.li-landing header{
  margin:0 !important;
}

/* Things to do section alignment inside landing */
body.li-landing .li-ttd{
  max-width:1180px;
  margin:0 auto;
  padding:0 14px;
}

body.li-landing .li-ttdGrid{
  margin-top:14px;
}
/* Things-to-do cards: force same style as Town cards */
#li-root .li-townGrid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:12px;
}
@media(max-width:1020px){ #li-root .li-townGrid{ grid-template-columns:repeat(3,minmax(0,1fr)); } }
@media(max-width:640px){  #li-root .li-townGrid{ grid-template-columns:repeat(2,minmax(0,1fr)); } }

#li-root .li-townCard{
  display:block;
  text-decoration:none;
  border-radius:18px;
  padding:14px 14px 12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(20,20,20,.35);
  backdrop-filter:blur(10px);
  box-shadow:0 10px 24px rgba(0,0,0,.25);
  transition:transform .15s ease, border-color .15s ease;
}
#li-root .li-townCard:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.22);
}
#li-root .li-townTitle{ font-weight:900; letter-spacing:-.02em; color:#fff; }
#li-root .li-townSub{ margin-top:6px; opacity:.78; font-size:13px; color:#fff; }