/* ===== MODE PAVILLON ===== */
#flag-section { display: none; }
#flag-section.active { display: block; }
.flag-layout { display: flex; gap: 36px; align-items: flex-start; }
.flag-left { flex-shrink: 0; }
.flag-grid-wrap {
  background: var(--card); border: 3px solid var(--border);
  border-radius: 12px; padding: 8px;
  box-shadow: 0 6px 28px var(--shadow), 0 0 0 1px var(--border2); width: 320px;
}
.flag-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 4px; width: 100%; aspect-ratio: 1; overflow: hidden; border-radius: 8px; position: relative; }
.flag-cell { background: var(--wrong); overflow: hidden; position: relative; transition: all 0.5s ease; aspect-ratio: 1; }
.flag-cell.flag-masked::after {
  content: '?'; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: var(--text3); font-weight: 700;
  background: var(--wrong); z-index: 2;
}
.flag-cell.flag-masked img { visibility: hidden; }
.flag-cell img { width: 400%; height: 400%; object-fit: cover; position: absolute; display: block; }
.flag-cell[data-r="0"][data-c="0"] img{top:0;left:0}
.flag-cell[data-r="0"][data-c="1"] img{top:0;left:-100%}
.flag-cell[data-r="0"][data-c="2"] img{top:0;left:-200%}
.flag-cell[data-r="0"][data-c="3"] img{top:0;left:-300%}
.flag-cell[data-r="1"][data-c="0"] img{top:-100%;left:0}
.flag-cell[data-r="1"][data-c="1"] img{top:-100%;left:-100%}
.flag-cell[data-r="1"][data-c="2"] img{top:-100%;left:-200%}
.flag-cell[data-r="1"][data-c="3"] img{top:-100%;left:-300%}
.flag-cell[data-r="2"][data-c="0"] img{top:-200%;left:0}
.flag-cell[data-r="2"][data-c="1"] img{top:-200%;left:-100%}
.flag-cell[data-r="2"][data-c="2"] img{top:-200%;left:-200%}
.flag-cell[data-r="2"][data-c="3"] img{top:-200%;left:-300%}
.flag-cell[data-r="3"][data-c="0"] img{top:-300%;left:0}
.flag-cell[data-r="3"][data-c="1"] img{top:-300%;left:-100%}
.flag-cell[data-r="3"][data-c="2"] img{top:-300%;left:-200%}
.flag-cell[data-r="3"][data-c="3"] img{top:-300%;left:-300%}
.flag-progress { text-align: center; margin-top: 10px; font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text3); }
.flag-progress span { color: var(--gold); font-weight: 700; }
.flag-right { flex: 1; min-width: 0; }
.flag-hint { background: var(--card); border: 2px solid var(--border2); border-radius: 12px; padding: 14px 18px; margin-bottom: 14px; font-size: 0.78rem; letter-spacing: 0.1em; color: var(--text2); text-transform: uppercase; text-align: center; }
.flag-hint strong { color: var(--gold-l); font-size: 0.9rem; display: block; margin-bottom: 4px; }
#flag-guesses { display: flex; flex-direction: column; gap: 6px; }

