@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=Crimson+Text:ital,wght@0,400;0,600;1,400&family=IM+Fell+English:ital@0;1&display=swap');

:root {
  --parchment: #c8ddb0;
  --parchment-dark: #5a9e3a;
  --parchment-light: #deecc8;
  --ink-dark: #081508;
  --ink-brown: #0f2808;
  --ink-med: #1a4818;
  --gold: #2e7d32;
  --gold-bright: #43a047;
  --gold-light: #76c442;
  --gold-dark: #246b27;
  --olive: #1a3a1a;
  --red-seal: #8b1a1a;
  --shadow: rgba(8,21,8,0.5);
  --header-bg: #0a2a0a;
  --border: #2a5e1e;
}

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

body {
  background: #081508;
  background-image:
    radial-gradient(ellipse at 20% 20%, #0a1f08 0%, transparent 60%),
    radial-gradient(ellipse at 80% 80%, #050d05 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%232e7d32' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 40px 20px 60px;
  font-family: 'IM Fell English', 'Crimson Text', serif;
  color: var(--ink-dark);
}

.btn-back {
  position: fixed;
  top: 18px;
  left: 18px;
  z-index: 999;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--gold-light);
  background: linear-gradient(135deg, #0a2a0a, #0a2a00);
  border: 2px solid var(--gold);
  border-radius: 2px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.5);
  transition: all 0.2s;
}

.btn-back:hover {
  background: linear-gradient(135deg, #0a2a10, #0a2a00);
  box-shadow: 0 4px 16px rgba(0,0,0,0.6), 0 0 10px rgba(67,160,71,0.25);
}

/* ── Cadre ornemente facon Registre ── */
.frame-outer {
  position: relative;
  background: var(--parchment);
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23noise)' opacity='0.08'/%3E%3C/svg%3E"),
    linear-gradient(135deg, #b0e090 0%, #d4a830 30%, #e8c870 50%, #c99a20 70%, #e0c060 100%);
  border: 6px solid var(--gold);
  border-radius: 4px;
  box-shadow:
    0 0 0 2px var(--ink-dark),
    0 0 0 10px var(--gold),
    0 0 0 12px var(--ink-dark),
    0 30px 80px rgba(0,0,0,0.8),
    inset 0 0 60px rgba(180,120,20,0.3);
  max-width: 1240px;
  width: 100%;
  padding: 36px 40px 32px;
  overflow: visible;
}

.frame-outer::before,
.frame-outer::after {
  content: '\2726';
  position: absolute;
  font-size: 24px;
  color: var(--gold);
  text-shadow: 0 0 8px var(--gold-light);
}
.frame-outer::before { top: 10px; left: 14px; }
.frame-outer::after  { bottom: 10px; right: 14px; }

.corner-tr,
.corner-bl {
  position: absolute;
  font-size: 24px;
  color: var(--gold);
  text-shadow: 0 0 8px var(--gold-light);
  z-index: 2;
}
.corner-tr { top: 10px; right: 14px; }
.corner-bl { bottom: 10px; left: 14px; }

.shuriken {
  position: absolute;
  opacity: 0.8;
  filter: drop-shadow(2px 2px 4px rgba(0,0,0,0.5));
  z-index: 2;
}
.shuriken-tr { top: -18px; right: -18px; transform: rotate(15deg); }
.shuriken-bl { bottom: -18px; left: -18px; transform: rotate(-15deg); }

.watermark-confidential {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-30deg);
  font-family: 'Cinzel', serif;
  font-weight: 900;
  font-size: 72px;
  color: rgba(139, 26, 26, 0.10);
  letter-spacing: 0.18em;
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}

/* ── Entete document (identique au Registre) ── */
.doc-header {
  position: relative;
  z-index: 1;
  text-align: center;
  margin-bottom: 26px;
}

.logo-svg {
  width: 54px;
  height: 54px;
  margin: 0 auto 6px;
  display: block;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.4));
}

.kanji-line {
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--ink-brown);
  margin-bottom: 6px;
  opacity: 0.85;
}

.page-title {
  font-family: 'Cinzel', serif;
  font-weight: 900;
  font-size: clamp(22px, 3.4vw, 34px);
  color: var(--ink-dark);
  letter-spacing: 0.14em;
  text-shadow: 1px 1px 0 rgba(255,220,100,0.5), 0 2px 6px rgba(0,0,0,0.2);
  line-height: 1.2;
  margin-bottom: 8px;
  text-transform: uppercase;
}

.sub-title {
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--ink-med);
  margin-top: 4px;
}

.header-divider {
  width: 60%;
  max-width: 480px;
  height: 2px;
  margin: 10px auto 0;
  background: linear-gradient(90deg, transparent, var(--gold), var(--ink-dark), var(--gold), transparent);
}

/* ── Corps academy ── */
.academy-shell {
  position: relative;
  z-index: 1;
  padding: 22px;
  border: 3px solid var(--border);
  border-radius: 2px;
  background: rgba(232, 213, 163, 0.55);
  box-shadow: inset 0 0 20px rgba(100,70,10,0.2), 0 4px 16px rgba(0,0,0,0.3);
}

