/* コントロールパネルのスタイル */
.controls-container {
    max-width: 1500px;
    margin: 0 auto 20px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.time-control {
    display: flex;
    align-items: center;
    gap: 30px;  /* 間隔を広げる */
    padding: 25px 40px;  /* 左右のパディングを増やす */
    background-color: #000000;
    border-radius: 0 0 8px 8px;
}

/* 入力部分のグループ */
.time-control-group {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;  /* コンポーネント間の間隔を広げる */
    flex: 1;  /* 利用可能な幅いっぱいに広げる */
}

/* 日付入力部分 */
.date-inputs {
    display: flex;
    align-items: center;
    gap: 10px;
}

input[type="number"] {
    width: 105px;  /* 1.5倍に拡大 */
    padding: 6px;
    background-color: #4d4d4d;
    border: 1px solid #333;
    color: #fff;
    border-radius: 4px;
    font-size: 17px;
    text-align: center;
}

/* 月、日、時の入力欄は年より少し小さく */
input[type="number"]#month,
input[type="number"]#day,
input[type="number"]#hour {
    width: 85px;
}

.time-label {
    font-size: 17px;
    color: #fff;
}

/* スタイル調整とホバー効果 */
input[type="number"]:hover,
input[type="number"]:focus {
    background-color: #3a3a3a;
    outline: none;
    border-color: #555;
}

/* モード選択部分 */
.mode-control {
    display: flex;
    gap: 20px;
    align-items: center;
}

.mode-control label {
    color: #fff;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    white-space: nowrap;
}

.mode-control input[type="checkbox"] {
    width: 16px;
    height: 16px;
    cursor: pointer;
}

/* スクロール制御 */
input[type="number"] {
    /* Firefox */
    scrollbar-width: none;
    /* その他のブラウザ */
    -ms-overflow-style: none;
}

input[type="number"]::-webkit-scrollbar {
    display: none;
}

input[type="number"]:hover,
input[type="number"]:focus {
    overflow: hidden;
}

.time-label {
    font-size: 17px;
    color: #fff;
}

/* スピンボタンの調整 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    opacity: 1;
    background: #444;
    border-left: 1px solid #555;
    height: 20px;
}

/* モード切り替え */
.mode-control {
    display: flex;
    gap: 15px;
}

.mode-control label {
    display: flex;
    align-items: center;
    gap: 5px;
    color: #ddd;
    cursor: pointer;
}

.mode-control input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin: 0;
    cursor: pointer;
}

/* 終了日時の入力制御 */
.range-inputs.disabled input {
    background-color: #151515;
    color: #555;
    cursor: not-allowed;
    pointer-events: none;
}

.range-inputs.disabled .time-label {
    color: #555;
}

/* 有効時のスタイル */
.range-inputs:not(.disabled) input:hover {
    background-color: #2a2a2a;
}

.range-inputs:not(.disabled) input {
    cursor: pointer;
}

/* 時刻固定時のスタイル */
input[type="number"]#hour.time-fixed,
input[type="number"]#endHour.time-fixed,
.range-inputs input[type="number"]#endHour.time-fixed,
input[type="number"]#hour[disabled],
input[type="number"]#endHour[disabled],
input[type="number"][disabled] {
    background-color: #202020 !important;
    color: #ffffff !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
    border-color: #222 !important;
    opacity: 0.8 !important;
    -webkit-user-select: none !important;
    user-select: none !important;
    -moz-user-select: none !important;
}

/* スピンボタンと入力を完全に無効化 */
input[type="number"].time-fixed::-webkit-inner-spin-button,
input[type="number"].time-fixed::-webkit-outer-spin-button,
input[type="number"][disabled]::-webkit-inner-spin-button,
input[type="number"][disabled]::-webkit-outer-spin-button,
input[type="number"].time-fixed::-webkit-calendar-picker-indicator {
    display: none !important;
    -webkit-appearance: none !important;
    margin: 0 !important;
}

/* 時間入力の選択を防止 */
input[type="number"].time-fixed,
input[type="number"][disabled] {
    -webkit-touch-callout: none !important;
    -webkit-user-select: none !important;
    -khtml-user-select: none !important;
    -moz-user-select: none !important;
    -ms-user-select: none !important;
    user-select: none !important;
}

/* ラベル */
span {
    color: #ddd;
    font-size: 14px;
}

/* レスポンシブ対応 */
@media (max-width: 1200px) {
    .time-control {
        flex-direction: column;
        gap: 20px;
        padding: 20px;
        align-items: center;
    }

    .time-control-group {
        flex-direction: column;
        width: auto;
        gap: 20px;
        align-items: center;
    }

    .date-inputs, .range-inputs {
        flex-wrap: nowrap;
        width: auto;
        justify-content: center;
        gap: 15px;
    }

    .mode-control {
        justify-content: center;
        margin-top: 10px;
        width: auto;
    }

    input[type="number"] {
        width: 80px;
    }

    input[type="number"]#year {
        width: 100px;
    }
}

@media (max-width: 600px) {
    .date-inputs, .range-inputs {
        flex-wrap: wrap;
        gap: 15px;
        justify-content: center;
    }

    .time-control {
        padding: 15px;
    }
}

/* マウスホイール操作時の視覚的フィードバック */
input[type="number"]:hover {
    background-color: #3a3a3a;
}

input[type="number"]:active {
    background-color: #444;
}