.policy-overlay{
  display:none;
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(0,0,0,.5);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  z-index:5000;
  align-items:center;
  justify-content:center;
  animation:fadeIn .3s ease;
}

.policy-overlay.policy-overlay--visible{
  display:flex;
}

body:has(.policy-overlay--visible) .nearChatFab{
  transform:translateY(100px);
  opacity:0;
  pointer-events:none;
}

.policy-card{
  background:rgba(255,255,255,0.98);
  -webkit-backdrop-filter:blur(20px);
  backdrop-filter:blur(20px);
  border:2px dashed rgba(150,150,150,0.3);
  border-radius:20px;
  width:92%;
  max-width:500px;
  max-height:90vh;
  display:flex;
  flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
  animation:slideUp .3s ease;
  overflow:hidden;
}

.policy-card__body{
  padding:28px 24px 0;
  overflow-y:auto;
  flex:1;
  -webkit-overflow-scrolling:touch;
}

.policy-card__logo{
  font-size:28px;
  font-weight:900;
  letter-spacing:-0.5px;
  margin-bottom:20px;
  text-align:center;
}

.policy-card__logo span{
  color:var(--accent, #222);
}

.policy-card__text{
  font-size:14px;
  line-height:1.65;
  color:#444;
}

.policy-card__text p{
  margin:0 0 12px;
}

.policy-card__text p:last-child{
  margin-bottom:0;
}

.policy-card__bottom{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-top:16px;
}

.policy-card__signature{
  font-weight:700;
  color:#222;
  margin:0;
}

.policy-card__rules-link{
  color:#222;
  font-size:13px;
  font-weight:600;
  text-decoration:underline;
  text-underline-offset:3px;
  transition:opacity .2s ease;
  white-space:nowrap;
}

.policy-card__rules-link:hover{
  opacity:0.6;
}

.policy-card__rules-link:focus-visible{
  outline:2px solid #222;
  outline-offset:2px;
}

.policy-card__link{
  margin-top:12px;
}

.policy-card__link a{
  color:#222;
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:3px;
  transition:opacity .2s ease;
}

.policy-card__link a:hover{
  opacity:0.6;
}

.policy-card__link a:focus-visible{
  outline:2px solid #222;
  outline-offset:2px;
}

.policy-card__footer{
  padding:16px 24px 24px;
  position:sticky;
  bottom:0;
  background:rgba(255,255,255,0.98);
}

.policy-card__accept{
  width:100%;
  padding:14px 18px;
  border-radius:12px;
  border:none;
  background:#111;
  color:#fff;
  font-weight:700;
  font-size:15px;
  cursor:pointer;
  transition:all .2s ease;
  font-family:inherit;
}

.policy-card__accept:hover{
  background:#000;
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(0,0,0,.2);
}

.policy-card__accept:focus-visible{
  outline:2px solid #222;
  outline-offset:2px;
}

.policy-card__accept:active{
  transform:translateY(0);
}

@media (max-width:480px){
  .policy-card{
    width:96%;
    border-radius:16px;
  }

  .policy-card__body{
    padding:14px 16px 0;
  }

  .policy-card__footer{
    padding:10px 16px 14px;
  }

  .policy-card__logo{
    font-size:20px;
    margin-bottom:12px;
  }

  .policy-card__text{
    font-size:12px;
    line-height:1.5;
  }

  .policy-card__text p{
    margin:0 0 6px;
  }

  .policy-card__bottom{
    margin-top:10px;
  }

  .policy-card__accept{
    padding:12px 14px;
    font-size:14px;
  }
}

.policy-page{
  max-width:720px;
  margin:24px auto;
  padding:32px;
  background:rgba(255,255,255,0.85);
  -webkit-backdrop-filter:blur(16px);
  backdrop-filter:blur(16px);
  border:2px dashed rgba(150,150,150,0.28);
  border-radius:18px;
  box-shadow:0 4px 16px rgba(0,0,0,.04);
}

.policy-page__title{
  font-size:22px;
  font-weight:900;
  color:#111;
  letter-spacing:-0.4px;
  margin:0 0 28px;
  text-align:center;
}

.policy-page__section{
  margin-bottom:28px;
}

.policy-page__section:last-child{
  margin-bottom:0;
}

.policy-page__section h2{
  font-size:16px;
  font-weight:800;
  color:#222;
  margin:0 0 12px;
  letter-spacing:-0.2px;
}

.policy-page__section p{
  font-size:14px;
  line-height:1.65;
  color:#444;
  margin:0 0 8px;
}

.policy-page__section p:last-child{
  margin-bottom:0;
}

.policy-page__section ul{
  margin:4px 0 8px 20px;
  padding:0;
}

.policy-page__section li{
  font-size:14px;
  line-height:1.65;
  color:#444;
  margin-bottom:4px;
}

@media (max-width:768px){
  .policy-page{
    margin:12px;
    padding:20px;
    border-radius:14px;
  }

  .policy-page__title{
    font-size:18px;
  }

  .policy-page__section h2{
    font-size:15px;
  }
}
