:root{
  --cl-bg: #08101c;
  --cl-surface: rgba(11,18,32,.76);
  --cl-surface-2: rgba(255,255,255,.05);
  --cl-border: rgba(255,255,255,.08);
  --cl-text: #ffffff;
  --cl-text-soft: rgba(255,255,255,.82);
  --cl-text-dim: rgba(255,255,255,.60);
  --cl-accent: #6d8fff;
  --cl-success: #29c56f;
  --cl-shadow: 0 24px 70px rgba(0,0,0,.34);
  --cl-radius-xl: 34px;
  --cl-radius-lg: 26px;
  --cl-radius-md: 20px;
}

*{
  box-sizing: border-box;
}

html, body{
  min-height: 100%;
}

body.customer-login-page{
  margin: 0;
  color: var(--cl-text);
  background:
    radial-gradient(circle at 15% 10%, rgba(109,143,255,.16), transparent 30%),
    radial-gradient(circle at 85% 12%, rgba(41,197,111,.10), transparent 24%),
    linear-gradient(180deg, #07101b 0%, #09111f 100%);
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  position: relative;
}

.cl-bg-orb{
  position: fixed;
  border-radius: 999px;
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
}

.cl-bg-orb-1{
  width: 260px;
  height: 260px;
  left: -70px;
  top: 110px;
  background: rgba(109,143,255,.14);
}

.cl-bg-orb-2{
  width: 220px;
  height: 220px;
  right: -40px;
  top: 140px;
  background: rgba(41,197,111,.10);
}

.cl-topbar{
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: calc(16px + env(safe-area-inset-top)) 18px 16px;
  background: rgba(7,16,27,.72);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.05);
}

.cl-brand{
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.cl-brand-logo{
  width: 46px;
  height: 46px;
  min-width: 46px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  font-weight: 900;
  background:
    linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.04)),
    linear-gradient(135deg, var(--cl-accent), #26365d);
  box-shadow: 0 10px 28px rgba(0,0,0,.25);
}

.cl-brand-title{
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: .01em;
}

.cl-brand-sub{
  font-size: .82rem;
  color: var(--cl-text-dim);
  margin-top: 2px;
}

.cl-auth-state{
  color: var(--cl-text-dim);
  font-size: .82rem;
  text-align: right;
  word-break: break-word;
}

.cl-main{
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 22px 12px 30px;
}

.cl-shell{
  width: min(100%, 1120px);
  margin: 0 auto;
}

.cl-surface{
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr);
  gap: 18px;
  align-items: stretch;
  min-height: calc(100dvh - 150px);
}

.cl-surface-left{
  padding: 18px 8px 18px 6px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
}

.cl-badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  max-width: 100%;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  color: var(--cl-text-soft);
  font-size: .82rem;
  font-weight: 700;
}

.cl-badge-dot{
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--cl-success);
  box-shadow: 0 0 0 5px rgba(41,197,111,.12);
}

.cl-title{
  margin: 0;
  font-size: clamp(2.1rem, 4vw, 3.6rem);
  line-height: .98;
  letter-spacing: -.05em;
  font-weight: 900;
  max-width: 11ch;
}

.cl-subtitle{
  margin: 0;
  max-width: 52ch;
  color: var(--cl-text-dim);
  font-size: 1rem;
  line-height: 1.6;
}

.cl-feature-list{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}

.cl-feature-card{
  padding: 16px;
  border-radius: 22px;
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.065);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

.cl-feature-card strong{
  display: block;
  font-size: .92rem;
  margin-bottom: 7px;
}

.cl-feature-card span{
  display: block;
  font-size: .84rem;
  line-height: 1.45;
  color: var(--cl-text-dim);
}

.cl-surface-right{
  display: flex;
  align-items: center;
  justify-content: center;
}

.cl-login-card{
  width: 100%;
  max-width: 520px;
  padding: 22px;
  border-radius: var(--cl-radius-xl);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025)),
    rgba(11,18,32,.78);
  border: 1px solid var(--cl-border);
  box-shadow: var(--cl-shadow);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.cl-login-head{
  margin-bottom: 18px;
}

