#maison-bleue-game {
all: initial;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
color: #000000;
background-color: #ffffff;
line-height: 1.6;
font-size: 18px;
padding: 20px;
max-width: 1200px;
margin: 0 auto;
box-sizing: border-box;
}
#maison-bleue-game *,
#maison-bleue-game *::before,
#maison-bleue-game *::after {
box-sizing: border-box;
color: inherit;
background: transparent;
border: none;
margin: 0;
padding: 0;
font: inherit;
line-height: inherit;
}
#maison-bleue-game h1 { font-size: 2.5rem; font-weight: bold; margin: 0 0 1rem 0; color: #1a1a1a; text-align: center; }
#maison-bleue-game h2 { font-size: 1.8rem; font-weight: bold; margin: 2rem 0 1rem 0; color: #1a1a1a; border-bottom: 2px solid #333; padding-bottom: 0.5rem; }
#maison-bleue-game h3 { font-size: 1.4rem; font-weight: bold; margin: 1.5rem 0 0.5rem 0; color: #1a1a1a; }
#maison-bleue-game .section { margin: 2rem 0; padding: 1.5rem; border: 2px solid #ddd; border-radius: 8px; background-color: #ffffff; }
#maison-bleue-game input, #maison-bleue-game select, #maison-bleue-game textarea, #maison-bleue-game button {
display: block; width: 100%; min-height: 44px; padding: 12px 16px; margin: 8px 0 16px 0; border: 2px solid #333; border-radius: 4px; font-size: 18px; background-color: #ffffff; color: #000000;
}
#maison-bleue-game button { background-color: #0066cc; color: #ffffff; font-weight: bold; cursor: pointer; border: 2px solid #0066cc; transition: all 0.2s ease; }
#maison-bleue-game button:hover { background-color: #0052a3; border-color: #0052a3; }
#maison-bleue-game button:focus { outline: 3px solid #ff6600; outline-offset: 2px; }
#maison-bleue-game button:disabled { background-color: #cccccc; border-color: #cccccc; color: #666666; cursor: not-allowed; }
#maison-bleue-game input:focus, #maison-bleue-game select:focus, #maison-bleue-game textarea:focus { outline: 3px solid #ff6600; outline-offset: 2px; border-color: #0066cc; }
#maison-bleue-game .button-inline { display: inline-block; width: auto; margin: 0 8px 8px 0; padding: 8px 16px; min-height: 40px; }
#maison-bleue-game .message { padding: 12px 16px; margin: 16px 0; border-radius: 4px; font-weight: bold; }
#maison-bleue-game .message.success { background-color: #d4edda; color: #155724; border: 2px solid #c3e6cb; }
#maison-bleue-game .message.error { background-color: #f8d7da; color: #721c24; border: 2px solid #f5c6cb; }
#maison-bleue-game .message.info { background-color: #d1ecf1; color: #0c5460; border: 2px solid #bee5eb; }
#maison-bleue-game .grid { display: grid; gap: 16px; grid-template-columns: 1fr; }
@media (min-width: 768px) { #maison-bleue-game .grid.two-cols { grid-template-columns: 1fr 1fr; } }
#maison-bleue-game .enigme { padding: 16px; margin: 16px 0; border: 2px solid #333; border-radius: 8px; background-color: #f8f9fa; }
#maison-bleue-game .enigme.solved { background-color: #d4edda; border-color: #28a745; }
#maison-bleue-game .enigme-title { font-size: 1.2rem; font-weight: bold; margin-bottom: 8px; }
#maison-bleue-game .enigme-text { margin: 12px 0; line-height: 1.8; }
#maison-bleue-game .map-container { margin: 16px 0; border: 2px solid #333; border-radius: 8px; overflow: hidden; }
#maison-bleue-game .map-container iframe { width: 100%; height: 300px; border: none; }
#maison-bleue-game table { width: 100%; border-collapse: collapse; margin: 16px 0; }
#maison-bleue-game th, #maison-bleue-game td { padding: 12px; text-align: left; border: 1px solid #333; }
#maison-bleue-game th { background-color: #f1f1f1; font-weight: bold; }
#maison-bleue-game tr:nth-child(even) { background-color: #f8f9fa; }
#maison-bleue-game #journal { height: 200px; resize: vertical; font-family: monospace; font-size: 14px; }
#maison-bleue-game .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
#maison-bleue-game .game-status { text-align: center; padding: 16px; margin: 16px 0; background-color: #e9ecef; border-radius: 8px; font-weight: bold; }
#maison-bleue-game .progress-bar { width: 100%; height: 20px; background-color: #e9ecef; border-radius: 10px; overflow: hidden; margin: 8px 0; }
#maison-bleue-game .progress-fill { height: 100%; background-color: #28a745; transition: width 0.3s ease; }
