body { font-family: sans-serif; line-height: 1.6; margin: 20px; background-color: #f4f4f4; color: #333; }
.container { max-width: 960px; margin: auto; background: #fff; padding: 20px; border-radius: 8px; box-shadow: 0 0 10px rgba(0,0,0,0.1); }
h1, h2 { color: #333; }
.version-span { font-size: 0.6em; vertical-align: baseline; }
.logout { float: right; text-decoration: none; background: #f44336; color: white; padding: 5px 10px; border-radius: 4px; }
.message { padding: 15px; margin-bottom: 20px; border-radius: 4px; }
.error { background-color: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }
.success { background-color: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
form { margin-bottom: 2em; padding: 20px; border: 1px solid #ddd; border-radius: 5px; background: #f9f9f9; }
label { display: block; margin-bottom: 5px; font-weight: bold; }
input[type="text"], input[type="time"], input[type="date"], select, input[type="password"] { width: 100%; padding: 8px; margin-bottom: 10px; border-radius: 4px; border: 1px solid #ccc; box-sizing: border-box; }
button { background-color: #4CAF50; color: white; padding: 10px 15px; border: none; border-radius: 4px; cursor: pointer; }
button[type="submit"]:hover { background-color: #45a049; }
.delete-button { background-color: #f44336; }
.button.delete-button { background-color: #f44336; } /* Specificity for combined classes */
.delete-button:hover { background-color: #da190b; }
table { width: 100%; border-collapse: collapse; margin-top: 20px; }
th, td { text-align: left; padding: 12px; border-bottom: 1px solid #ddd; }
th { background-color: #4CAF50; color: white; }
tr:hover { background-color: #f1f1f1; }
.actions a, .actions button {
    text-decoration: none; color: #fff; padding: 5px 8px; border-radius: 3px;
    margin-right: 5px; font-size: 0.9em; border: none;
    box-sizing: border-box; /* Ensures padding is included in height */
    height: 28px; /* Sets a consistent height */
    vertical-align: middle; /* Aligns elements on the same line */
}
.actions .edit-btn { background-color: #008CBA; display: inline-block; }
.actions .inline-form { display:inline-block; margin:0; padding:0; border:0; }
.inline-form { display:inline-block; margin:0; padding:0; border:0; background:none; }
.login-form { max-width: 400px; margin: 50px auto; }
.form-group { flex: 1; }
.status-indicators { float: right; display: flex; gap: 10px; margin-left: 20px; }
.status-btn { padding: 5px 10px; border-radius: 4px; color: white; font-weight: bold; border: 1px solid #555; }
.status-off { background-color: #777; }
.status-on { background-color: #4CAF50; box-shadow: 0 0 8px #4CAF50; }
.status-temp { background-color: #008CBA; border-color: #00739c; }
.form-row { margin-bottom: 10px; }
.compact-form-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: flex-end; }
.compact-form-row .form-group { flex: 1 1 auto; min-width: 150px; }
.compact-form-row label { margin-bottom: 2px; font-size: 0.9em; }
.compact-form-row input, .compact-form-row select { width: 100%; padding: 8px; margin-bottom: 0; box-sizing: border-box; height: 35px; }
.form-group-checkbox {
    display: flex;
    align-items: center;
    gap: 0.5em;
    margin-top: 10px;
}
.form-group-checkbox label { margin-bottom: 0; }
.form-group-checkbox input[type="checkbox"] { width: auto; margin-bottom: 0; }
.compact-form-row .form-group button,
.compact-form-row .form-group .button {
    height: 35px;
}
.form-group-cancel {
    margin-left: auto;
}
.settings-group { flex-grow: 0; flex-basis: 150px; }
.settings-group.separator { margin-left: 20px; }
.settings-group .input-pair { display: flex; gap: 5px; align-items: center; }
.settings-group .input-pair input { width: 50px; flex-grow: 0; }
.button-group { flex-grow: 1; }
.button-group button { width: 100%; }


pre.log-view { background-color: #222; color: #eee; padding: 15px; border-radius: 5px; white-space: pre-wrap; word-wrap: break-word; max-height: 500px; overflow-y: auto; }
.button {
    display: inline-block;
    background-color: #4CAF50;
    color: white;
    padding: 10px 15px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    text-decoration: none;
    box-sizing: border-box; /* Ensure padding is included in width/height */
}
.button.cancel-button { background: #f44336; color: white; }
.centered-div { text-align: center; }
.margin-top-30 { margin-top: 30px; }
.margin-top-20 { margin-top: 20px; }

/* --- Added from index.php --- */

.message.warning {
    background-color: #ff9800;
    color: white;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.close-warning {
    background: transparent;
    border: none;
    color: white;
    font-size: 20px;
    cursor: pointer;
    margin-left: 10px;
}

/* Custom Tooltip Styles */
[data-tooltip] {
    position: relative;
    cursor: help;
}
[data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    margin-top: 10px;
    background-color: #333;
    color: #fff;
    padding: 8px 12px;
    border-radius: 4px;
    font-size: 0.85em;
    white-space: pre-wrap;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s;
    pointer-events: none;
    width: max-content;
    text-align: center;
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
    line-height: 1.4;
}
[data-tooltip]:hover::after {
    opacity: 1;
    visibility: visible;
}
[data-tooltip]::before {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    margin-top: -2px;
    border: 6px solid transparent;
    border-bottom-color: #333;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s;
    z-index: 1000;
}
[data-tooltip]:hover::before {
    opacity: 1;
    visibility: visible;
}

/* Utility classes for log view and form fields */
#manual-fields-start, #manual-fields-stop { display: none; }
.log-filter-form { margin-bottom: 15px; }
.log-actions-container { display: flex; justify-content: center; gap: 10px; align-items: stretch; }
.flex-align-center { display: flex; align-items: center; }
.flex-display { display: flex; }