/* ── UPLOAD PAGE ── */
.page{max-width:620px;margin:0 auto;padding:4rem 2rem 6rem;}
.page-header{text-align:center;margin-bottom:2.5rem;opacity:0;animation:up 0.45s 0.05s both;}
.page-header h1{font-size:1.9rem;font-weight:700;letter-spacing:-0.8px;color:var(--ink);margin-bottom:0.5rem;}
.page-header h1 em{font-style:normal;color:var(--blue);}
.page-header p{font-size:0.92rem;color:var(--ink2);line-height:1.6;}

.upload-zone{background:var(--white);border:2px dashed rgba(37,99,235,0.28);border-radius:14px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:border-color 0.2s,background 0.2s;position:relative;opacity:0;animation:up 0.45s 0.15s both;box-shadow:0 1px 4px rgba(15,23,42,0.06);}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--blue);background:var(--blue-soft);}
.uz-icon{width:52px;height:52px;background:var(--blue-soft);border:1.5px solid var(--blue-border);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;font-size:1.4rem;transition:transform 0.2s;}
.upload-zone.dragover .uz-icon{transform:scale(1.1);}
.uz-title{font-size:1rem;font-weight:600;color:var(--ink);margin-bottom:0.4rem;}
.uz-sub{font-size:0.82rem;color:var(--ink2);margin-bottom:1.4rem;}
.uz-btn{display:inline-block;font-size:0.83rem;font-weight:600;background:var(--blue);color:#fff;padding:0.55rem 1.4rem;border-radius:6px;transition:background 0.15s;box-shadow:0 2px 8px rgba(37,99,235,0.22);}
.uz-btn:hover{background:var(--blue2);}
.uz-formats{font-size:0.72rem;color:var(--ink2);margin-top:1.2rem;}
#fileInput{position:absolute;inset:0;opacity:0;cursor:pointer;}

.file-selected{display:none;background:var(--white);border:1px solid var(--border);border-radius:14px;padding:1.2rem 1.5rem;align-items:center;gap:1rem;}
.file-selected.show{display:flex;animation:up 0.3s both;}
.fs-icon{width:40px;height:40px;flex-shrink:0;background:#FEF2F2;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;}
.fs-icon.doc{background:#EFF6FF;}
.fs-info{flex:1;min-width:0;}
.fs-name{font-size:0.88rem;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.fs-size{font-size:0.75rem;color:var(--ink3);margin-top:0.15rem;}
.fs-remove{width:28px;height:28px;flex-shrink:0;border:1px solid var(--border);border-radius:6px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink3);font-size:0.9rem;transition:background 0.15s,color 0.15s;}
.fs-remove:hover{background:var(--red-soft);color:var(--red);border-color:transparent;}

.field-wrap{margin-top:1.2rem;opacity:0;animation:up 0.45s 0.25s both;}
.field-label{display:block;font-size:0.82rem;font-weight:600;color:var(--ink);margin-bottom:0.5rem;}
.field-label span{color:var(--ink2);font-weight:400;}
.field-input{width:100%;font-family:'Inter',sans-serif;font-size:0.9rem;color:var(--ink);background:var(--white);border:1.5px solid rgba(15,23,42,0.14);border-radius:8px;padding:0.75rem 1rem;outline:none;transition:border-color 0.15s,box-shadow 0.15s;}
.field-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,0.08);}
.field-input::placeholder{color:var(--ink3);}

.checklist{margin-top:1.2rem;background:var(--white);border:1.5px solid rgba(15,23,42,0.1);border-radius:12px;overflow:hidden;opacity:0;animation:up 0.45s 0.35s both;box-shadow:0 1px 4px rgba(15,23,42,0.05);}
.cl-header{padding:1rem 1.2rem;border-bottom:1.5px solid rgba(15,23,42,0.08);display:flex;align-items:center;justify-content:space-between;background:var(--bg);}
.cl-title{font-size:0.82rem;font-weight:700;color:var(--ink);}
.cl-sub{font-size:0.75rem;color:var(--ink2);}
.cl-item{display:flex;align-items:center;gap:0.85rem;padding:0.85rem 1.2rem;border-bottom:1px solid rgba(15,23,42,0.07);transition:background 0.15s;cursor:default;}
.cl-item:last-child{border-bottom:none;}
.cl-item:hover{background:transparent;}
.cl-check{width:18px;height:18px;flex-shrink:0;border:1.5px solid var(--blue);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background 0.15s,border-color 0.15s;font-size:0.65rem;color:#fff;background:var(--blue);}
.cl-check.checked{background:var(--blue);border-color:var(--blue);color:#fff;}
.cl-item-title{font-size:0.83rem;font-weight:600;color:var(--ink);}
.cl-item-sub{font-size:0.75rem;color:var(--ink2);margin-top:0.1rem;}

.submit-wrap{margin-top:1.5rem;opacity:0;animation:up 0.45s 0.45s both;}
.submit-btn{display:flex;align-items:center;justify-content:center;gap:0.5rem;width:100%;font-family:'Inter',sans-serif;font-size:0.95rem;font-weight:600;background:var(--blue);color:#fff;border:none;border-radius:8px;padding:0.9rem;cursor:pointer;transition:background 0.15s,transform 0.15s,box-shadow 0.15s;}
.submit-btn:hover:not(:disabled){background:var(--blue2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,0.22);}
.submit-btn:disabled{opacity:0.55;cursor:not-allowed;}
.submit-note{font-size:0.75rem;color:var(--ink2);text-align:center;margin-top:0.75rem;}

.loading-state{display:none;text-align:center;padding:3rem 2rem;background:var(--white);border:1px solid var(--border);border-radius:14px;margin-top:1.5rem;}
.loading-state.show{display:block;}
.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;margin:0 auto 1.2rem;animation:spin 0.7s linear infinite;}
.loading-title{font-size:0.95rem;font-weight:600;color:var(--ink);margin-bottom:0.4rem;}
.loading-steps{display:flex;flex-direction:column;gap:0.5rem;margin-top:1.2rem;text-align:left;}
.ls-row{display:flex;align-items:center;gap:0.7rem;font-size:0.8rem;color:var(--ink3);padding:0.5rem 0.75rem;border-radius:6px;transition:background 0.2s,color 0.2s;}
.ls-row.active{background:var(--blue-soft);color:var(--blue);}
.ls-row.done{color:var(--green);}
.ls-dot{width:7px;height:7px;border-radius:50%;background:var(--border2);flex-shrink:0;transition:background 0.2s;}
.ls-row.active .ls-dot{background:var(--blue);animation:pulse 1s infinite;}
.ls-row.done .ls-dot{background:var(--green);}
.loading-note{margin-top:1.2rem;font-size:0.75rem;color:var(--ink3);text-align:center;}

.trust{display:flex;align-items:center;justify-content:center;gap:2rem;margin-top:2rem;opacity:0;animation:up 0.45s 0.55s both;}
.trust-item{display:flex;align-items:center;gap:0.4rem;font-size:0.75rem;color:var(--ink2);font-weight:500;}
.trust-item svg{color:var(--green);}

@media(max-width:500px){.trust{flex-direction:column;gap:0.75rem;}}

/* ── Scan limit modal ── */
.sl-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(10, 12, 20, 0.55);
  backdrop-filter: blur(4px);
  z-index: 9000;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}
.sl-backdrop.open {
  display: flex;
  animation: sl-fade 0.2s ease both;
}
@keyframes sl-fade {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.sl-box {
  background: #fff;
  border-radius: 18px;
  padding: 2.25rem 2rem 1.75rem;
  max-width: 400px;
  width: 100%;
  box-shadow: 0 32px 80px rgba(0,0,0,0.28), 0 4px 16px rgba(0,0,0,0.1);
  position: relative;
  animation: sl-up 0.25s cubic-bezier(0.34,1.2,0.64,1) both;
  text-align: center;
}
@keyframes sl-up {
  from { opacity: 0; transform: translateY(20px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.sl-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 28px;
  height: 28px;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
  font-size: 0.75rem;
  color: var(--ink3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}
.sl-close:hover { background: var(--bg); color: var(--ink); }

.sl-icon-wrap {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: var(--blue-soft);
  border: 1px solid var(--blue-border);
  color: var(--blue);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
}
.sl-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.3px;
  margin-bottom: 0.5rem;
}
.sl-sub {
  font-size: 0.82rem;
  color: var(--ink2);
  line-height: 1.6;
  margin-bottom: 1.25rem;
}
.sl-features {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 1.4rem;
  text-align: left;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.9rem 1rem;
}
.sl-feat {
  font-size: 0.79rem;
  color: var(--ink2);
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  line-height: 1.45;
}
.sl-feat strong { color: var(--ink); font-weight: 600; }
.sl-feat-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 6px;
  background: var(--blue-soft);
  border: 1px solid var(--blue-border);
  color: var(--blue);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}

.sl-price-row {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.65rem;
  margin-bottom: 1.1rem;
}
.sl-price {
  font-size: 2rem;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -1px;
  line-height: 1;
}
.sl-price sup { font-size: 0.9rem; font-weight: 700; vertical-align: super; }
.sl-price em  { font-size: 1.1rem; font-style: normal; font-weight: 700; }
.sl-price-note {
  font-size: 0.72rem;
  color: var(--ink3);
  line-height: 1.4;
  text-align: left;
  max-width: 130px;
}
.sl-cta {
  display: block;
  background: var(--blue);
  color: #fff;
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 10px;
  padding: 0.8rem 1.25rem;
  transition: background 0.15s, transform 0.15s, box-shadow 0.15s;
  margin-bottom: 0.85rem;
}
.sl-cta:hover {
  background: var(--blue2);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(37,99,235,0.22);
}
.sl-dismiss {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
}
.sl-dismiss button {
  font-family: 'Inter', sans-serif;
  font-size: 0.78rem;
  color: var(--ink3);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.25rem 0.5rem;
  transition: color 0.15s;
}
.sl-dismiss button:first-child {
  color: var(--blue);
  font-weight: 500;
}
.sl-dismiss button:hover { color: var(--ink); }
