* { box-sizing: border-box; }
:root {
  --brand: #195d3f;
  --brand-2: #12472f;
  --brand-soft: #e8f2ed;
  --bg: #f5f7f6;
  --border: #dfe8e2;
  --text: #1f2937;
}
body {
  margin: 0;
  font-family: Tahoma, Arial, Helvetica, sans-serif;
  color: var(--text);
  background: var(--bg);
}
.wrap {
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px;
}
.hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  margin-bottom: 24px;
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);
  color: #fff;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  box-shadow: 0 10px 28px rgba(25,93,63,.16);
  padding: 30px;
}
.hero-text {
  max-width: 760px;
  margin: 0;
  color: rgba(255,255,255,.92);
}
.card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.05);
}
.badge {
  display: inline-block;
  padding: 6px 10px;
  background: rgba(255,255,255,.14);
  color: #fff;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
}
h1, h2, h3 { color: var(--brand); margin-top: 0; }
.hero h1 { color: #fff; }
h1 { font-size: 38px; margin-top: 12px; }
.grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 24px;
}
.card { padding: 24px; }
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
label { display: flex; flex-direction: column; gap: 8px; font-size: 14px; font-weight: 700; }
label span { color: #374151; }
.full { grid-column: 1 / -1; }
.top-space { margin-top: 12px; }
input, select, textarea, button { font: inherit; }
input, select, textarea {
  width: 100%;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid #cad7d0;
  background: #fff;
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(25,93,63,.12);
}
.field-help {
  font-size: 12px;
  font-weight: 400;
  color: #6b7280;
  line-height: 1.45;
}
.checks {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}
.checks label {
  flex-direction: row;
  font-weight: 400;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fbfcfb;
  line-height: 1.5;
}
.checks input {
  width: 18px;
  height: 18px;
  accent-color: var(--brand);
  margin-top: 2px;
  flex: 0 0 auto;
}
button {
  border: 0;
  padding: 12px 18px;
  border-radius: 12px;
  background: var(--brand);
  color: #fff;
  cursor: pointer;
  font-weight: 700;
}
button:hover { background: var(--brand-2); }
button.secondary {
  background: #eef4f0;
  color: var(--brand);
  border: 1px solid #cfe0d6;
}
.actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 20px;
}
.reason-list {
  margin-top: 12px;
  border: 1px dashed #cfe0d6;
  border-radius: 14px;
  padding: 12px;
  background: #fbfcfb;
}
.reason-list.empty { color: #6b7280; }
.reason-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: start;
  padding: 8px 0;
  border-bottom: 1px solid #e5ece8;
}
.reason-item:last-child { border-bottom: 0; }
.remove-reason {
  background: #fff1f2;
  color: #9f1239;
  border: 1px solid #fecdd3;
  padding: 6px 10px;
  border-radius: 10px;
}
.preview-box {
  white-space: pre-wrap;
  min-height: 720px;
  background: #f8faf9;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px;
  line-height: 1.6;
}
.message {
  margin-top: 16px;
  padding: 12px 14px;
  border-radius: 12px;
}
.message.success { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }
.message.error { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
.hidden { display: none; }
.is-hidden { display: none; }
.helper-note {
  margin: 12px 0 0;
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--brand-soft);
  color: var(--brand);
}
@media (max-width: 980px) {
  .grid, .form-grid { grid-template-columns: 1fr; }
  h1 { font-size: 30px; }
}


.court-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(260px, .8fr);
  gap: 16px;
  align-items: start;
}
.court-fields {
  display: grid;
  gap: 16px;
}
.court-note {
  padding: 16px 18px;
  border-radius: 16px;
  background: var(--brand-soft);
  border: 1px solid #cfe0d6;
  color: var(--brand);
  line-height: 1.55;
}
.court-note strong {
  display: block;
  margin-bottom: 8px;
  font-size: 15px;
}
.court-note p {
  margin: 0;
  font-size: 14px;
}
@media (max-width: 980px) {
  .court-layout { grid-template-columns: 1fr; }
}

.download-box {
  margin-top: 16px;
  padding: 16px 18px;
  border: 1px solid #cfe0d6;
  border-radius: 14px;
  background: #f8fbf9;
}
.download-box p { margin: 8px 0 12px; }
.download-link {
  display: inline-block;
  text-decoration: none;
  background: #195d3f;
  color: #fff;
  padding: 12px 16px;
  border-radius: 12px;
  font-weight: 700;
}
.download-link:hover { background: #12472f; }
