* { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: "Segoe UI", system-ui, sans-serif;
  background: linear-gradient(135deg, #7c3aed 0%, #db2777 60%, #f59e0b 100%);
  min-height: 100vh; color: #1f2937;
}
.wrap { max-width: 760px; margin: 0 auto; padding: 24px 16px 60px; }
.card { background: #fff; border-radius: 22px; padding: 26px; box-shadow: 0 14px 40px rgba(0,0,0,.22); }
h1 { color: #fff; text-align: center; font-size: 30px; margin: 16px 0 4px; text-shadow: 2px 2px 0 rgba(0,0,0,.15); }
.sub { color: #fff; text-align: center; opacity: .92; margin-bottom: 22px; }

/* Login */
.tiles { display: flex; gap: 18px; justify-content: center; flex-wrap: wrap; }
.tile {
  background: #f5f3ff; border: 3px solid #ede9fe; border-radius: 20px;
  width: 150px; padding: 22px 12px; text-align: center; cursor: pointer; transition: .12s;
}
.tile:hover { transform: translateY(-4px); border-color: #7c3aed; }
.tile.sel { border-color: #db2777; background: #fdf2f8; }
.tile .emoji { font-size: 56px; display: block; }
.tile .nm { font-weight: 700; font-size: 19px; margin-top: 8px; color: #4c1d95; }
.pinbox { margin-top: 22px; text-align: center; display: none; }
.pinbox.show { display: block; }
.pindots { font-size: 30px; letter-spacing: 8px; height: 38px; color: #7c3aed; }
.pad { display: grid; grid-template-columns: repeat(3, 78px); gap: 12px; justify-content: center; margin: 14px auto; }
.key { font-size: 26px; padding: 16px 0; background: #ede9fe; border: none; border-radius: 16px; cursor: pointer; font-weight: 700; color: #4c1d95; }
.key:hover { background: #ddd6fe; }
.key.wide { grid-column: span 1; }
.err { color: #dc2626; font-weight: 600; min-height: 22px; margin-top: 6px; }

/* App */
.topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.topbar .who { color: #fff; font-weight: 700; font-size: 18px; }
.btn { background: #7c3aed; color: #fff; border: none; border-radius: 14px; padding: 12px 18px; font-size: 16px; font-weight: 700; cursor: pointer; }
.btn:hover { background: #6d28d9; }
.btn.pink { background: #db2777; } .btn.pink:hover { background: #be185d; }
.btn.gray { background: #6b7280; } .btn.small { padding: 8px 12px; font-size: 14px; }
.btn:disabled { opacity: .5; cursor: default; }
.field { margin: 12px 0; }
.field label { display: block; font-weight: 700; margin-bottom: 6px; color: #4c1d95; }
.field input[type=text], .field select { width: 100%; padding: 12px; border: 2px solid #ede9fe; border-radius: 12px; font-size: 16px; }
.drop {
  border: 3px dashed #c4b5fd; border-radius: 18px; padding: 34px; text-align: center;
  color: #6d28d9; cursor: pointer; background: #faf5ff; font-size: 18px; font-weight: 600;
}
.styles { display: flex; gap: 10px; flex-wrap: wrap; }
.styopt { border: 3px solid #ede9fe; border-radius: 14px; padding: 10px 14px; cursor: pointer; font-weight: 700; color: #4c1d95; }
.styopt.sel { border-color: #db2777; background: #fdf2f8; }
.job { border: 2px solid #f3e8ff; border-radius: 16px; padding: 14px; margin: 12px 0; }
.job h3 { color: #4c1d95; font-size: 18px; }
.job .meta { color: #6b7280; font-size: 13px; margin: 2px 0 8px; }
.bar { background: #ede9fe; border-radius: 10px; height: 16px; overflow: hidden; }
.bar > div { background: linear-gradient(90deg,#7c3aed,#db2777); height: 100%; width: 0; transition: width .4s; }
.statusmsg { font-size: 14px; color: #6d28d9; margin-top: 6px; font-weight: 600; }
.badge { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 700; }
.badge.ok { background: #d1fae5; color: #065f46; } .badge.wait { background: #fef3c7; color: #92400e; }
.badge.err { background: #fee2e2; color: #991b1b; } .badge.appr { background: #dbeafe; color: #1e40af; }
video { width: 100%; border-radius: 14px; margin-top: 10px; background: #000; }
.hidden { display: none; }
