:root {
  --bg: #f8f6f2;
  --paper: #ffffff;
  --paper-warm: #fbf8f3;
  --ink: #15120f;
  --ink-soft: #4f4943;
  --muted: #6f6961;
  --faint: #9a9288;
  --line: #e0dbd4;
  --line-strong: #cfc5bb;
  --purple: #6b3fa0;
  --purple-dark: #553080;
  --purple-soft: #efe7fb;
  --purple-wash: #f6f1ff;
  --gold: #b79b68;
  --success: #5f7f45;
  --coral: #a65f4a;
  --radius: 10px;
  --radius-sm: 8px;
  --font: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
}

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

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

.brand-bar,
.site-footer {
  background: #080808;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
}

.brand-bar { min-height: 80px; margin-bottom: 68px; }
.site-footer { min-height: 172px; margin-top: 80px; flex-direction: column; gap: 14px; }

.brand-signature {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 500;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -0.04em;
  color: #fff;
}

.brand-signature span {
  display: inline-block;
  margin-left: 4px;
  font-family: var(--font);
  font-style: normal;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .28em;
  text-transform: uppercase;
}

.footer-links { color: #7b7772; font-size: 13px; }

.wrap {
  max-width: 840px;
  margin: 0 auto;
  padding: 0 24px 34px;
}

#hub-view,
#submit-view {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 30px;
  box-shadow: none;
}

.hdr {
  margin-bottom: 30px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
}

.hdr h1 {
  font-family: var(--serif);
  font-size: clamp(34px, 5vw, 48px);
  font-weight: 600;
  line-height: .98;
  letter-spacing: -0.035em;
  color: var(--ink);
}

.hdr h1 span { color: var(--purple); font-style: italic; }
.hdr p { color: var(--muted); font-size: 15px; margin-top: 12px; }

.section-label {
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  font-weight: 600;
  color: var(--purple);
  margin: 28px 0 16px;
}

.section-label::after {
  content: "";
  height: 1px;
  background: var(--line);
  flex: 1;
}

.grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (max-width: 620px) { .grid { grid-template-columns: 1fr; } .brand-bar { margin-bottom: 36px; } #hub-view, #submit-view { padding: 22px; } }

.tile {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  cursor: pointer;
  transition: border-color .15s, transform .15s, background .15s;
  text-align: left;
  font-family: var(--font);
  color: var(--ink);
  width: 100%;
}

.tile:hover { border-color: var(--purple); transform: translateY(-1px); background: var(--paper-warm); }
.tile-top { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }

.tile-ic {
  width: 38px; height: 38px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  font-size: 19px; flex-shrink: 0;
}

.tile-title { font-weight: 700; font-size: 15px; color: var(--ink); }
.tile-desc { font-size: 13px; color: var(--muted); line-height: 1.5; }
.tile.locked { cursor: default; opacity: .62; border-style: dashed; background: #faf8f5; }
.tile.locked:hover { transform: none; border-color: var(--line); }
.tile.locked .tile-ic { background: #ece7df; color: var(--faint); }
.lock-tag { font-size: 12px; color: var(--faint); margin-top: 8px; display: flex; align-items: center; gap: 5px; }

.ic-purple,
.ic-teal,
.ic-coral,
.ic-blue { background: var(--purple-soft); color: var(--purple); }
.ic-teal { background: #f0eadf; color: #7a633b; }
.ic-coral { background: #f5e8e1; color: #9b5f4a; }
.ic-blue { background: #eee7fa; color: var(--purple); }

.cta {
  background: var(--purple);
  border: 1px solid var(--purple);
  border-radius: var(--radius-sm);
  padding: 17px 20px;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer; width: 100%;
  font-family: var(--font); color: #fff;
  transition: background .15s, transform .15s;
  margin-top: 4px;
}

.cta:hover { background: var(--purple-dark); transform: translateY(-1px); }
.cta-left { display: flex; align-items: center; gap: 12px; }
.cta-ic {
  width: 38px; height: 38px; border-radius: 999px; background: rgba(255,255,255,.14);
  display: flex; align-items: center; justify-content: center; font-size: 19px;
}
.cta-title { font-weight: 700; font-size: 15px; }
.cta-sub { font-size: 13px; color: rgba(255,255,255,.78); }
.cta-arrow { color: #fff; font-size:18px; }

.back {
  background: none; border: none; color: var(--purple);
  font-family: var(--font); font-size: 14px; font-weight: 600; cursor: pointer;
  display: flex; align-items: center; gap: 6px; margin-bottom: 22px; padding: 0;
}
.back:hover { color: var(--purple-dark); }

.hint {
  background: var(--purple-wash);
  border: 1px solid #d4bff2;
  border-radius: var(--radius-sm);
  padding: 13px 15px; font-size: 13px; color: var(--purple);
  display: flex; gap: 9px; align-items: flex-start; margin-bottom: 24px;
  text-decoration: none;
}
.hint:hover { border-color: var(--purple); }

.field-label { display: block; font-size: 14px; font-weight: 700; margin-bottom: 10px; color: var(--ink); }
.question-label { margin-top: 8px; }

.bucket {
  display: flex; align-items: center; gap: 12px;
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px 16px; cursor: pointer; margin-bottom: 10px;
  transition: border-color .15s, background .15s;
  background: #fff;
}
.bucket:hover { border-color: var(--purple); background: var(--paper-warm); }
.bucket:has(input:checked) { border-color: var(--purple); background: var(--purple-wash); }
.bucket input { accent-color: var(--purple); width: 17px; height: 17px; }
.bucket-name { font-weight: 700; font-size: 14px; }
.bucket-when { font-size: 12px; padding: 4px 10px; border-radius: 999px; margin-left: auto; }
.when-teal,
.when-coral,
.when-blue { background: var(--purple-soft); color: var(--purple); }
.when-teal { background: #f0eadf; color: #7a633b; }
.when-coral { background: #f5e8e1; color: #9b5f4a; }

textarea {
  width: 100%; min-height: 118px; margin: 0 0 22px;
  background: #fff; border: 1px solid var(--line);
  border-radius: var(--radius-sm); padding: 14px 15px;
  color: var(--ink); font-family: var(--font); font-size: 14px; resize: vertical;
}
textarea::placeholder { color: var(--faint); }
textarea:focus { outline: none; border-color: var(--purple); box-shadow: 0 0 0 3px rgba(107,63,160,.12); }

.submit-btn {
  background: var(--purple); color: #fff;
  border: 1px solid var(--purple); border-radius: var(--radius-sm);
  padding: 13px 24px; font-family: var(--font); font-size: 14px; font-weight: 700;
  cursor: pointer; transition: background .15s, transform .15s;
}
.submit-btn:hover { background: var(--purple-dark); transform: translateY(-1px); }
.submit-btn:disabled { opacity: .6; cursor: wait; }
.form-status { min-height: 22px; margin-top: 12px; color: var(--muted); font-size: 13px; }
.form-status.is-success { color: var(--success); }
.form-status.is-error { color: var(--coral); }
.hidden { display: none; }
