.register-premium-hero{
  position:relative;
  overflow:hidden;
  padding:136px 0 72px;
  color:#fff;
  background:
    radial-gradient(circle at 78% 18%,rgba(57,159,219,.42),transparent 28%),
    linear-gradient(135deg,#03172f 0%,#062f5f 48%,#074d86 100%);
}
.register-premium-hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg,rgba(255,255,255,.06) 0 1px,transparent 1px 100%),
    radial-gradient(circle at 8% 85%,rgba(255,194,71,.18),transparent 27%);
  background-size:34px 34px,auto;
  opacity:.7;
}
.register-hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) 330px;
  gap:34px;
  align-items:center;
}
.register-kicker{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:0 17px;
  border:1px solid rgba(255,194,71,.44);
  border-radius:999px;
  background:rgba(255,194,71,.14);
  color:#ffd36d;
  font-size:12px;
  font-weight:900;
  letter-spacing:1.7px;
}
.register-hero-copy h1{
  max-width:790px;
  margin:20px 0 18px;
  font-family:"Plus Jakarta Sans","Inter",sans-serif;
  font-size:58px;
  line-height:1.04;
  letter-spacing:-2.4px;
}
.register-hero-copy p{
  max-width:660px;
  margin:0;
  color:#d7e8f3;
  font-size:17px;
  line-height:1.75;
}
.register-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:13px;
  margin-top:30px;
}
.btn-ghost-light{
  border:1px solid rgba(255,255,255,.42);
  background:rgba(255,255,255,.08);
  color:#fff;
  backdrop-filter:blur(10px);
}
.btn-ghost-light:hover{background:rgba(255,255,255,.16)}
.register-hero-card{
  position:relative;
  overflow:hidden;
  min-height:275px;
  padding:28px;
  border:1px solid rgba(255,255,255,.2);
  border-radius:28px;
  background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.07));
  box-shadow:0 28px 80px rgba(0,0,0,.22);
  backdrop-filter:blur(14px);
}
.register-hero-card:after{
  content:"";
  position:absolute;
  right:-54px;
  bottom:-54px;
  width:170px;
  height:170px;
  border-radius:50%;
  border:28px solid rgba(255,194,71,.18);
}
.register-hero-card img{
  width:78px;
  height:78px;
  object-fit:contain;
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.22));
}
.register-hero-card small,
.register-hero-card strong,
.register-hero-card span,
.register-hero-card i{display:block;position:relative;z-index:1}
.register-hero-card small{
  margin-top:30px;
  color:#9edcff;
  font-size:11px;
  font-weight:900;
  letter-spacing:1.8px;
}
.register-hero-card strong{
  margin:8px 0 4px;
  font-family:"Plus Jakarta Sans","Inter",sans-serif;
  font-size:31px;
  letter-spacing:-.8px;
}
.register-hero-card span{color:#e5f1f8;font-size:14px}
.register-hero-card i{
  width:max-content;
  margin-top:24px;
  padding:10px 14px;
  border-radius:14px;
  background:#ffc247;
  color:#062d55;
  font-size:12px;
  font-style:normal;
  font-weight:900;
}

.register-progress{
  position:relative;
  z-index:3;
  margin-top:-34px;
}
.register-progress>.container{
  min-height:86px;
  padding:18px 30px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px;
  border:1px solid #dbe8f0;
  border-radius:22px;
  background:rgba(255,255,255,.95);
  box-shadow:0 24px 70px rgba(6,45,91,.13);
  backdrop-filter:blur(12px);
}
.register-progress div{
  display:flex;
  align-items:center;
  gap:10px;
  color:#6e8190;
  font-size:13px;
  font-weight:900;
}
.register-progress div b{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:#edf4f9;
  color:#748898;
  font-size:12px;
}
.register-progress div.active{color:#062d55}
.register-progress div.active b{
  background:linear-gradient(145deg,#064b86,#0877bd);
  color:#fff;
  box-shadow:0 12px 25px rgba(8,113,180,.22);
}
.register-progress i{
  width:64px;
  height:1px;
  background:linear-gradient(90deg,#d1dde7,#ffc247,#d1dde7);
}

.register-premium-page{
  padding:64px 0 95px;
  background:linear-gradient(180deg,#f7fbfe 0,#fff 36%);
}
.register-premium-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 350px;
  gap:30px;
  align-items:start;
}
.register-premium-form{
  padding:34px;
  border:1px solid #dce8f0;
  border-radius:28px;
  background:#fff;
  box-shadow:0 26px 80px rgba(6,45,91,.1);
}
.register-form-head{
  margin-bottom:30px;
  padding:24px;
  border:1px solid #dce8f0;
  border-radius:22px;
  background:
    radial-gradient(circle at 95% 0,rgba(255,194,71,.23),transparent 31%),
    linear-gradient(135deg,#f8fbfe,#fff);
}
.register-form-head span{
  color:#0871b4;
  font-size:11px;
  font-weight:950;
  letter-spacing:1.8px;
}
.register-form-head h2{
  margin:8px 0 7px;
  color:#062d55;
  font-family:"Plus Jakarta Sans","Inter",sans-serif;
  font-size:34px;
  letter-spacing:-1.2px;
}
.register-form-head p{margin:0;color:#647889;font-size:14px;line-height:1.65}
.register-section-title{
  margin:34px 0 18px;
  display:flex;
  align-items:center;
  gap:14px;
}
.register-section-title:first-of-type{margin-top:0}
.register-section-title>b{
  width:48px;
  height:48px;
  flex:0 0 48px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:linear-gradient(145deg,#062d55,#0871b4);
  color:#fff;
  font-size:13px;
  box-shadow:0 13px 25px rgba(8,113,180,.2);
}
.register-section-title h3{
  margin:0;
  color:#062d55;
  font-family:"Plus Jakarta Sans","Inter",sans-serif;
  font-size:23px;
  letter-spacing:-.7px;
}
.register-section-title p{margin:4px 0 0;color:#6f8190;font-size:13px}
.document-title{align-items:flex-start}
.register-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.register-grid .span-2{grid-column:1/-1}
.register-premium-form label{
  display:grid;
  gap:8px;
  color:#203b54;
  font-size:13px;
  font-weight:900;
}
.register-premium-form input,
.register-premium-form select,
.register-premium-form textarea{
  width:100%;
  min-height:52px;
  padding:0 15px;
  border:1px solid #d4e2ec;
  border-radius:15px;
  background:#f8fbfe;
  color:#062d55;
  font:700 14px/1.5 "Inter","Plus Jakarta Sans",sans-serif;
  outline:none;
  transition:.2s ease;
}
.register-premium-form textarea{
  min-height:112px;
  padding:14px 15px;
  resize:vertical;
}
.register-premium-form input:focus,
.register-premium-form select:focus,
.register-premium-form textarea:focus{
  border-color:#0871b4;
  background:#fff;
  box-shadow:0 0 0 4px rgba(8,113,180,.09);
}
.requirements-upload-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:15px;
}
.requirement-upload-card{
  position:relative;
  overflow:hidden;
  min-height:176px;
  padding:21px;
  display:flex!important;
  flex-direction:column;
  justify-content:space-between;
  gap:10px!important;
  border:1px solid #d9e6ef;
  border-radius:22px;
  background:
    radial-gradient(circle at 100% 0,rgba(8,113,180,.08),transparent 28%),
    linear-gradient(180deg,#fff,#f8fbfe);
  box-shadow:0 13px 34px rgba(6,45,91,.055);
  cursor:pointer;
}
.requirement-upload-card:before{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:4px;
  background:linear-gradient(90deg,#062d55,#0871b4,#ffc247);
}
.requirement-upload-card.required .req-number{background:#062d55;color:#fff}
.requirement-upload-card.optional .req-number{background:#fff2cf;color:#8a5b00}
.req-number{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:14px;
  font-size:13px;
  font-weight:950;
}
.req-icon{
  position:absolute;
  right:18px;
  top:18px;
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:#edf6fc;
  font-size:21px;
}
.requirement-upload-card b{
  max-width:78%;
  color:#062d55;
  font-family:"Plus Jakarta Sans","Inter",sans-serif;
  font-size:17px;
  line-height:1.28;
  letter-spacing:-.45px;
}
.requirement-upload-card small{
  color:#718493;
  font-size:12px;
  font-weight:800;
}
.requirement-upload-card input{
  min-height:44px;
  padding:8px;
  border-radius:13px;
  background:#fff;
  font-size:12px;
  font-weight:800;
}
.register-consent{
  margin:28px 0 18px;
  padding:17px 18px;
  display:flex!important;
  grid-template-columns:auto 1fr;
  flex-direction:row!important;
  align-items:flex-start;
  gap:12px!important;
  border:1px solid #d4e7f2;
  border-radius:17px;
  background:#f2f8fc;
}
.register-consent input{
  width:18px;
  min-height:18px;
  margin-top:2px;
  flex:0 0 18px;
}
.register-consent span{
  color:#4c6273;
  font-size:13px;
  line-height:1.55;
}
.register-submit{
  min-height:58px;
  justify-content:space-between;
  padding-left:24px;
  padding-right:24px;
  border-radius:17px;
  font-size:15px;
  font-weight:950;
}
.register-premium-aside{
  position:sticky;
  top:24px;
  display:grid;
  gap:18px;
}
.register-aside-card,
.register-security-note{
  border:1px solid #dce8f0;
  border-radius:24px;
  background:#fff;
  box-shadow:0 18px 55px rgba(6,45,91,.075);
}
.register-aside-card{padding:24px}
.register-aside-card.primary{
  overflow:hidden;
  color:#fff;
  border:0;
  background:
    radial-gradient(circle at 100% 0,rgba(57,159,219,.42),transparent 30%),
    linear-gradient(145deg,#031a35,#064f87);
}
.register-aside-card.primary img{
  width:78px;
  height:78px;
  object-fit:contain;
  margin-bottom:18px;
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.2));
}
.register-aside-card.primary>span{
  display:block;
  color:#95d9ff;
  font-size:11px;
  font-weight:950;
  letter-spacing:1.2px;
}
.register-aside-card h3{
  margin:7px 0 14px;
  color:#062d55;
  font-family:"Plus Jakarta Sans","Inter",sans-serif;
  font-size:21px;
  letter-spacing:-.55px;
}
.register-aside-card.primary h3{color:#fff}
.register-aside-card ul{
  list-style:none;
  padding:0;
  margin:18px 0 0;
}
.register-aside-card li{
  position:relative;
  padding-left:24px;
  margin:12px 0;
  color:#dcecf6;
  font-size:13px;
  line-height:1.45;
}
.register-aside-card li:before{
  content:"✓";
  position:absolute;
  left:0;
  color:#ffc247;
  font-weight:950;
}
.aside-requirement-list{display:grid;gap:10px}
.aside-requirement-list div{
  display:grid;
  grid-template-columns:38px 1fr;
  align-items:center;
  gap:10px;
  padding:10px;
  border:1px solid #e0eaf1;
  border-radius:15px;
  background:#f8fbfe;
}
.aside-requirement-list b{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:#062d55;
  color:#fff;
  font-size:12px;
}
.aside-requirement-list span{
  color:#234159;
  font-size:12px;
  font-weight:850;
  line-height:1.35;
}
.register-security-note{
  padding:20px;
  background:linear-gradient(135deg,#f1fbf6,#fff);
}
.register-security-note b{
  color:#176b48;
  font-size:14px;
  font-weight:950;
}
.register-security-note p{
  margin:6px 0 0;
  color:#5f756b;
  font-size:12px;
  line-height:1.55;
}

@media(max-width:1040px){
  .register-hero-grid,
  .register-premium-layout{grid-template-columns:1fr}
  .register-premium-aside{position:static}
  .register-hero-card{max-width:430px}
}
@media(max-width:760px){
  .register-premium-hero{padding:112px 0 58px}
  .register-hero-copy h1{font-size:40px;letter-spacing:-1.5px}
  .register-hero-copy p{font-size:15px}
  .register-progress>.container{
    align-items:stretch;
    flex-direction:column;
    gap:10px;
  }
  .register-progress i{width:1px;height:18px;margin-left:18px}
  .register-grid,
  .requirements-upload-grid{grid-template-columns:1fr}
  .register-grid .span-2{grid-column:auto}
  .register-premium-form{padding:22px}
  .register-form-head{padding:20px}
  .register-form-head h2{font-size:27px}
}
@media(max-width:520px){
  .register-hero-actions .btn{width:100%;justify-content:center}
  .register-hero-card{min-height:240px;padding:22px}
  .register-section-title{align-items:flex-start}
  .register-section-title h3{font-size:20px}
}
