  :root{
    --vip-accent:#F6B91D;
    --vip-bg:#000000;
    --vip-fg:#FFFFFF;
    --vip-muted: rgba(255,255,255,.72);
    --vip-shadow: 0 18px 48px rgba(0,0,0,.45);
  }

  /* Floating button */
  .vip-fab{
    position: fixed;
    right: 50px;
    bottom: 115px; /* якщо є WhatsApp кнопка знизу (bottom:50px) */
    z-index: 120;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 14px 18px;
    border-radius: 999px;
    border: 1px solid rgba(246,185,29,.65);
    background: rgba(0,0,0,.88);
    color: var(--vip-fg);
    font: 700 13px/1.1 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    letter-spacing: .2px;
    cursor: pointer;
    box-shadow: 0 10px 26px rgba(0,0,0,.35), 0 0 0 0 rgba(246,185,29,.55);
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
    -webkit-tap-highlight-color: transparent;
  }
  .vip-fab:hover{ transform: translateY(-2px); box-shadow: 0 14px 36px rgba(0,0,0,.44), 0 0 0 6px rgba(246,185,29,.12); }
  .vip-fab:active{ transform: translateY(0); }
  .vip-fab__dot{
    width: 10px; height: 10px; border-radius: 99px;
    background: var(--vip-accent);
    box-shadow: 0 0 0 0 rgba(246,185,29,.55);
    animation: vipPulse 1.8s infinite;
    flex: 0 0 auto;
  }
  .vip-fab__text{
    color: #fff;
    text-shadow: 0 1px 0 rgba(0,0,0,.45), 0 0 18px rgba(0,0,0,.25);
    white-space: nowrap;
  }
  @keyframes vipPulse{
    0%{ box-shadow: 0 0 0 0 rgba(246,185,29,.55); }
    70%{ box-shadow: 0 0 0 10px rgba(246,185,29,0); }
    100%{ box-shadow: 0 0 0 0 rgba(246,185,29,0); }
  }

  /* Modal overlay */
  .vip-overlay{
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,.58);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    padding: 18px;
  }
  .vip-overlay.is-open{ display: flex; }

  .vip-modal{
    width: min(560px, 100%);
    background: rgba(0,0,0,.92);
    border: 1px solid rgba(246,185,29,.35);
    border-radius: 18px;
    color: var(--vip-fg);
    box-shadow: var(--vip-shadow);
    overflow: hidden;
    transform: translateY(8px);
    opacity: 0;
    transition: transform .22s ease, opacity .22s ease;
  }
  .vip-overlay.is-open .vip-modal{ transform: translateY(0); opacity: 1; }

  .vip-modal__head{
    padding: 16px 16px 12px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    display:flex;
    align-items:flex-start;
    gap: 12px;
  }
  .vip-handle{ display:none; }

  .vip-title{
    margin: 0;
    font: 800 18px/1.2 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    letter-spacing: .2px;
  }
  .vip-sub{
    margin: 6px 0 0;
    color: var(--vip-muted);
    font: 400 13.5px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }
  .vip-close{
    margin-left:auto;
    border: 0;
    background: transparent;
    color: rgba(255,255,255,.88);
    cursor: pointer;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display:grid;
    place-items:center;
    transition: background .15s ease;
  }
  .vip-close:hover{ background: rgba(255,255,255,.08); }
  .vip-close svg{ width: 18px; height: 18px; }

  .vip-modal__body{
    padding: 14px 16px 16px;
    max-height: min(64vh, 560px);
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  .vip-bullets{
    margin: 0 0 14px 0;
    padding: 0;
    list-style: none;
    display:grid;
    gap: 10px;
  }
  .vip-bullet{
    display:flex;
    gap: 10px;
    padding: 11px 12px;
    border-radius: 14px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.06);
  }
  .vip-check{
    width: 18px; height: 18px; border-radius: 6px;
    background: rgba(246,185,29,.18);
    border: 1px solid rgba(246,185,29,.35);
    flex: 0 0 auto;
    display:grid;
    place-items:center;
  }
  .vip-check:before{
    content:"";
    width: 8px; height: 8px;
    background: var(--vip-accent);
    border-radius: 3px;
    display:block;
  }
  .vip-bullet b{
    display:block;
    font: 700 13.5px/1.2 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }
  .vip-bullet span{
    display:block;
    margin-top: 2px;
    color: var(--vip-muted);
    font: 400 13px/1.45 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }

  .vip-contacts{
    margin-top: 12px;
    padding: 12px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(246,185,29,.10), rgba(255,255,255,.04));
    border: 1px solid rgba(246,185,29,.22);
    display:grid;
    gap: 10px;
  }
  .vip-row{
    display:flex;
    gap: 10px;
    align-items:flex-start;
    color: rgba(255,255,255,.92);
    font: 500 13.2px/1.35 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }
  .vip-ico{
    width: 26px; height: 26px;
    border-radius: 10px;
    background: rgba(0,0,0,.55);
    border: 1px solid rgba(255,255,255,.10);
    display:grid;
    place-items:center;
    flex:0 0 auto;
  }
  .vip-ico svg{ width: 14px; height: 14px; fill: var(--vip-accent); }
  .vip-row a{
    color: var(--vip-fg);
    text-decoration: none;
    border-bottom: 1px dashed rgba(246,185,29,.55);
  }
  .vip-row a:hover{ border-bottom-color: rgba(246,185,29,.95); }

  .vip-actions{
    margin-top: 14px;
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .vip-btn{
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.06);
    color: var(--vip-fg);
    padding: 12px 12px;
    border-radius: 14px;
    font: 800 13px/1.1 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    cursor: pointer;
    text-decoration: none;
    display:flex;
    align-items:center;
    justify-content:center;
    gap: 8px;
    transition: transform .14s ease, background .14s ease, border-color .14s ease;
  }
  .vip-btn:hover{ transform: translateY(-1px); border-color: rgba(246,185,29,.30); }
  .vip-btn--accent{
    background: rgba(246,185,29,.96);
    border-color: rgba(246,185,29,.92);
    color: #000;
  }
  .vip-btn--accent:hover{ background: rgba(246,185,29,1); }
  .vip-btn svg{ width: 16px; height: 16px; }

  .vip-small{
    margin: 12px 0 0;
    color: rgba(255,255,255,.55);
    font: 400 11.5px/1.4 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  }

  /* Lock page scroll when modal open */
  body.vip-scroll-locked{
    position: fixed;
    width: 100%;
    overflow: hidden;
  }

  /* Mobile bottom sheet */
  @media (max-width: 640px){
    .vip-fab{
      right: 14px;
      bottom: 92px;
      padding: 14px 16px;
      font-size: 14px;
      z-index: 9998;
    }
    .vip-overlay{
      align-items: flex-end;
      padding: 10px;
    }
    .vip-modal{
      width: 100%;
      border-radius: 18px 18px 14px 14px;
      transform: translateY(100%);
      transition: transform .28s cubic-bezier(.2,.9,.2,1), opacity .22s ease;
    }
    .vip-overlay.is-open .vip-modal{ transform: translateY(0); }

    .vip-handle{
      display:block;
      width: 44px;
      height: 5px;
      border-radius: 999px;
      background: rgba(255,255,255,.22);
      margin: 10px auto 8px;
    }
    .vip-modal__head{ padding-top: 6px; }
    .vip-modal__body{
      max-height: 72vh;
      padding-bottom: 18px;
    }
    .vip-actions{ grid-template-columns: 1fr; }
  }

