/* login page styles */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --font:'Geist',-apple-system,sans-serif;
  --white:#ffffff;
  --s100:#f5f5f7;
  --s200:#e8e8ed;
  --s300:#d1d1d6;
  --s400:#aeaeb2;
  --s500:#8e8e93;
  --s600:#636366;
  --s700:#3a3a3c;
  --s800:#2c2c2e;
  --s900:#1c1c1e;
  --green:rgba(74,222,128,.85);
  --red:rgba(248,113,113,.85);
  --blue:rgba(96,165,250,.85);
}

html,body{
  min-height:100vh;
  background:#000;
  font-family:var(--font);
  color:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ── Background ── */
.bg{position:fixed;inset:0;z-index:0;pointer-events:none}

.orb{
  position:absolute;border-radius:50%;
  pointer-events:none;
}
.orb-a{
  width:600px;height:600px;
  background:radial-gradient(ellipse,rgba(255,255,255,.045) 0%,transparent 65%);
  top:-200px;left:-150px;
  filter:blur(80px);
  animation:floatA 20s ease-in-out infinite alternate;
}
.orb-b{
  width:500px;height:500px;
  background:radial-gradient(ellipse,rgba(150,150,180,.035) 0%,transparent 65%);
  bottom:-150px;right:-100px;
  filter:blur(80px);
  animation:floatB 16s ease-in-out infinite alternate;
}
.orb-c{
  width:300px;height:300px;
  background:radial-gradient(ellipse,rgba(74,222,128,.025) 0%,transparent 70%);
  top:40%;left:40%;
  filter:blur(60px);
  animation:floatA 24s ease-in-out infinite alternate-reverse;
}

@keyframes floatA{0%{transform:translate(0,0)}100%{transform:translate(50px,35px)}}
@keyframes floatB{0%{transform:translate(0,0)}100%{transform:translate(-35px,-25px)}}

.bg-grid{
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:56px 56px;
}

/* ── Page Layout ── */
.page{
  position:relative;z-index:1;
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 720px;
}

/* ── Left Panel ── */
.left-panel{
  display:flex;
  flex-direction:column;
  padding:36px 40px;
  border-right:1px solid rgba(255,255,255,.05);
  position:relative;
  overflow:hidden;
}

/* top brand in left */
.brand{
  display:inline-flex;align-items:center;gap:10px;
  text-decoration:none;
  flex-shrink:0;
}
.brand-icon{
  width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,#fff 0%,#9a9a9e 100%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 1px rgba(255,255,255,.2),0 4px 16px rgba(0,0,0,.5);
  flex-shrink:0;
}
.brand-icon svg{width:19px;height:19px}
.brand-name{font-size:17px;font-weight:700;color:var(--white);letter-spacing:-.02em}

/* preview cards area */
.preview-area{
  flex:1;
  display:flex;align-items:center;justify-content:center;
  padding:32px 0;
}
.preview-stack{
  width:100%;
  max-width:400px;
  display:flex;flex-direction:column;gap:10px;
}

.preview-card{
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:18px 20px;
  backdrop-filter:blur(16px);
  position:relative;
  overflow:hidden;
  transition:all .25s;
}
.preview-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent);
}
.preview-card:hover{
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.13);
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(0,0,0,.3);
}

.card-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}

.card-icon{
  width:34px;height:34px;border-radius:9px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:17px;flex-shrink:0;
}
.card-title{font-size:13px;font-weight:600;color:var(--white)}
.card-sub{font-size:11px;color:var(--s500);margin-top:2px}

/* KPI grid inside card */
.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.metric-block{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  border-radius:8px;padding:10px 12px;
}
.metric-val{font-size:20px;font-weight:800;color:var(--white);letter-spacing:-.04em;line-height:1}
.metric-lbl{font-size:10px;color:var(--s500);margin-top:3px}

/* Shimmer lines for AI card */
.skel-line{
  height:7px;border-radius:4px;
  background:linear-gradient(90deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.05) 100%);
  background-size:300% 100%;
  animation:shimmer 2s linear infinite;
  margin-bottom:8px;
}
.skel-line:last-child{margin-bottom:0}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* Progress bars in card */
.prog-bars{display:flex;flex-direction:column;gap:9px}
.prog-row{display:flex;align-items:center;gap:10px}
.prog-lbl{font-size:11px;color:var(--s400);width:70px;flex-shrink:0}
.prog-track{flex:1;height:4px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden}
.prog-fill{height:100%;border-radius:99px;transition:width 1.2s cubic-bezier(.16,1,.3,1)}
.prog-pct{font-size:11px;color:var(--s400);width:32px;text-align:right;flex-shrink:0}

/* Live indicator */
.live-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px rgba(74,222,128,.6);
  animation:pulse 2.5s ease-in-out infinite;
  display:inline-block;margin-right:5px;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

.left-footer{
  font-size:11px;color:var(--s700);flex-shrink:0;
  display:flex;align-items:center;gap:6px;
}

/* ── Right Panel — Form ── */
.right-panel{
  display:flex;align-items:center;justify-content:center;
  padding:40px 48px;
  position:relative;
}
.right-panel::before{
  content:'';
  position:absolute;top:0;left:0;bottom:0;width:1px;
  /* already handled by left border-right */
}

.form-wrap{width:100%;max-width:360px}

/* Back link */
.back-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;color:var(--s500);
  text-decoration:none;
  transition:color .15s;
  margin-bottom:44px;
}
.back-link:hover{color:var(--s200)}
.back-link svg{flex-shrink:0}

