#return-btn { position: absolute; /* 绝对定位 */ top: 20px; /* 距离顶部 20px */ left: 20px; /* 距离左侧 20px */ padding: 10px 20px; /* 内边距 */ font-size: 1rem; /* 字体大小 */ cursor: pointer; /* 鼠标悬停时显示为手型 */ background-color: #f0f0f0; /* 按钮背景颜色 */ color: #333; /* 按钮文字颜色 */ border: 1px solid #ccc; /* 按钮边框 */ 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; /* 设置按钮的层级,确保在其他元素之上 */ } #return-btn:hover { background-color: #ccc; /* 悬停时的背景颜色 */ transform: scale(1.05); /* 悬停时放大 5% */ } body { font-family: 'HarmonyOS Sans SC Regular', 'Roboto', Arial, sans-serif; /* 设置字体 */ margin: 0; /* 去除默认外边距 */ padding: 0; /* 去除默认内边距 */ background: url('background_light.jpg') no-repeat center center fixed; /* 设置背景图片 */ background-size: cover; /* 背景图片覆盖整个页面 */ animation: fadeIn 1s; /* 页面加载时的淡入动画 */ color: #333; /* 全局文字颜色 */ overflow: auto; /* 允许页面滚动 */ } body::-webkit-scrollbar { display: none; /* 隐藏滚动条 */ } @keyframes fadeIn { from { opacity: 0; } /* 动画开始时透明 */ to { opacity: 1; } /* 动画结束时完全显示 */ } #fullscreen-btn, #settings-btn { position: absolute; /* 绝对定位 */ top: 20px; /* 距离顶部 20px */ padding: 10px 20px; /* 内边距 */ font-size: 1rem; /* 字体大小 */ cursor: pointer; /* 鼠标悬停时显示为手型 */ background-color: #f0f0f0; /* 按钮背景颜色 */ color: #333; /* 按钮文字颜色 */ border: 1px solid #ccc; /* 按钮边框 */ 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; /* 距离右侧 20px */ } #settings-btn { right: 120px; /* 距离右侧 120px */ } #settings-btn:hover, #fullscreen-btn:hover { background-color: #ccc; /* 悬停时的背景颜色 */ transform: scale(1.05); /* 悬停时放大 5% */ } .container { padding: 20px; /* 内边距 */ max-width: 1400px; /* 最大宽度 */ margin: auto; /* 居中对齐 */ background-color: rgba(255, 255, 255, 0.4); /* 半透明背景 */ } h1 { font-size: 3.5rem; /* 字体大小 */ font-weight: bold; /* 字体加粗 */ text-align: left; /* 左对齐 */ margin-bottom: 10px; /* 下边距 */ color: #333; /* 文字颜色 */ display: flex; /* 使用 flex 布局 */ align-items: center; /* 垂直居中 */ justify-content: space-between; /* 两端对齐 */ } #room { font-size: 3.5rem; /* 字体大小 */ font-weight: bold; /* 字体加粗 */ color: #333; /* 文字颜色 */ position: relative; /* 相对定位 */ right: 0; /* 向右移动 0 */ margin-left: 20px; /* 左边距 */ } #message { font-size: 1.8rem; /* 字体大小 */ color: #16a3d1; /* 文字颜色 */ margin-bottom: 20px; /* 下边距 */ } .content { display: flex; justify-content: space-between; gap: 3px; } .left-column, .right-column { display: flex; flex-direction: column; gap: 3px; } .left-column { width: 45%; } .right-column { width: 50%; } .clock-section, .info-section, .right-column { background-color: rgba(255, 255, 255, 0.2); backdrop-filter: blur(10px); padding: 20px; box-shadow: 0 0 10px rgba(0, 0, 0, 0.3); border-radius: 8px; } .clock-section, .info-section { margin-bottom: 20px; /* 增加时钟和信息板块之间的间隔 */ } #current-time { font-size: 8rem; text-align: center; color: #333; margin: 0; font-weight: bold; } #current-subject, #exam-timing, #remaining-time, #status { font-size: 3rem; margin: 10px 0; text-align: left; color: #333; } table { width: 100%; /* 表格宽度 */ border-collapse: collapse; /* 合并边框 */ margin-top: 20px; /* 上边距 */ border: 1px solid #000; /* 表格边框 */ background-color: rgba(255, 255, 255, 0.5); /* 半透明背景 */ } th, td { border: 1px solid #000; padding: 0px; font-size: 1.8rem; text-align: center; } th { background-color: #f0f0f0; /* 背景颜色 */ color: #333; /* 文字颜色 */ font-weight: bold; /* 字体加粗 */ border-bottom: 2px solid #000; /* 下边框 */ } tr:hover { background-color: #f0f0f0; /* 背景颜色 */ } table { border-radius: 8px; overflow: hidden; } td { border-bottom: 1px solid #000; /* 下边框 */ padding: 0px; /* 内边距 */ font-size: 1.8rem; /* 字体大小 */ text-align: center; /* 居中对齐 */ } 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; /* 右下角圆角 */ } .exam-status-tag { padding: 3px 6px; border-radius: 4px; font-size: 1.2rem; display: inline-block; min-width: 60px; } .exam-status-进行中 { background-color: rgba(91, 168, 56, 0.1); color: #5ba838; } .exam-status-即将开始 { background-color: rgba(254, 153, 1, 0.1); color: #fe9901; } .exam-status-已结束 { background-color: rgba(236, 4, 52, 0.1); color: #ec0434; } .exam-status-未开始 { background-color: rgba(238, 238, 91, 0.1); color: #d4b106; } #settings-modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgba(0, 0, 0, 0.4); padding-top: 60px; } #settings-modal-content { background: rgba(255, 255, 255, 0.95); padding: 25px; margin: 25px auto; border-radius: 12px; border: 1px solid #ccc; backdrop-filter: blur(8px); max-width: 600px; max-height: 60vh; /* 限制最大高度 */ overflow-y: auto; /* 允许垂直滚动 */ animation: fadeIn 0.5s ease; } /* 设置滚动条样式 */ #settings-modal-content::-webkit-scrollbar { width: 8px; } #settings-modal-content::-webkit-scrollbar-track { background: rgba(0, 0, 0, 0.1); border-radius: 4px; } #settings-modal-content::-webkit-scrollbar-thumb { background: #ccc; border-radius: 4px; } #settings-modal-content::-webkit-scrollbar-thumb:hover { background: #999; } @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: #333; font-size: 20px; } #settings-modal-content label { display: flex; align-items: center; gap: 10px; margin: 12px 0; font-size: 16px; color: #666; } #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; } #settings-modal-content input[type="number"], #settings-modal-content input[type="text"] { font-size: 1.8rem; padding: 10px; margin-top: 10px; margin-bottom: 20px; width: 100%; box-sizing: border-box; border: 1px solid #ccc; border-radius: 5px; background-color: #fff; color: #333; } #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; } #theme-select { padding: 8px 12px; font-size: 14px; border: 1px solid #ccc; border-radius: 4px; background-color: #fff; color: #333; cursor: pointer; outline: none; width: 120px; } #theme-select:hover { border-color: #999; } #theme-select:focus { border-color: #007acc; box-shadow: 0 0 0 1px #007acc; } #theme-select option { background-color: #fff; color: #333; padding: 8px; } .config-file-container { margin: 12px 0; padding: 10px; border: 1px solid #ccc; border-radius: 5px; background-color: rgba(255, 255, 255, 0.5); box-sizing: border-box; max-width: 100%; } .config-file-container label { display: block; margin-bottom: 8px; color: #333; } .config-file-container input[type="file"] { display: block; width: calc(100% - 16px); /* 减去padding的宽度 */ padding: 8px; border: 1px solid #ccc; border-radius: 4px; background-color: #fff; color: #333; cursor: pointer; box-sizing: border-box; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .config-file-container input[type="file"]:hover { background-color: #f5f5f5; } .file-hint { margin-top: 4px; font-size: 12px; color: #666; } .config-control-btn { margin-top: 10px; padding: 8px 16px; background-color: #d9534f; color: white; border: none; border-radius: 4px; cursor: pointer; font-size: 14px; transition: background-color 0.3s ease; } .config-control-btn:hover { background-color: #c9302c; } .reminder-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(255, 255, 255, 0.95); display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: all 0.5s ease; backdrop-filter: blur(8px); z-index: 9999; } .reminder-overlay.show { opacity: 1; visibility: visible; } .reminder-content { text-align: center; animation: fadeIn 0.5s ease; } .reminder-title { font-size: 5rem; color: #FF3B30; margin-bottom: 2rem; } .reminder-subtitle { font-size: 3rem; color: #FF9500; } @keyframes fadeIn { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } } .info-section { position: relative; } .info-toggle-btn { position: absolute; right: 0; top: 0; background-color: #f0f0f0; color: #333; border: none; border-radius: 50%; width: 48px; height: 48px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.2s ease; z-index: 2; } .info-toggle-btn:hover { background-color: #ccc; transform: translateY(-1px); } .info-toggle-btn .material-icons { font-size: 24px; } .paper-count-container { margin: 20px 0; } .paper-input-group { display: flex; align-items: center; gap: 10px; margin: 10px 0; font-size: 2.5rem; } .count-control { display: flex; align-items: center; gap: 5px; } .count-btn { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: none; border-radius: 50%; background-color: #f0f0f0; color: #333; cursor: pointer; transition: all 0.2s ease; } .count-btn:hover { background-color: #ccc; transform: translateY(-1px); } .count-btn .material-icons { font-size: 20px; } .count-btn-group { display: flex; flex-direction: column; gap: 2px; margin-right: 8px; } .count-control { display: flex; align-items: center; gap: 5px; } .count-btn { width: 24px; height: 24px; padding: 0; border: 1px solid #ccc; display: flex; align-items: center; justify-content: center; } .count-btn .material-icons { font-size: 16px; }