.state-card {
  position: relative;
  z-index: 1;
  padding: 26px;
  border: 3px solid var(--border);
  border-radius: 2px;
  background: rgba(232, 213, 163, 0.55);
  box-shadow: inset 0 0 20px rgba(100,70,10,0.2), 0 4px 16px rgba(0,0,0,0.3);
  text-align: center;
  font-family: 'IM Fell English', serif;
  font-size: 18px;
  color: var(--ink-brown);
}

.hero-strip {
  display: grid;
  grid-template-columns: 1.3fr 320px;
  gap: 18px;
  margin-bottom: 20px;
  align-items: start;
}

.section-kicker {
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold-dark);
  margin-bottom: 6px;
}

.section-copy {
  color: var(--ink-brown);
  font-family: 'IM Fell English', serif;
  font-size: 15px;
  line-height: 1.6;
}

.timer-card {
  padding: 16px 18px;
  border: 2px solid var(--gold);
  background: linear-gradient(180deg, #0a1f0a 0%, #0f2808 100%);
  color: var(--gold-light);
  border-radius: 4px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,220,80,0.18);
}

.timer-label {
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  opacity: 0.9;
}

.timer-value {
  margin-top: 8px;
  font-family: 'Cinzel', serif;
  font-size: 34px;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-shadow: 0 0 10px rgba(67,160,71,0.45);
}

.timer-meta {
  margin-top: 8px;
  font-family: 'IM Fell English', serif;
  font-size: 14px;
  line-height: 1.45;
  color: rgba(244, 228, 174, 0.88);
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.form-group.full {
  grid-column: 1 / -1;
}

.form-label {
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--ink-brown);
  text-shadow: 0 1px 0 rgba(255,220,100,0.35);
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: 11px 12px;
  font-family: 'IM Fell English', 'Crimson Text', serif;
  font-size: 16px;
  color: var(--ink-dark);
  background: rgba(255, 248, 218, 0.85);
  border: 1.5px solid var(--border);
  border-radius: 2px;
  outline: none;
  transition: background 0.15s, box-shadow 0.15s, border-color 0.15s;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  background: rgba(255, 240, 180, 0.95);
  border-color: var(--gold);
  box-shadow: inset 0 0 0 1px var(--gold), 0 0 12px rgba(67,160,71,0.3);
}

.form-input[readonly] {
  background: rgba(30,100,40,0.18);
  color: var(--ink-brown);
  cursor: default;
}

.form-textarea {
  min-height: 160px;
  resize: vertical;
  line-height: 1.55;
}

.academy-actions,
.result-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 22px;
}

.btn-primary,
.btn-secondary {
  font-family: 'Cinzel', serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 11px 24px;
  border: 2px solid var(--gold);
  border-radius: 2px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
  overflow: hidden;
}

.btn-primary::before,
.btn-secondary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,220,80,0.15), transparent);
  opacity: 0;
  transition: opacity 0.2s;
}
.btn-primary:hover::before,
.btn-secondary:hover::before { opacity: 1; }

.btn-primary {
  background: linear-gradient(135deg, #0a2a0a, #0a2a00);
  color: var(--gold-light);
  box-shadow: 0 4px 12px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,220,80,0.2);
  text-shadow: 0 0 6px rgba(67,160,71,0.5);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #0a2a10, #0a2a00);
  box-shadow: 0 6px 20px rgba(0,0,0,0.5), 0 0 15px rgba(67,160,71,0.3);
  transform: translateY(-1px);
}
.btn-primary:active { transform: translateY(0); }

.btn-secondary {
  background: linear-gradient(135deg, rgba(232,213,163,0.9), rgba(200,168,80,0.7));
  color: var(--ink-dark);
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.btn-secondary:hover {
  background: linear-gradient(135deg, rgba(245,230,180,0.95), rgba(220,188,100,0.85));
  transform: translateY(-1px);
}

/* ── Resultat PA terminee ── */
.result-shell {
  position: relative;
  z-index: 1;
  margin-top: 24px;
  padding: 22px;
  border: 3px solid var(--border);
  border-radius: 2px;
  background: rgba(232, 213, 163, 0.55);
  box-shadow: inset 0 0 20px rgba(100,70,10,0.2), 0 4px 16px rgba(0,0,0,0.3);
  display: none;
}

.result-shell.visible {
  display: block;
}

.result-title {
  font-family: 'Cinzel', serif;
  font-weight: 900;
  font-size: 20px;
  color: var(--ink-dark);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.result-copy {
  color: var(--ink-brown);
  font-family: 'IM Fell English', serif;
  font-size: 16px;
  line-height: 1.6;
}

.result-meta {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.result-pill {
  padding: 10px 12px;
  border: 1.5px solid var(--border);
  background: rgba(255, 248, 218, 0.7);
  border-radius: 2px;
}

.result-pill strong {
  display: block;
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: var(--gold-dark);
  margin-bottom: 4px;
}

/* ── Responsive ── */
@media (max-width: 980px) {
  .hero-strip {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  body { padding: 56px 10px 50px; }

  .frame-outer {
    padding: 24px 18px 22px;
  }

  .form-grid,
  .result-meta {
    grid-template-columns: 1fr;
  }

  .academy-actions,
  .result-actions {
    flex-direction: column;
  }

  .btn-primary,
  .btn-secondary { width: 100%; }

  .shuriken-tr,
  .shuriken-bl { display: none; }

  .watermark-confidential { font-size: 44px; }
}
