/* certificates-page.css — Player-facing certificate/diploma page styles.
   Does NOT own: landing page styles, farm game styles, admin panel. */

.cert-page {
  background: var(--bg3);
  min-height: 100vh;
  padding: 40px 20px 80px;
}
.cert-page-inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.cert-page .section-label {
  display: inline-block;
  background: rgba(234,179,8,0.15);
  color: var(--accent);
  font-family: var(--font-heading);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 2px;
  padding: 6px 18px;
  border-radius: 20px;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.cert-page .section-title {
  font-family: var(--font-heading);
  font-size: clamp(28px, 5vw, 42px);
  color: #fff;
  text-transform: uppercase;
  line-height: 1.1;
  margin-bottom: 12px;
}
.cert-page .section-sub {
  color: rgba(255,255,255,0.7);
  font-size: 16px;
  max-width: 520px;
  margin: 0 auto 32px;
}

/* Certificate Preview */
.cert-preview-wrap { margin: 0 auto 40px; max-width: 520px; }
.cert-mockup-lg {
  background: #fff;
  border: 3px solid var(--fg);
  border-radius: 4px;
  padding: 8px;
}
.cert-mockup-lg .cert-inner {
  border: 2px solid var(--fg);
  padding: 32px 24px;
  text-align: center;
}
.cert-mockup-lg .cert-of {
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #888;
  margin-bottom: 4px;
}
.cert-mockup-lg .cert-title {
  font-family: var(--font-heading);
  font-size: 28px;
  color: var(--fg);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 16px;
}
.cert-mockup-lg .cert-this {
  color: #666;
  font-size: 14px;
  margin-bottom: 8px;
}
.cert-mockup-lg .cert-name {
  font-family: var(--font-heading);
  font-size: 22px;
  font-weight: 700;
  color: var(--fg);
  margin-bottom: 12px;
}
.cert-mockup-lg .cert-dash {
  border-top: 2px dashed #ccc;
  width: 80%;
  margin: 0 auto 12px;
}
.cert-mockup-lg .cert-desc {
  color: #555;
  font-size: 13px;
  line-height: 1.5;
  margin-bottom: 24px;
}
.cert-mockup-lg .cert-footer {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.cert-mockup-lg .cert-dean-line {
  width: 140px;
  border-top: 2px solid var(--fg);
  margin-bottom: 4px;
}
.cert-mockup-lg .cert-dean-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--fg);
}
.cert-mockup-lg .cert-seal img {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 3px solid var(--barn-red);
  object-fit: cover;
}

/* Requirements */
.cert-requirements {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 28px 24px;
  margin-bottom: 32px;
  text-align: left;
}
.req-heading {
  font-family: var(--font-heading);
  font-size: 20px;
  color: #fff;
  margin-bottom: 8px;
}
.req-sub { color: rgba(255,255,255,0.6); font-size: 14px; margin-bottom: 16px; }
.req-list { display: flex; flex-direction: column; gap: 10px; }
.req-item {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,0.85);
  font-size: 14px;
  padding: 8px 12px;
  background: rgba(255,255,255,0.04);
  border-radius: 8px;
}
.req-check { font-size: 18px; flex-shrink: 0; }
.req-item-sm { font-size: 13px; padding: 6px 10px; }

/* Apply Form */
.cert-apply {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 28px 24px;
  margin-bottom: 32px;
  text-align: left;
}
.apply-heading {
  font-family: var(--font-heading);
  font-size: 20px;
  color: #fff;
  margin-bottom: 16px;
}
.apply-form { display: flex; flex-direction: column; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label {
  color: rgba(255,255,255,0.7);
  font-size: 13px;
  font-weight: 600;
}
.form-input {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 8px;
  padding: 10px 14px;
  color: #fff;
  font-size: 15px;
  font-family: var(--font-body);
}
.form-input:focus {
  outline: none;
  border-color: var(--accent);
}
.form-input option { color: #1a1a2e; }
.btn-apply {
  background: var(--barn-red);
  color: #fff;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  font-family: var(--font-heading);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.2s;
}
.btn-apply:hover { background: #991b1b; }
.btn-apply:disabled { opacity: 0.5; cursor: not-allowed; }

/* Alerts */
.alert {
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 14px;
  margin-bottom: 12px;
}
.alert-ok { background: rgba(61,107,53,0.3); color: #90ee90; border: 1px solid rgba(61,107,53,0.5); }
.alert-err { background: rgba(185,28,28,0.3); color: #fca5a5; border: 1px solid rgba(185,28,28,0.5); }

/* My Certificates */
.cert-my {
  text-align: left;
}
.my-heading {
  font-family: var(--font-heading);
  font-size: 20px;
  color: #fff;
  margin-bottom: 16px;
}
.my-certs-list { display: flex; flex-direction: column; gap: 16px; }
.my-cert-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 20px;
}
.my-cert-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  color: #fff;
  font-size: 15px;
}
.status-badge {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 12px;
}
.st-pending { background: rgba(234,179,8,0.2); color: #eab308; }
.st-issued { background: rgba(61,107,53,0.3); color: #90ee90; }
.st-rejected { background: rgba(185,28,28,0.3); color: #fca5a5; }
.cert-id { color: var(--accent); font-size: 13px; margin-bottom: 8px; }
.rejection-note { color: #fca5a5; font-size: 13px; margin-bottom: 8px; font-style: italic; }
.my-cert-checklist { margin-top: 8px; }
.my-cert-date { color: rgba(255,255,255,0.4); font-size: 12px; margin-top: 10px; }
.empty-state { color: rgba(255,255,255,0.5); font-size: 14px; text-align: center; }
