body { font-family: 'HarmonyOS Sans SC Regular', 'Roboto', Arial, sans-serif; margin: 0; padding: 0; background: url('../../background.jpg') no-repeat center center fixed; /* 更新路径 */ background-size: cover; animation: fadeIn 1s; color: #e0e0e0; overflow: auto; /* 允许页面滚动 */ } /* 隐藏滚动条 */ body::-webkit-scrollbar { display: none; } @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } #fullscreen-btn, #settings-btn { position: absolute; top: 20px; padding: 10px 20px; font-size: 1rem; cursor: pointer; background-color: #1f1f1f; color: #e0e0e0; border: 1px solid #333; border-radius: 5px; box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); transition: background-color 0.3s ease, transform 0.3s ease; z-index: 1001; } #fullscreen-btn { right: 20px; } #settings-btn { right: 120px; /* Fullscreen button's left */ } #settings-btn:hover, #fullscreen-btn:hover { background-color: #333; transform: scale(1.05); } .container { padding: 20px; max-width: 1400px; /* 增加主体部分宽度 */ margin: auto; background-color: rgba(255, 255, 255, 0); /* 使用rgba设置背景透明度为80% */ } h1 { font-size: 3.5rem; font-weight: bold; text-align: left; margin-bottom: 10px; color: #e0e0e0; display: flex; align-items: center; justify-content: space-between; } #room { font-size: 3.5rem; font-weight: bold; color: #e0e0e0; position: relative; right: 0; margin-left: 20px; /* 调整位置使其保持在container中 */ } #message { font-size: 1.5rem; color: #16a3d1; margin-bottom: 20px; } .content { display: flex; justify-content: space-between; gap: 3px; /* 板块间隔3px */ } .left-column, .right-column { width: 48%; display: flex; flex-direction: column; gap: 3px; /* 板块间隔3px */ } .clock-section, .info-section, .right-column { background-color: rgba(31, 31, 31, 0.5); /* 亚克力效果 */ backdrop-filter: blur(10px); padding: 20px; box-shadow: 0 0 10px rgba(0, 0, 0, 0.3); border-radius: 8px; } #current-time { font-size: 8rem; text-align: center; color: #7cc3fb; margin: 0; font-weight: bold; } #current-subject, #exam-timing, #remaining-time, #status { font-size: 3rem; margin: 10px 0; text-align: left; color: #e0e0e0; } table { width: 100%; border-collapse: collapse; margin-top: 20px; border: 1px solid #333; background-color: rgba(31, 31, 31, 0.5); } th, td { border: 1px solid #333; padding: 2px; /* 缩短行高 */ font-size: 2rem; text-align: center; } th { background-color: #333; color: #7cc3fb; font-weight: bold; border-bottom: 2px solid #2b71ad; } .exam-status-进行中 td { color: #5ba838 !important; /* 绿色字体 */ } .exam-status-即将开始 td { color: #fe9901 !important; /* 橙色字体 */ } .exam-status-已结束 td { color: #ec0434 !important; /* 红色字体 */ } .exam-status-空闲 td { color: blue !important; /* 蓝色字体 */ } tr:hover { background-color: #333; } table { border-radius: 8px; overflow: hidden; } td { border-bottom: 1px solid #333; } td:first-child { border-top-left-radius: 8px; border-bottom-left-radius: 8px; } td:last-child { border-top-right-radius: 8px; border-bottom-right-radius: 8px; } #settings-modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgb(0, 0, 0); background-color: rgba(0, 0, 0, 0.4); padding-top: 60px; } #settings-modal-content { background: rgba(31, 31, 31, 0.95); padding: 25px; margin: 25px auto; border-radius: 12px; border: 1px solid #444; backdrop-filter: blur(8px); max-width: 600px; animation: fadeIn 0.5s ease; } @keyframes fadeIn { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } } @keyframes fadeOut { from { opacity: 1; transform: translateY(0); } to { opacity: 0; transform: translateY(-20px); } } .fade-out { animation: fadeOut 0.3s ease; } #settings-modal-content h3 { margin: 0 0 20px; color: #e0e0e0; font-size: 20px; } #settings-modal-content label { display: flex; align-items: center; gap: 10px; margin: 12px 0; font-size: 16px; color: #b0b0b0; } #settings-modal-content label[for="offset-time"], #settings-modal-content label[for="room-input"], #settings-modal-content label[for="zoom-input"] { justify-content: space-between; } #settings-modal-content input[type="number"], #settings-modal-content input[type="text"] { flex-grow: 1; margin-left: 10px; font-size: 1.5rem; padding: 10px; margin-top: 10px; margin-bottom: 20px; width: 100%; box-sizing: border-box; border: 1px solid #555; border-radius: 5px; background-color: #222; color: #e0e0e0; } #settings-modal-content input:focus { outline: none; border-color: #007acc; box-shadow: 0 0 0 1px #007acc; } .button-group { display: flex; justify-content: flex-end; gap: 10px; } #settings-modal-content button { background: linear-gradient(135deg, #3498db, #2980b9); color: white; border: none; padding: 12px 24px; border-radius: 8px; cursor: pointer; font-size: 15px; font-weight: 500; transition: all 0.2s ease; box-shadow: 0 4px 12px rgba(52,152,219,0.25); } #settings-modal-content button:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(52,152,219,0.35); } #close-settings-btn { padding: 10px 20px; font-size: 2rem; cursor: pointer; background-color: #d9534f; color: white; border: none; border-radius: 5px; box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); transition: background-color 0.3s ease; } #close-settings-btn:hover { background-color: #c9302c; } .error-container { position: fixed; bottom: 0; left: 0; right: 0; background: #ff6b6b; color: white; padding: 16px; display: none; z-index: 10001; animation: slideUp 0.3s ease; } @keyframes slideUp { from { transform: translateY(100%); } to { transform: translateY(0); } } .error-content { max-width: 800px; margin: 0 auto; font-size: 15px; display: flex; align-items: center; gap: 12px; } .error-content:before { content: '!'; display: flex; align-items: center; justify-content: center; width: 24px; height: 24px; background: white; color: #ff6b6b; border-radius: 50%; font-weight: bold; } .switch { position: relative; display: inline-block; width: 60px; height: 34px; } .switch input { opacity: 0; width: 0; height: 0; } .slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: #ccc; transition: .4s; border-radius: 34px; } .slider:before { position: absolute; content: ""; height: 26px; width: 26px; left: 4px; bottom: 4px; background-color: white; transition: .4s; border-radius: 50%; } input:checked + .slider { background-color: #2196F3; } input:checked + .slider:before { transform: translateX(26px); } .theme-toggle-container { display: flex; align-items: center; justify-content: space-between; gap: 10px; }