:root{
  --text: #ffffff;
  --muted: rgba(255,255,255,0.75);
  --line: rgba(255,255,255,0.22);
  --line2: rgba(255,255,255,0.14);
  --chip: rgba(0,0,0,0.35);
  --inputBg: rgba(0,0,0,0.30);
  --inputBg2: rgba(0,0,0,0.18);
  --btn: #ff4d57;
  --btn2: #ff6b73;
}

*{ box-sizing: border-box; }
html, body { height: 100%; margin: 0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color: var(--text); }

body{
  background: #000 url("./bg.JPG") center/cover no-repeat fixed;
  overflow-x: hidden;
}

/* Overlay gelap nipis supaya text jelas tapi background masih nampak */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.28);
  pointer-events: none;
}

.page{
  position: relative;
  z-index: 1;
  min-height: 100%;
  padding: 26px 28px 40px;
}

.header{
  text-align: center;
  margin-top: 10px;
  margin-bottom: 26px; /* bagi turun bawah sikit (tak rapat sangat) */
}

.header h1{
  margin: 0;
  font-size: clamp(30px, 4vw, 54px);
  letter-spacing: 1px;
  text-shadow: 0 6px 18px rgba(0,0,0,0.55);
}

.grid{
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 40px;
  align-items: start;
}

@media (max-width: 980px){
  .grid{ grid-template-columns: 1fr; gap: 28px; }
}

.left, .right{
  /* TIADA background block besar — ikut permintaan awak (background nampak jelas) */
  padding: 0;
}

h2{
  margin: 0 0 6px;
  font-size: 26px;
  text-shadow: 0 4px 14px rgba(0,0,0,0.55);
}

.hint{
  margin: 0 0 18px;
  color: var(--muted);
  text-shadow: 0 4px 14px rgba(0,0,0,0.55);
}

h3{
  margin: 18px 0 10px;
  font-size: 20px;
  text-shadow: 0 4px 14px rgba(0,0,0,0.55);
}

.field{
  margin: 12px 0;
}

label{
  display: block;
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 6px;
  text-shadow: 0 3px 10px rgba(0,0,0,0.55);
}

input[type="text"]{
  width: 100%;
  height: 44px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid var(--line);
  color: var(--text);
  outline: none;
  background: var(--inputBg);
  backdrop-filter: none;
}

input[type="text"]::placeholder{ color: rgba(255,255,255,0.55); }

.row2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 520px){
  .row2{ grid-template-columns: 1fr; }
}

.checkbox{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
  color: var(--muted);
  text-shadow: 0 3px 10px rgba(0,0,0,0.55);
}

.checkbox input{ transform: translateY(1px); }

.uploadBlock{
  margin: 16px 0 18px;
  padding: 14px 14px 10px;
  border: 1px solid var(--line2);
  border-radius: 16px;

  /* Block nipis supaya kemas tapi bukan blur/gelap tebal */
  background: rgba(0,0,0,0.10);
}

.uploadHead{
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 10px;
}

.uploadTitle{
  font-weight: 800;
  letter-spacing: 0.2px;
  text-shadow: 0 4px 14px rgba(0,0,0,0.55);
}

.uploadSub{
  font-size: 12px;
  color: rgba(255,255,255,0.70);
  margin-top: 3px;
  text-shadow: 0 3px 10px rgba(0,0,0,0.55);
}

.uploadActions{
  display: flex;
  align-items: center;
  gap: 8px;
}

.btnGhost{
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(0,0,0,0.22);
  color: var(--text);
  cursor: pointer;
}

.btnX{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255,77,87,0.55);
  background: rgba(0,0,0,0.22);
  color: #ffb3b8;
  cursor: pointer;
}

.fileInput{
  display: none;
}

.dropZone{
  border: 1px dashed rgba(255,255,255,0.30);
  border-radius: 14px;
  padding: 12px 12px;
  background: rgba(0,0,0,0.14);
  cursor: pointer;
  user-select: none;
}

.dropZone:focus{
  outline: 2px solid rgba(255,255,255,0.30);
  outline-offset: 2px;
}

.dzTitle{
  font-weight: 700;
  font-size: 13px;
}
.dzNote{
  font-size: 12px;
  color: rgba(255,255,255,0.70);
  margin-top: 4px;
}

.optRow{
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin: 10px 2px 6px;
}

.miniCheck{
  display: inline-flex;
  gap: 8px;
  align-items: center;
  color: rgba(255,255,255,0.80);
  font-size: 13px;
}

.note{
  margin: 6px 0 14px;
  font-size: 12px;
  color: rgba(255,255,255,0.78);
  line-height: 1.35;
  text-shadow: 0 3px 10px rgba(0,0,0,0.55);
}

.fileList{
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.fileItem{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(0,0,0,0.18);
}

.fileName{
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}

.fileMeta{
  font-size: 12px;
  color: rgba(255,255,255,0.68);
}

.fileRight{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.btnRemove{
  width: 30px;
  height: 30px;
  border-radius: 10px;
  border: 1px solid rgba(255,77,87,0.55);
  background: rgba(0,0,0,0.22);
  color: #ffb3b8;
  cursor: pointer;
}

.bottomBar{
  margin-top: 18px;
  display: grid;
  justify-items: center;
  gap: 10px;
}

.btnPrimary{
  min-width: 260px;
  height: 48px;
  padding: 0 22px;
  border-radius: 14px;
  border: none;
  background: linear-gradient(90deg, var(--btn), var(--btn2));
  color: #fff;
  font-weight: 900;
  letter-spacing: 0.6px;
  cursor: pointer;
  box-shadow: 0 10px 26px rgba(0,0,0,0.35);
}

.uiMsg{
  font-size: 13px;
  color: rgba(255,255,255,0.85);
  text-shadow: 0 3px 10px rgba(0,0,0,0.55);
}
