
    :root{
      --card-bg: rgba(255,255,255,0.70);
      --card-radius: 22px;
      --card-maxw: 980px;
      --card-maxh: 86vh;
      --shadow: 0 12px 40px rgba(0,0,0,0.25);
      --text: #0f172a;
      --muted: rgba(15,23,42,0.65);
      --accent: #0b5cab;
    }
    *{ box-sizing:border-box; }

    html, body{
      height: 100%;
      margin: 0;
      overflow: hidden;
      background: #000;
      font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }

    .bg{
      position: fixed;
      inset: 0;
      z-index: 0;
      background-image: url("./horizontal.png");
      background-repeat: no-repeat;
      background-size: auto 100%;
      background-color: #000;
      background-position: 50% 45%;
    }
@media (max-width: 768px) and (orientation: portrait){
  .bg{
    background-image: url("./vertical.png");
  }
}
@media (max-width: 768px) and (orientation: landscape){
  .bg{
    background-image: url("./horizontal.png");
  }
}    
.bg-dim{
      position: fixed;
      inset: 0;
      z-index: 1;
      pointer-events: none;
      background: radial-gradient(ellipse at center, rgba(0,0,0,0.10), rgba(0,0,0,0.28));
    }

    .stage{
      position: fixed;
      inset: 0;
      z-index: 2;
      display: grid;
      place-items: center;
      padding: 16px;
    }
.venue a:hover{
  text-decoration: underline;
}
.empty a{
  color: var(--accent);
  text-decoration: none;
}
.empty a:hover{
  text-decoration: underline;
}

    .card{
      width: min(var(--card-maxw), 100%);
      max-height: var(--card-maxh);
      background: var(--card-bg);
      border-radius: var(--card-radius);
      box-shadow: var(--shadow);
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
      overflow: hidden;

      opacity: 0;
      transform: translateY(8px) scale(0.99);
      transition: opacity 420ms ease, transform 420ms ease;

      display: grid;
      grid-template-rows: auto 1fr auto;
    }
    .card.visible{ opacity: 1; transform: translateY(0) scale(1); }

    .card-header{
      padding: 10px 12px 12px;
      border-bottom: 1px solid rgba(15,23,42,0.10);
      display: grid;
      gap: 10px;
    }
    .toprow{
      display:flex;
      align-items:center;
      justify-content: space-between;
      gap: 10px;
    }
    .card-header h1{
      margin: 0;
      font-size: 16px;
      letter-spacing: 0.2px;
      color: var(--text);
      white-space: nowrap;
    }

    .rtabs{
      display:flex;
      gap: 8px;
      align-items:center;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      padding: 0 2px 2px;
      scrollbar-width: none;
    }
    .rtabs::-webkit-scrollbar{ display:none; }

    .rtab{
      border: 1px solid rgba(15,23,42,0.14);
      background: rgba(255,255,255,0.55);
      color: var(--text);
      border-radius: 999px;
      padding: 7px 10px;
      font-size: 13px;
      cursor: pointer;
      user-select: none;
      white-space: nowrap;
      transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
    }
    .rtab:active{ transform: scale(0.98); }
    .rtab.active{
      background: rgba(11,92,171,0.16);
      border-color: rgba(11,92,171,0.35);
      color: #0b5cab;
      font-weight: 650;
    }

    .content{
      overflow: auto;
      -webkit-overflow-scrolling: touch;
      padding: 12px;
    }
    .content::-webkit-scrollbar{ width: 10px; }
    .content::-webkit-scrollbar-thumb{
      background: rgba(15,23,42,0.20);
      border-radius: 999px;
      border: 2px solid rgba(255,255,255,0.45);
    }
    .content::-webkit-scrollbar-track{ background: transparent; }

    .venue{
      margin: 2px 0 6px 0;
      font-size: 20px;
      line-height: 1.15;
    }
    .subline{
      display:flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 12px;
      color: var(--muted);
      font-size: 12px;
      margin-bottom: 10px;
    }

    .menu-box{
      border-radius: 16px;
      background: rgba(255,255,255,0.55);
      border: 1px solid rgba(15,23,42,0.10);
      padding: 12px 12px;
    }
    .menu-list{
      margin: 0;
      padding-left: 18px;
      display: grid;
      gap: 8px;
    }
    .menu-list li{
      line-height: 1.35;
      color: var(--text);
      font-size: 14px;
    }
    .menu-list .small{
      color: var(--muted);
      font-size: 13px;
    }

    .dayblock{
      padding: 10px 0 2px 0;
      border-top: 1px solid rgba(15,23,42,0.10);
      margin-top: 10px;
    }
    .dayblock:first-child{
      border-top: none;
      margin-top: 0;
      padding-top: 0;
    }
    .daytitle{
      margin: 0 0 6px 0;
      font-size: 13px;
      font-weight: 750;
      color: rgba(15,23,42,0.85);
    }

    .empty{
      padding: 8px 2px;
      color: var(--muted);
      font-size: 14px;
    }

    .footer{
      border-top: 1px solid rgba(15,23,42,0.10);
      background: rgba(255,255,255,0.25);
      padding: 10px 12px 12px;
      display: grid;
      gap: 10px;
    }

    .tabs{
  display:flex;
  gap: 8px;
  align-items:center;
  justify-content: flex-start;   /* <-- tämä */
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0 10px;               /* <-- tämä */
  scrollbar-width: none;
}
    .tabs::-webkit-scrollbar{ display:none; }

    .tab{
      border: 1px solid rgba(15,23,42,0.14);
      background: rgba(255,255,255,0.55);
      color: var(--text);
      border-radius: 999px;
      padding: 7px 10px;
      font-size: 13px;
      cursor: pointer;
      user-select: none;
      white-space: nowrap;
      transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
    }
    .tab:active{ transform: scale(0.98); }
    .tab.active{
      background: rgba(11,92,171,0.16);
      border-color: rgba(11,92,171,0.35);
      color: #0b5cab;
      font-weight: 650;
    }

    @media (max-width: 480px){
      :root{ --card-radius: 18px; }
      .card-header{ padding: 10px 10px 12px; }
      .content{ padding: 10px; }
      .venue{ font-size: 18px; }
      .footer{ padding: 10px 10px 12px; }
    }
