.pv-protect{
  background:#0b1020;
  min-height:100vh;
  padding:40px 20px;
  color:#fff;
  font-family:Arial, Helvetica, sans-serif;
}

.pv-protect__inner{
  max-width:1200px;
  margin:0 auto;
}

.pv-screen{
  display:none;
}

.pv-screen.is-active{
  display:block;
}

.pv-login-card{
  max-width:520px;
  margin:80px auto;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:24px;
  padding:36px;
  box-shadow:0 30px 60px rgba(0,0,0,0.35);
  text-align:center;
}

.pv-login-card__icon{
  width:78px;
  height:78px;
  border-radius:20px;
  background:linear-gradient(135deg,#1d4ed8,#06b6d4);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 18px;
  font-size:30px;
}

.pv-login-card__title{
  margin:0 0 10px;
  font-size:32px;
  line-height:1.2;
}

.pv-login-card__text{
  margin:0 0 24px;
  color:rgba(255,255,255,0.75);
  font-size:15px;
  line-height:1.7;
}

.pv-login-form{
  text-align:left;
}

.pv-field{
  margin-bottom:16px;
}

.pv-field label{
  display:block;
  font-size:13px;
  font-weight:700;
  margin:0 0 8px;
  color:#fff;
}

.pv-field input,
.pv-field textarea,
.pv-form-box .wpcf7 input,
.pv-form-box .wpcf7 textarea,
.pv-form-box .wpcf7 select{
  width:100%;
  background:#fff;
  color:#111827;
  border:1px solid #d1d5db;
  border-radius:14px;
  min-height:52px;
  padding:14px 16px;
  outline:none;
  box-sizing:border-box;
  font-size:15px;
}

.pv-field textarea,
.pv-form-box .wpcf7 textarea{
  min-height:140px;
  resize:vertical;
}

.pv-btn{
  border:none;
  border-radius:14px;
  min-height:54px;
  padding:0 22px;
  font-size:15px;
  font-weight:700;
  cursor:pointer;
  transition:all .25s ease;
}

.pv-btn--primary{
  background:linear-gradient(135deg,#2563eb,#06b6d4);
  color:#fff;
  width:100%;
}

.pv-btn--primary:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 30px rgba(37,99,235,0.25);
}

.pv-login-error{
  color:#fca5a5;
  font-size:14px;
  margin:12px 0 0;
}

.pv-topnote{
  display:flex;
  gap:16px;
  align-items:flex-start;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:20px;
  padding:20px;
  margin-bottom:28px;
}

.pv-topnote__icon{
  width:52px;
  height:52px;
  flex:0 0 52px;
  border-radius:14px;
  background:#1f2937;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
}

.pv-topnote h3{
  margin:0 0 6px;
  font-size:20px;
}

.pv-topnote p{
  margin:0;
  color:rgba(255,255,255,0.76);
  line-height:1.7;
}

.pv-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}

.pv-cube{
  appearance:none;
  border:none;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:24px;
  padding:28px 22px;
  color:#fff;
  text-align:left;
  min-height:190px;
  cursor:pointer;
  transition:all .25s ease;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.pv-cube:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,0.22);
  box-shadow:0 24px 40px rgba(0,0,0,0.28);
}

.pv-cube__icon{
  width:64px;
  height:64px;
  border-radius:18px;
  background:rgba(255,255,255,0.08);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:28px;
}

.pv-cube__icon img,
.pv-form-head__icon img{
  width:32px;
  height:32px;
  object-fit:contain;
}

.pv-cube__title{
  display:block;
  font-size:20px;
  line-height:1.4;
  font-weight:700;
}

.pv-form-wrap{
  max-width:860px;
  margin:0 auto;
}

.pv-back{
  border:none;
  background:none;
  color:#fff;
  font-size:15px;
  font-weight:700;
  padding:0;
  margin:0 0 18px;
  cursor:pointer;
}

.pv-form-head{
  display:flex;
  gap:16px;
  align-items:flex-start;
  margin-bottom:20px;
}

.pv-form-head__icon{
  width:70px;
  height:70px;
  flex:0 0 70px;
  border-radius:20px;
  background:rgba(255,255,255,0.08);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:28px;
}

.pv-form-head h2{
  margin:0 0 8px;
  font-size:30px;
}

.pv-form-head p{
  margin:0;
  color:rgba(255,255,255,0.75);
  line-height:1.7;
}

.pv-form-box{
  background:#fff;
  color:#111827;
  border-radius:24px;
  padding:26px;
  box-shadow:0 20px 45px rgba(0,0,0,0.25);
}

.pv-field-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}

.pv-note{
  margin:16px 0 18px;
  padding:14px 16px;
  border-radius:14px;
  background:#eff6ff;
  color:#1e3a8a;
  font-size:14px;
  line-height:1.7;
}

.pv-form-box .wpcf7-form p{
  margin:0 0 16px;
}

.pv-form-box .wpcf7-submit{
  width:100%;
  min-height:54px;
  border:none;
  border-radius:14px;
  background:linear-gradient(135deg,#2563eb,#06b6d4);
  color:#fff;
  font-size:15px;
  font-weight:700;
  cursor:pointer;
}

.pv-form-box .wpcf7-spinner{
  display:block;
  margin:12px auto 0;
}

.pv-form-box .wpcf7-response-output{
  margin:16px 0 0 !important;
  border-radius:12px;
  padding:12px 14px !important;
  font-size:14px;
}

@media (max-width: 991px){
  .pv-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .pv-form-head h2{
    font-size:26px;
  }
}

@media (max-width: 767px){
  .pv-protect{
    padding:24px 14px;
  }

  .pv-login-card{
    margin:30px auto;
    padding:24px 18px;
    border-radius:20px;
  }

  .pv-login-card__title{
    font-size:26px;
  }

  .pv-grid{
    grid-template-columns:1fr;
  }

  .pv-topnote{
    padding:16px;
  }

  .pv-form-box{
    padding:18px;
    border-radius:20px;
  }

  .pv-field-grid{
    grid-template-columns:1fr;
  }

  .pv-form-head{
    flex-direction:column;
  }
}