/* Form header */
.form-eyebrow{
  font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--s600);
  margin-bottom:8px;
}
.form-title{
  font-size:34px;font-weight:900;color:var(--white);
  letter-spacing:-.045em;margin-bottom:8px;line-height:1.1;
}
.form-sub{font-size:14px;color:var(--s500);margin-bottom:36px;line-height:1.5}

/* Divider */
.divider{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.div-line{flex:1;height:1px;background:rgba(255,255,255,.07)}
.div-txt{font-size:12px;color:var(--s600);white-space:nowrap}

/* Error banner */
.error-banner{
  display:none;
  padding:11px 14px;border-radius:10px;
  background:rgba(248,113,113,.07);
  border:1px solid rgba(248,113,113,.2);
  color:#f87171;font-size:13px;
  margin-bottom:16px;
  align-items:center;gap:9px;
  animation:slideDown .2s ease;
}
.error-banner.show{display:flex}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* Success banner */
.success-banner{
  display:none;
  padding:11px 14px;border-radius:10px;
  background:rgba(74,222,128,.07);
  border:1px solid rgba(74,222,128,.2);
  color:rgba(74,222,128,.9);font-size:13px;
  margin-bottom:16px;
  align-items:center;gap:9px;
  animation:slideDown .2s ease;
}
.success-banner.show{display:flex}

/* Field */
.field-group{margin-bottom:14px}
.field-label{
  display:block;
  font-size:11px;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;color:var(--s500);
  margin-bottom:7px;
}
.field-wrap{position:relative}
.field-input{
  width:100%;
  padding:13px 16px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.09);
  border-radius:12px;
  font-size:14px;color:var(--white);
  font-family:var(--font);
  outline:none;
  transition:border-color .2s,background .2s,box-shadow .2s;
}
.field-input::placeholder{color:rgba(255,255,255,.2)}
.field-input:hover:not(:focus){border-color:rgba(255,255,255,.15)}
.field-input:focus{
  border-color:rgba(255,255,255,.3);
  background:rgba(255,255,255,.07);
  box-shadow:0 0 0 3px rgba(255,255,255,.05);
}
.field-input.error-field{border-color:rgba(248,113,113,.4)}

/* Password toggle */
.pw-wrap .field-input{padding-right:48px}
.eye-btn{
  position:absolute;right:14px;top:50%;
  transform:translateY(-50%);
  background:none;border:none;cursor:pointer;
  color:var(--s600);display:flex;align-items:center;
  padding:4px;border-radius:6px;
  transition:color .15s,background .15s;
}
.eye-btn:hover{color:var(--s300);background:rgba(255,255,255,.06)}

/* Extras row */
.extras{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.check-label{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:var(--s400);cursor:pointer;
  user-select:none;
}
.check-label input[type="checkbox"]{
  width:15px;height:15px;
  accent-color:#fff;cursor:pointer;
  flex-shrink:0;
}
.forgot-btn{
  font-size:13px;font-weight:500;color:var(--s500);
  background:none;border:none;cursor:pointer;
  font-family:var(--font);
  transition:color .15s;padding:0;
}
.forgot-btn:hover{color:var(--white)}

/* Submit */
.submit-btn{
  width:100%;padding:14px 20px;
  border-radius:12px;
  font-size:15px;font-weight:700;
  background:var(--white);color:#000;
  border:none;cursor:pointer;
  font-family:var(--font);
  transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:9px;
  letter-spacing:-.01em;
  position:relative;overflow:hidden;
}
.submit-btn::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 0%,rgba(0,0,0,.06) 100%);
  opacity:0;transition:opacity .2s;
}
.submit-btn:hover{
  background:var(--s100);
  transform:translateY(-1px);
  box-shadow:0 10px 36px rgba(255,255,255,.14);
}
.submit-btn:hover::after{opacity:1}
.submit-btn:active{transform:translateY(0)}
.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* Spinner inside btn */
.btn-spinner{
  display:none;
  width:17px;height:17px;
  border:2.5px solid rgba(0,0,0,.15);
  border-top-color:#000;
  border-radius:50%;
  animation:spin .6s linear infinite;
  flex-shrink:0;
}
@keyframes spin{to{transform:rotate(360deg)}}

.submit-btn.loading .btn-text{display:none}
.submit-btn.loading .btn-spinner{display:block}
.submit-btn.loading{pointer-events:none}

/* Footer */
.form-footer{
  margin-top:28px;text-align:center;
  font-size:13px;color:var(--s600);line-height:1.6;
}
.form-footer a{color:var(--s200);font-weight:600;text-decoration:none}
.form-footer a:hover{color:var(--white)}

/* ── Responsive ── */
@media(max-width:960px){
  .page{grid-template-columns:1fr}
  .left-panel{display:none}
  .right-panel{
    min-height:100vh;
    padding:32px 24px;
    align-items:flex-start;
    padding-top:48px;
  }
  .form-wrap{max-width:420px;margin:0 auto;width:100%}

  /* Show compact brand on mobile since left panel is hidden */
  .mobile-brand{
    display:flex !important;
    align-items:center;gap:10px;
    margin-bottom:40px;
    text-decoration:none;
  }
}

@media(min-width:961px){
  .mobile-brand{display:none}
}

/* Input autofill style fix */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus{
  -webkit-text-fill-color:#fff;
  -webkit-box-shadow:0 0 0 1000px rgba(40,40,42,.8) inset;
  transition:background-color 5000s;
}
