:root{
  --bg:#eef3f8;
  --bg-2:#f8fafc;
  --panel:#ffffff;
  --panel-soft:#f7f9fc;
  --ink:#0f172a;
  --ink-2:#203044;
  --muted:#64748b;
  --line:#d6dee9;
  --line-strong:#b9c6d6;
  --primary:#114f8f;
  --primary-2:#0b355f;
  --primary-soft:#e8f1fb;
  --accent:#18a0a9;
  --good:#0d7a4d;
  --warn:#9a6200;
  --bad:#b42318;
  --shadow:0 24px 80px rgba(15,23,42,.14);
  --radius:22px;
}
*{box-sizing:border-box}
html,body{min-height:100%}
body{
  margin:0;
  font-family:"Aptos","Aptos Display","Segoe UI Variable Text","Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 20% 12%,rgba(17,79,143,.15),transparent 30%),
    radial-gradient(circle at 82% 82%,rgba(24,160,169,.13),transparent 28%),
    linear-gradient(135deg,var(--bg-2),var(--bg));
}
button,input{font:inherit}
button{transition:background .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}
button:hover:not(:disabled){transform:translateY(-1px)}
button:disabled{cursor:not-allowed;opacity:.48}
.app-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:28px;
}
.auth-view,.workspace-view{width:100%}
.auth-view{display:grid;place-items:center}
.workspace-view{display:none}
.is-signed-in .auth-view{display:none}
.is-signed-in .workspace-view{display:block}
.login-card{
  width:min(420px,100%);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(214,222,233,.95);
  border-radius:28px;
  box-shadow:var(--shadow);
  padding:36px 34px 32px;
  backdrop-filter:blur(14px);
}
.brand-lockup{display:flex;justify-content:center;margin-bottom:28px}
.uone-logo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:156px;
  height:58px;
  border-radius:18px;
  background:linear-gradient(135deg,var(--primary-2),var(--primary));
  color:#fff;
  box-shadow:0 14px 32px rgba(17,79,143,.24);
  letter-spacing:-.035em;
  overflow:hidden;
}
.uone-logo.small{min-width:116px;height:44px;border-radius:14px;box-shadow:none}
.logo-u{font-size:30px;font-weight:820;line-height:1;padding:0 1px 0 0}
.logo-one{font-size:30px;font-weight:760;line-height:1;color:#d8f7ff}
.uone-logo.small .logo-u,.uone-logo.small .logo-one{font-size:23px}
.screen-reader-title{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.credential-stack{display:grid;gap:16px}
.field{display:grid;gap:8px}
.field span{font-size:13px;font-weight:780;color:var(--ink-2);letter-spacing:.01em}
.field input{
  width:100%;
  height:48px;
  border:1px solid var(--line-strong);
  border-radius:14px;
  background:#fff;
  color:var(--ink);
  padding:0 14px;
  outline:none;
  font-size:15px;
  font-weight:600;
}
.field input::placeholder{color:#94a3b8;font-weight:500}
.field input:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(17,79,143,.12)}
.primary-btn,.secondary-btn{
  min-height:44px;
  border-radius:13px;
  font-size:14px;
  font-weight:720;
  cursor:pointer;
  white-space:nowrap;
}
.primary-btn{
  border:0;
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff;
  box-shadow:0 12px 26px rgba(17,79,143,.18);
}
.primary-btn:hover:not(:disabled){box-shadow:0 14px 30px rgba(17,79,143,.25)}
.secondary-btn{
  border:1px solid var(--line-strong);
  background:#fff;
  color:var(--ink-2);
}
.secondary-btn:hover:not(:disabled){border-color:var(--primary);background:var(--primary-soft)}
.secondary-btn.danger{color:var(--bad);border-color:#efb9b2;background:#fff8f7}
.secondary-btn.danger:hover:not(:disabled){background:#fff1ef;border-color:#e58b81}
.login-btn{width:100%;height:48px;margin-top:20px;font-size:15px}
.login-status{min-height:22px;margin-top:14px;text-align:center;font-size:13px;font-weight:700;color:var(--muted)}
.login-status.good{color:var(--good)}
.login-status.warn{color:var(--warn)}
.login-status.bad{color:var(--bad)}
.workspace-view{
  max-width:1120px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(214,222,233,.95);
  border-radius:30px;
  box-shadow:var(--shadow);
  padding:22px;
  backdrop-filter:blur(14px);
}
.workspace-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:8px 8px 22px;
  border-bottom:1px solid var(--line);
}
.workspace-brand{display:flex;align-items:center;gap:15px}
.workspace-kicker{margin:0 0 3px;color:var(--accent);font-size:12px;font-weight:760;letter-spacing:.12em;text-transform:uppercase}
.workspace-header h2{margin:0;font-size:28px;line-height:1.05;letter-spacing:-.035em;color:var(--ink)}
.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.quota-pill,.badge,.step-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  font-size:12px;
  font-weight:720;
  min-height:30px;
  padding:6px 10px;
}
.quota-pill{background:var(--primary-soft);color:var(--primary-2);border:1px solid #cae0f7}
.badge.locked{background:#fff1ef;color:var(--bad);border:1px solid #f0bbb5}
.badge.unlocked{background:#ecfff5;color:var(--good);border:1px solid #a8e6c3}
.signout-btn{min-height:34px;padding:7px 11px;font-size:12px}
.workspace-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:16px;margin-top:18px}
.panel{
  background:var(--panel-soft);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
}
.panel-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.panel h3{margin:0;font-size:18px;letter-spacing:-.025em;color:var(--ink-2)}
.step-pill{background:#fff;color:var(--muted);border:1px solid var(--line);font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.file-zone{
  display:grid;
  place-items:center;
  gap:6px;
  min-height:156px;
  text-align:center;
  border:1.6px dashed #9eb0c5;
  background:#fff;
  border-radius:18px;
  padding:20px;
  cursor:pointer;
}
.file-zone:hover{border-color:var(--primary);background:#fafdff}
.file-zone input{display:none}
.file-icon{
  display:grid;
  place-items:center;
  width:38px;
  height:38px;
  border-radius:13px;
  background:var(--primary-soft);
  color:var(--primary);
  font-size:24px;
  font-weight:760;
}
.file-title{font-size:17px;font-weight:760;color:var(--ink)}
.file-subtitle{max-width:100%;font-size:13px;font-weight:650;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.check-row{display:flex;align-items:flex-start;gap:9px;margin:14px 0 0;color:var(--muted);font-size:13px;font-weight:650;line-height:1.35}
.check-row input{margin-top:2px;accent-color:var(--primary)}
.control-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.control-grid .primary-btn,.control-grid .secondary-btn{width:100%;height:52px;font-size:15px}
.progress-panel{margin-top:16px;background:#fff}
.progress-wrap{margin-top:4px}
.progress-meta{display:flex;justify-content:space-between;gap:10px;color:var(--ink-2);font-size:13px;font-weight:720;margin-bottom:10px}
.progress-track{height:12px;border-radius:999px;background:#e4ebf4;overflow:hidden;border:1px solid #dce4ee}
.progress-bar{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--accent));transition:width .25s ease}
.status-box{
  margin-top:14px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fbfdff;
  min-height:52px;
  padding:13px 14px;
  color:var(--muted);
  font-size:13px;
  font-weight:650;
  line-height:1.45;
  white-space:pre-wrap;
}
.status-box.good{color:var(--good);border-color:#a8e6c3;background:#f2fff8}
.status-box.warn{color:var(--warn);border-color:#ffd894;background:#fff9eb}
.status-box.bad{color:var(--bad);border-color:#f3b1ab;background:#fff5f4}
.locked-section{opacity:1}
.locked-section:before{display:none}
@media (max-width:860px){
  .app-shell{padding:18px}
  .workspace-view{padding:16px;border-radius:24px}
  .workspace-header{align-items:flex-start;flex-direction:column}
  .header-actions{justify-content:flex-start}
  .workspace-grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .login-card{padding:30px 22px 26px;border-radius:24px}
  .uone-logo{min-width:142px;height:54px}
  .workspace-brand{align-items:flex-start;flex-direction:column;gap:10px}
  .workspace-header h2{font-size:24px}
  .header-actions{width:100%}
  .quota-pill,.badge,.signout-btn{flex:1}
  .control-grid{grid-template-columns:1fr}
}

/* UONE landing upgrade: two-part secure access screen */
.auth-view{
  min-height:calc(100vh - 56px);
  display:grid;
  place-items:center;
}
.landing-card{
  width:min(1040px,100%);
  min-height:560px;
  display:grid;
  grid-template-columns:minmax(0,1.12fr) minmax(360px,.88fr);
  overflow:hidden;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(214,222,233,.96);
  border-radius:34px;
  box-shadow:0 30px 90px rgba(15,23,42,.16);
  backdrop-filter:blur(16px);
}
.brand-panel{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:34px;
  padding:52px;
  color:#fff;
  background:
    radial-gradient(circle at 22% 18%,rgba(74,195,204,.34),transparent 32%),
    linear-gradient(135deg,#071f38 0%,#0b355f 48%,#114f8f 100%);
  isolation:isolate;
}
.brand-panel:before{
  content:"";
  position:absolute;
  inset:22px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:26px;
  pointer-events:none;
  z-index:-1;
}
.brand-panel:after{
  content:"";
  position:absolute;
  right:-90px;
  bottom:-90px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:rgba(24,160,169,.22);
  filter:blur(2px);
  z-index:-1;
}
.mark-wrap{display:flex;align-items:center;gap:16px}
.uone-mark{
  display:grid;
  place-items:center;
  width:64px;
  height:64px;
  border-radius:20px;
  background:rgba(255,255,255,.96);
  color:#0b355f;
  font-size:36px;
  line-height:1;
  font-weight:820;
  letter-spacing:-.08em;
  box-shadow:0 18px 36px rgba(0,0,0,.18);
}
.uone-wordmark{
  font-size:24px;
  line-height:1;
  font-weight:800;
  letter-spacing:.08em;
  color:#f8fbff;
}
.brand-copy{max-width:520px}
.eyebrow{
  margin:0 0 16px;
  color:#9ee7ef;
  font-size:12px;
  font-weight:760;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.brand-copy h1{
  margin:0;
  max-width:560px;
  color:#fff;
  font-size:clamp(37px,4.8vw,60px);
  line-height:.96;
  letter-spacing:-.035em;
  font-weight:780;
}
.brand-lead{
  max-width:500px;
  margin:22px 0 0;
  color:rgba(255,255,255,.86);
  font-size:18px;
  line-height:1.55;
  font-weight:650;
  letter-spacing:-.01em;
}
.brand-note{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  margin:34px 0 0;
  padding:8px 13px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.88);
  font-size:13px;
  font-weight:780;
}
.landing-card .login-card{
  width:100%;
  min-height:560px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:#fff;
  border:0;
  border-radius:0;
  box-shadow:none;
  padding:54px 46px;
  backdrop-filter:none;
}
.login-topline{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.login-kicker{
  color:var(--accent);
  font-size:12px;
  font-weight:780;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.secure-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:var(--good);
  box-shadow:0 0 0 6px rgba(13,122,77,.11);
}
.landing-card .login-card h2{
  margin:0 0 28px;
  color:var(--ink);
  font-size:31px;
  line-height:1.08;
  letter-spacing:-.035em;
  font-weight:780;
}
.landing-card .field span{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#4a5a6e}
.landing-card .field input{height:52px;border-radius:15px;font-size:15px;background:#fbfdff}
.landing-card .login-btn{height:52px;border-radius:15px;margin-top:22px;font-size:15px;letter-spacing:.01em}
.landing-card .login-status{text-align:left;margin-top:13px}
@media (max-width:920px){
  .landing-card{grid-template-columns:1fr;min-height:0;border-radius:28px}
  .brand-panel{min-height:380px;padding:40px}
  .landing-card .login-card{min-height:0;padding:38px 40px 36px}
  .brand-copy h1{font-size:clamp(36px,9vw,54px)}
}
@media (max-width:560px){
  .app-shell{padding:14px}
  .landing-card{border-radius:24px}
  .brand-panel{min-height:340px;padding:30px 24px}
  .brand-panel:before{inset:14px;border-radius:20px}
  .mark-wrap{gap:12px}
  .uone-mark{width:54px;height:54px;border-radius:17px;font-size:31px}
  .uone-wordmark{font-size:20px}
  .brand-lead{font-size:16px;line-height:1.48}
  .brand-note{margin-top:24px}
  .landing-card .login-card{padding:30px 24px 28px}
  .landing-card .login-card h2{font-size:27px;margin-bottom:22px}
}