.cl-login-kicker{
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .11em;
  color: var(--cl-text-dim);
  font-weight: 800;
  margin-bottom: 8px;
}

.cl-login-head h2{
  margin: 0;
  font-size: 1.65rem;
  line-height: 1;
  letter-spacing: -.03em;
  font-weight: 900;
}

.cl-login-head p{
  margin: 10px 0 0;
  color: var(--cl-text-dim);
  font-size: .93rem;
  line-height: 1.55;
}

.cl-form{
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cl-field{
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cl-field label,
.cl-picker-wrap > label{
  color: var(--cl-text-soft);
  font-size: .86rem;
  font-weight: 700;
}

.cl-field input{
  width: 100%;
  min-height: 58px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.045);
  color: #fff;
  border-radius: 18px;
  padding: 0 16px;
  outline: none;
  font-size: 1rem;
}

.cl-field input::placeholder{
  color: rgba(255,255,255,.35);
}

.cl-field input:focus{
  border-color: rgba(109,143,255,.7);
  box-shadow: 0 0 0 4px rgba(109,143,255,.12);
}

.cl-picker-wrap{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cl-profile-picker{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cl-profile-item{
  appearance: none;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.045);
  color: #fff;
  border-radius: 18px;
  min-height: 68px;
  padding: 14px 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  text-align: left;
}

.cl-profile-item:hover{
  background: rgba(255,255,255,.07);
}

.cl-profile-item-left{
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.cl-profile-item-left strong{
  font-size: .95rem;
}

.cl-profile-item-left span{
  margin-top: 4px;
  color: var(--cl-text-dim);
  font-size: .82rem;
  line-height: 1.35;
  word-break: break-word;
}

.cl-profile-item-right{
  flex: 0 0 auto;
  color: var(--cl-text-dim);
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .06em;
}

.cl-picker-empty{
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
  color: var(--cl-text-dim);
  font-size: .86rem;
}

.cl-picker-note{
  color: var(--cl-text-dim);
  font-size: .82rem;
  line-height: 1.4;
}

.cl-actions{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.cl-btn{
  appearance: none;
  border: 0;
  cursor: pointer;
  min-height: 54px;
  border-radius: 18px;
  padding: 0 16px;
  font-size: .94rem;
  font-weight: 800;
  color: #fff;
}

.cl-btn:disabled{
  opacity: .6;
  cursor: not-allowed;
}

.cl-btn-primary{
  background:
    linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.04)),
    linear-gradient(135deg, var(--cl-accent), #26365d);
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
}

.cl-btn-secondary{
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)),
    rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}

.cl-message{
  min-height: 22px;
  color: var(--cl-text-dim);
  font-size: .9rem;
  line-height: 1.4;
}

.cl-message.is-error{
  color: #ff9f9f;
}

.cl-footnote{
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.055);
  color: var(--cl-text-dim);
  font-size: .84rem;
  line-height: 1.5;
}

@media (max-width: 980px){
  .cl-surface{
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .cl-surface-left{
    justify-content: flex-start;
    padding: 4px 2px 0;
  }

  .cl-title{
    max-width: none;
  }
}

@media (max-width: 720px){
  .cl-feature-list{
    grid-template-columns: 1fr;
  }

  .cl-actions{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px){
  .cl-topbar{
    padding: calc(14px + env(safe-area-inset-top)) 14px 14px;
  }

  .cl-main{
    padding: 16px 10px 24px;
  }

  .cl-login-card{
    padding: 18px;
    border-radius: 28px;
  }

  .cl-title{
    font-size: 2rem;
  }

  .cl-subtitle{
    font-size: .94rem;
  }

  .cl-profile-item{
    align-items: flex-start;
    flex-direction: column;
  }

  .cl-profile-item-right{
    white-space: normal;
  }
}