| | * { |
| | margin: 0; |
| | padding: 0; |
| | box-sizing: border-box; |
| | } |
| |
|
| | body { |
| | font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; |
| | background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); |
| | min-height: 100vh; |
| | color: #333; |
| | } |
| |
|
| | .container { |
| | max-width: 1200px; |
| | margin: 0 auto; |
| | padding: 20px; |
| | } |
| |
|
| | header { |
| | text-align: center; |
| | margin-bottom: 30px; |
| | color: white; |
| | } |
| |
|
| | h1 { |
| | font-size: 2.5em; |
| | margin-bottom: 10px; |
| | text-shadow: 2px 2px 4px rgba(0,0,0,0.3); |
| | } |
| |
|
| | .subtitle { |
| | font-size: 1.2em; |
| | opacity: 0.9; |
| | margin-bottom: 30px; |
| | } |
| |
|
| | .mode-selector { |
| | display: flex; |
| | justify-content: center; |
| | gap: 20px; |
| | margin-bottom: 30px; |
| | } |
| |
|
| | .mode-btn { |
| | background: rgba(255, 255, 255, 0.9); |
| | border: none; |
| | padding: 15px 30px; |
| | border-radius: 25px; |
| | font-size: 1.1em; |
| | font-weight: bold; |
| | cursor: pointer; |
| | transition: all 0.3s ease; |
| | box-shadow: 0 4px 15px rgba(0,0,0,0.1); |
| | } |
| |
|
| | .mode-btn:hover { |
| | background: white; |
| | transform: translateY(-2px); |
| | box-shadow: 0 6px 20px rgba(0,0,0,0.2); |
| | } |
| |
|
| | .mode-btn.active { |
| | background: #4CAF50; |
| | color: white; |
| | } |
| |
|
| | .content { |
| | background: white; |
| | border-radius: 15px; |
| | min-height: 600px; |
| | box-shadow: 0 8px 32px rgba(0,0,0,0.1); |
| | overflow: hidden; |
| | position: relative; |
| | } |
| |
|
| | .guided-mode, .flowchart-mode { |
| | padding: 0; |
| | height: 100%; |
| | min-height: 600px; |
| | } |
| |
|
| | .guided-mode { |
| | display: flex; |
| | height: 600px; |
| | } |
| |
|
| | .navigation-panel { |
| | width: 300px; |
| | background: #f8f9fa; |
| | border-right: 1px solid #e9ecef; |
| | padding: 20px; |
| | overflow-y: auto; |
| | } |
| |
|
| | .current-panel { |
| | flex: 1; |
| | padding: 30px; |
| | display: flex; |
| | flex-direction: column; |
| | justify-content: center; |
| | } |
| |
|
| | .context-section { |
| | margin-bottom: 20px; |
| | padding: 15px; |
| | background: #e3f2fd; |
| | border-radius: 8px; |
| | border-left: 4px solid #2196f3; |
| | } |
| |
|
| | .context-section h3 { |
| | color: #1976d2; |
| | margin-bottom: 10px; |
| | font-size: 1.1em; |
| | } |
| |
|
| | .context-text { |
| | color: #424242; |
| | font-weight: 500; |
| | } |
| |
|
| | .history-section { |
| | margin-bottom: 20px; |
| | } |
| |
|
| | .history-section h3 { |
| | color: #333; |
| | margin-bottom: 15px; |
| | font-size: 1.1em; |
| | border-bottom: 2px solid #ddd; |
| | padding-bottom: 5px; |
| | } |
| |
|
| | .history-item { |
| | margin-bottom: 10px; |
| | padding: 10px; |
| | background: white; |
| | border-radius: 6px; |
| | border: 1px solid #ddd; |
| | cursor: pointer; |
| | transition: all 0.2s ease; |
| | position: relative; |
| | } |
| |
|
| | .history-item:hover { |
| | background: #f0f7ff; |
| | border-color: #2196f3; |
| | transform: translateX(5px); |
| | } |
| |
|
| | .history-question { |
| | font-weight: bold; |
| | color: #333; |
| | margin-bottom: 5px; |
| | font-size: 0.9em; |
| | } |
| |
|
| | .history-answer { |
| | color: #666; |
| | font-style: italic; |
| | font-size: 0.85em; |
| | } |
| |
|
| | .tooltip { |
| | position: absolute; |
| | left: 100%; |
| | top: 0; |
| | margin-left: 10px; |
| | background: #333; |
| | color: white; |
| | padding: 8px 12px; |
| | border-radius: 4px; |
| | font-size: 0.8em; |
| | white-space: nowrap; |
| | opacity: 0; |
| | pointer-events: none; |
| | transition: opacity 0.2s ease; |
| | z-index: 1000; |
| | } |
| |
|
| | .history-item:hover .tooltip { |
| | opacity: 1; |
| | } |
| |
|
| | .tooltip::before { |
| | content: ''; |
| | position: absolute; |
| | left: -5px; |
| | top: 50%; |
| | transform: translateY(-50%); |
| | border: 5px solid transparent; |
| | border-right-color: #333; |
| | } |
| |
|
| | .articles-section { |
| | padding: 15px; |
| | background: #e8f5e8; |
| | border-radius: 8px; |
| | border-left: 4px solid #4caf50; |
| | } |
| |
|
| | .articles-section h3 { |
| | color: #2e7d32; |
| | margin-bottom: 10px; |
| | font-size: 1.1em; |
| | } |
| |
|
| | .articles-list { |
| | list-style: none; |
| | } |
| |
|
| | .articles-list li { |
| | margin-bottom: 5px; |
| | padding: 5px; |
| | background: white; |
| | border-radius: 4px; |
| | font-size: 0.9em; |
| | color: #1565c0; |
| | cursor: pointer; |
| | transition: background 0.2s ease; |
| | } |
| |
|
| | .articles-list li:hover { |
| | background: #e3f2fd; |
| | } |
| |
|
| | #question-container { |
| | text-align: center; |
| | } |
| |
|
| | .question { |
| | font-size: 1.8em; |
| | margin-bottom: 30px; |
| | color: #333; |
| | line-height: 1.4; |
| | font-weight: 500; |
| | } |
| |
|
| | .choices { |
| | display: flex; |
| | gap: 20px; |
| | justify-content: center; |
| | flex-wrap: wrap; |
| | } |
| |
|
| | .choice-btn { |
| | background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); |
| | color: white; |
| | border: none; |
| | padding: 15px 30px; |
| | border-radius: 25px; |
| | font-size: 1.1em; |
| | font-weight: bold; |
| | cursor: pointer; |
| | transition: all 0.3s ease; |
| | box-shadow: 0 4px 15px rgba(0,0,0,0.1); |
| | min-width: 120px; |
| | } |
| |
|
| | .choice-btn:hover { |
| | transform: translateY(-2px); |
| | box-shadow: 0 6px 20px rgba(0,0,0,0.2); |
| | } |
| |
|
| | .outcome { |
| | background: linear-gradient(135deg, #d4edda 0%, #c3e6cb 100%); |
| | color: #155724; |
| | padding: 30px; |
| | border-radius: 15px; |
| | margin-top: 20px; |
| | font-size: 1.2em; |
| | line-height: 1.6; |
| | border: 2px solid #4CAF50; |
| | } |
| |
|
| | .outcome.gpai { |
| | background: linear-gradient(135deg, #d4edda 0%, #c3e6cb 100%); |
| | color: #155724; |
| | border: 2px solid #4CAF50; |
| | } |
| |
|
| | .breadcrumb { |
| | margin-bottom: 20px; |
| | font-size: 0.9em; |
| | color: #666; |
| | } |
| |
|
| | .breadcrumb span { |
| | margin: 0 5px; |
| | } |
| |
|
| | .restart-btn { |
| | background: #f44336; |
| | color: white; |
| | border: none; |
| | padding: 10px 20px; |
| | border-radius: 20px; |
| | cursor: pointer; |
| | font-size: 0.9em; |
| | margin-top: 20px; |
| | transition: background 0.3s ease; |
| | } |
| |
|
| | .restart-btn:hover { |
| | background: #d32f2f; |
| | } |
| |
|
| | .flowchart-mode { |
| | position: relative; |
| | overflow: hidden; |
| | } |
| |
|
| | .controls { |
| | position: absolute; |
| | top: 20px; |
| | right: 20px; |
| | display: flex; |
| | gap: 10px; |
| | z-index: 100; |
| | } |
| |
|
| | .control-btn { |
| | background: white; |
| | border: 2px solid #ddd; |
| | width: 40px; |
| | height: 40px; |
| | border-radius: 50%; |
| | font-size: 18px; |
| | font-weight: bold; |
| | cursor: pointer; |
| | display: flex; |
| | align-items: center; |
| | justify-content: center; |
| | transition: all 0.2s ease; |
| | box-shadow: 0 2px 8px rgba(0,0,0,0.1); |
| | } |
| |
|
| | .control-btn:hover { |
| | background: #f0f0f0; |
| | border-color: #999; |
| | transform: scale(1.05); |
| | } |
| |
|
| | .flowchart-container { |
| | width: 100%; |
| | height: 600px; |
| | overflow: hidden; |
| | cursor: grab; |
| | position: relative; |
| | } |
| |
|
| | .flowchart-container:active { |
| | cursor: grabbing; |
| | } |
| |
|
| | #mermaid-container { |
| | transform-origin: 0 0; |
| | transition: transform 0.3s ease; |
| | } |
| |
|
| | .hidden { |
| | display: none; |
| | } |
| |
|
| | |
| | @media (max-width: 768px) { |
| | .container { |
| | padding: 10px; |
| | } |
| | |
| | h1 { |
| | font-size: 2em; |
| | } |
| | |
| | .mode-selector { |
| | flex-direction: column; |
| | align-items: center; |
| | } |
| | |
| | .guided-mode { |
| | flex-direction: column; |
| | height: auto; |
| | } |
| | |
| | .navigation-panel { |
| | width: 100%; |
| | max-height: 300px; |
| | } |
| | |
| | .current-panel { |
| | padding: 20px; |
| | } |
| | |
| | .question { |
| | font-size: 1.4em; |
| | } |
| | |
| | .choices { |
| | flex-direction: column; |
| | align-items: center; |
| | } |
| | |
| | .choice-btn { |
| | width: 100%; |
| | max-width: 300px; |
| | } |
| | } |