/* Neumorphism Base Variables */
:root {
    --neumorphic-bg: #e0e5ec; 
    --neumorphic-bg-darker: #c8d0e7; 
    --neumorphic-bg-lighter: #f8f9fa; 
    --neumorphic-text-color: #5b6577; 
    --neumorphic-primary-color: #4a77d4; 
    --neumorphic-primary-color-darker: #3b5fb0;
    --neumorphic-success-color: #28a745; /* Green for enable/success */
    --neumorphic-danger-color: #dc3545;  /* Red for disable/danger */
    --neumorphic-warning-color: #fd7e14; /* Orange for warning */
    --neumorphic-shadow-light: rgba(255, 255, 255, 0.7); 
    --neumorphic-shadow-dark: rgba(163, 177, 198, 0.6); 
    --neumorphic-border-radius: 15px; 
    --neumorphic-element-padding: 15px;
    --neumorphic-shadow-distance: 6px;
    --neumorphic-blur: 12px;
    --navbar-height-approx: 60px; 
}

body {
    font-family: 'Montserrat', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; 
    line-height: 1.6;
    margin: 0;
    padding: 0; 
    background-color: var(--neumorphic-bg);
    color: var(--neumorphic-text-color);
    transition: background-color 0.3s ease;
}

.navbar {
    background-color: var(--neumorphic-bg);
    padding: 10px 25px; 
    color: var(--neumorphic-text-color);
    position: sticky; 
    top: 0;           
    left: 0;
    width: 100%;
    z-index: 1000;    
    box-sizing: border-box;
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}

.navbar a {
    color: var(--neumorphic-text-color);
    text-decoration: none;
    margin-right: 20px;
    font-weight: 500;
    padding: 8px 12px; 
    border-radius: 10px;
    transition: all 0.3s ease;
}

.navbar a:hover {
    color: var(--neumorphic-primary-color);
    background-color: var(--neumorphic-bg); 
    box-shadow: 
        inset 2px 2px 5px var(--neumorphic-shadow-dark),
        inset -2px -2px 5px var(--neumorphic-shadow-light);
}

.admin-nav {
    margin-bottom: 25px;
    border-bottom: 1px solid var(--neumorphic-bg-darker);
    padding-bottom: 15px;
    display: flex; 
    gap: 10px;
}
.admin-nav a {
    text-decoration: none;
    padding: 10px 15px;
    border-radius: var(--neumorphic-border-radius);
    transition: all 0.3s ease;
    font-weight: 500;
    background-color: var(--neumorphic-bg);
    color: var(--neumorphic-text-color);
    box-shadow: 
        3px 3px 6px var(--neumorphic-shadow-dark),
        -3px -3px 6px var(--neumorphic-shadow-light);
}
.admin-nav a.active, .admin-nav a:hover {
    color: var(--neumorphic-primary-color);
    box-shadow: 
        inset 3px 3px 6px var(--neumorphic-shadow-dark),
        inset -3px -3px 6px var(--neumorphic-shadow-light);
}


.container { 
    max-width: 900px; 
    margin: 0 auto; 
    background: var(--neumorphic-bg); 
    /* padding: 30px; */
    /* padding-top: calc(var(--navbar-height-approx) + 20px);  */
    border-radius: var(--neumorphic-border-radius);
}

.auth-form-container {
    max-width: 480px; 
    margin: 0 auto; 
    margin-top: calc(var(--navbar-height-approx) + 20px); 
    margin-bottom: 30px;
    padding: 0; 
    background-color: transparent; 
    border-radius: 0; 
    box-shadow: none; 
}
.auth-form-container h1 { 
    margin-bottom: 25px;
    color: var(--neumorphic-text-color); 
}
.auth-form-container fieldset {
    border: none; 
    padding: 25px; 
    margin-bottom: 0; 
    border-radius: var(--neumorphic-border-radius);
    background-color: var(--neumorphic-bg); 
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}
.auth-form-container fieldset legend {
    font-weight: 600;
    color: var(--neumorphic-primary-color);
    padding: 8px 15px; 
    font-size: 1.1em; 
    margin-left: 0; 
    margin-bottom: 20px; 
    background-color: var(--neumorphic-bg); 
    border-radius: 10px; 
    box-shadow: 
        3px 3px 6px var(--neumorphic-shadow-dark),
        -3px -3px 6px var(--neumorphic-shadow-light);
    display: inline-block; 
}


h1, h2, h3 {
    color: var(--neumorphic-text-color);
    text-align: center;
    font-weight: 600; 
}

h1 {
    margin-bottom: 30px;
    font-size: 2em;
}

h2 {
    margin-top: 35px;
    border-bottom: 1px solid var(--neumorphic-bg-darker);
    padding-bottom: 15px;
    margin-bottom: 25px;
    font-size: 1.6em;
}

h3 {
    margin-top: 30px;
    color: var(--neumorphic-text-color);
    font-size: 1.3em;
    margin-bottom: 20px;
}

fieldset { 
    border: none; 
    padding: 25px;
    margin-bottom: 30px;
    border-radius: var(--neumorphic-border-radius);
    background-color: var(--neumorphic-bg);
    box-shadow: 
        inset var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        inset calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}

legend { 
    font-weight: 600;
    color: var(--neumorphic-primary-color);
    padding: 5px 15px; 
    font-size: 1.2em;
    margin-left: 10px; 
    background-color: var(--neumorphic-bg); 
    border-radius: 8px; 
    box-shadow: 
        3px 3px 6px var(--neumorphic-shadow-dark),
        -3px -3px 6px var(--neumorphic-shadow-light);
}

.form-group {
    margin-bottom: 20px; 
}

.form-group label { 
    display: block;
    margin-bottom: 8px; 
    font-weight: 500; 
    color: var(--neumorphic-text-color);
}

.form-row-flex {
    display: flex;
    flex-wrap: wrap; 
    gap: 20px; 
}

.form-row-flex .form-group {
    flex: 1; 
    min-width: 200px; 
    margin-bottom: 0; 
}

@media (max-width: 600px) { 
    .form-row-flex {
        flex-direction: column;
        gap: 0; 
    }
    .form-row-flex .form-group {
        margin-bottom: 20px; 
        min-width: 100%; 
        flex-basis: auto; 
    }
}


input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"], 
input[type="date"],
input[type="number"],
select,
textarea {
    width: 100%; 
    padding: var(--neumorphic-element-padding);
    margin-bottom: 20px; 
    border: none; 
    border-radius: var(--neumorphic-border-radius);
    box-sizing: border-box; 
    font-size: 1em;
    background-color: var(--neumorphic-bg);
    color: var(--neumorphic-text-color);
    box-shadow: 
        inset 4px 4px 8px var(--neumorphic-shadow-dark),
        inset -4px -4px 8px var(--neumorphic-shadow-light);
    transition: box-shadow 0.3s ease;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus, 
input[type="date"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus {
    outline: none;
    box-shadow: 
        inset 2px 2px 5px var(--neumorphic-shadow-dark),
        inset -2px -2px 5px var(--neumorphic-shadow-light),
        0 0 0 2px var(--neumorphic-bg-lighter), 
        0 0 0 4px var(--neumorphic-primary-color); 
}
select {
    appearance: none;
    background-image: url('data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2212%22%20height%3D%2212%22%20viewBox%3D%220%200%2012%2012%22%3E%3Cpath%20fill%3D%22%235b6577%22%20d%3D%22M10.707%203.293a1%201%200%2000-1.414%200L6%206.586%202.707%203.293a1%201%200%2000-1.414%201.414l4%204a1%201%200%20001.414%200l4-4a1%201%200%20000-1.414z%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: right var(--neumorphic-element-padding) top 50%;
    background-size: 12px auto;
    padding-right: calc(var(--neumorphic-element-padding) * 2 + 12px); 
}


.config-input { 
    width: auto !important;
    margin-right:10px;
    padding: 10px; 
}


textarea {
    min-height: 150px; 
    resize: vertical;
}

input[type="checkbox"],
input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 20px;
    height: 20px;
    background-color: var(--neumorphic-bg);
    border-radius: 5px; 
    box-shadow: 
        3px 3px 6px var(--neumorphic-shadow-dark),
        -3px -3px 6px var(--neumorphic-shadow-light);
    position: relative;
    cursor: pointer;
    outline: none;
    vertical-align: middle;
    margin-right: 8px;
}
input[type="radio"] {
    border-radius: 50%;
}

input[type="checkbox"]:checked,
input[type="radio"]:checked {
    box-shadow: 
        inset 3px 3px 6px var(--neumorphic-shadow-dark),
        inset -3px -3px 6px var(--neumorphic-shadow-light);
}
input[type="checkbox"]:checked::after,
input[type="radio"]:checked::after {
    content: '';
    display: block;
    width: 10px; 
    height: 10px;
    background-color: var(--neumorphic-primary-color);
    border-radius: 2px; 
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
input[type="radio"]:checked::after {
    border-radius: 50%; 
}

input[type="checkbox"] + label,
input[type="radio"] + label {
    display: inline-block;
    cursor: pointer;
    vertical-align: middle;
    margin-left: 4px; 
}


.checkbox-group label,
.radio-group label {
    font-weight: normal;
    display: inline-block; 
    margin-right: 20px;
    margin-bottom: 10px;
}
.checkbox-item, .radio-item {
    display: flex; 
    align-items: center;
    margin-bottom: 10px; 
}


button[type="submit"], .button-link {
    display: inline-block;
    background-color: var(--neumorphic-bg);
    color: var(--neumorphic-primary-color) !important; 
    padding: 12px 25px; 
    border: none;
    border-radius: var(--neumorphic-border-radius);
    cursor: pointer;
    font-size: 1em; 
    text-decoration: none; 
    transition: all 0.2s ease-out; 
    text-transform: uppercase; 
    font-weight: 600; 
    letter-spacing: 0.8px;
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}
.button-link {
    padding: 10px 20px; 
    font-size: 0.9em;
}


button[type="submit"]:hover, .button-link:hover {
    color: var(--neumorphic-primary-color-darker) !important;
    box-shadow: 
        calc(var(--neumorphic-shadow-distance) - 2px) calc(var(--neumorphic-shadow-distance) - 2px) calc(var(--neumorphic-blur) - 4px) var(--neumorphic-shadow-dark),
        calc(-1 * (var(--neumorphic-shadow-distance) - 2px)) calc(-1 * (var(--neumorphic-shadow-distance) - 2px)) calc(var(--neumorphic-blur) - 4px) var(--neumorphic-shadow-light);
}
button[type="submit"]:active, .button-link:active { 
    box-shadow: 
        inset var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        inset calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
    color: var(--neumorphic-primary-color-darker) !important;
}

a.button-link.cancel { 
    color: var(--neumorphic-text-color) !important;
}
a.button-link.cancel:hover {
    color: #333 !important;
}


.message {
    padding: 20px; 
    margin-bottom: 25px;
    border-radius: var(--neumorphic-border-radius);
    text-align: center;
    font-size: 1.05em;
    border: none; 
    background-color: var(--neumorphic-bg);
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}

.message.success {
    color: var(--neumorphic-success-color); 
}

.message.error {
    color: var(--neumorphic-danger-color); 
}

.message.orange {
    color: var(--neumorphic-warning-color); 
}

.input-error {
    box-shadow: 
        inset 3px 3px 6px var(--neumorphic-shadow-dark),
        inset -3px -3px 6px var(--neumorphic-shadow-light),
        0 0 0 2px var(--neumorphic-danger-color) !important; 
}

.error-message {
    display: block; 
    color: var(--neumorphic-danger-color); 
    font-size: 0.875em;
    margin-top: -15px; 
    margin-bottom: 10px; 
    min-height: 1.2em; 
}

.form-text.text-muted {
    font-size: 0.8em;
    color: #7a7a7a; 
    display: block;
    margin-top: -10px; 
    margin-bottom: 15px;
}


/* --- Common Table Styles (Neumorphic) --- */
table {
    width: 100%;
    border-collapse: separate; 
    border-spacing: 0; 
    margin-top: 25px;
    margin-bottom: 25px; 
    background-color: var(--neumorphic-bg);
    border-radius: var(--neumorphic-border-radius);
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}

table th,
table td {
    padding: 15px; 
    text-align: left;
    vertical-align: middle; 
}
table tr:not(:last-child) td { 
    border-bottom: 1px solid var(--neumorphic-bg-darker);
}


table th {
    background-color: var(--neumorphic-bg); 
    font-weight: 600; 
    color: var(--neumorphic-text-color);
    text-transform: uppercase; 
    font-size: 0.9em;
    letter-spacing: 0.8px;
     box-shadow: 
        2px 2px 4px var(--neumorphic-shadow-dark), 
        -2px -2px 4px var(--neumorphic-shadow-light);
    border-bottom: 2px solid var(--neumorphic-bg-darker); 
}
table th:first-child {
    border-top-left-radius: var(--neumorphic-border-radius);
}
table th:last-child {
    border-top-right-radius: var(--neumorphic-border-radius);
}


table tbody tr:hover td { 
    background-color: var(--neumorphic-bg-lighter); 
}

/* Action links within tables */
table td.actions a { 
    margin-right: 8px;
    text-decoration: none;
    font-weight: 500;
    font-size: 0.9em;
    padding: 6px 10px; 
    border-radius: 10px; 
    background-color: var(--neumorphic-bg);
    box-shadow: 2px 2px 5px var(--neumorphic-shadow-dark), -2px -2px 5px var(--neumorphic-shadow-light);
    transition: all 0.2s ease-in-out;
}
table td.actions a:hover {
    box-shadow: inset 1px 1px 3px var(--neumorphic-shadow-dark), inset -1px -1px 3px var(--neumorphic-shadow-light);
}
/*table td.actions a.edit-link {
    color: var(--neumorphic-primary-color);
}*/
table td.actions a.edit-link:hover {
    color: var(--neumorphic-primary-color-darker);
}
table td.actions a.disable-link { 
    color: var(--neumorphic-warning-color) !important; 
}
table td.actions a.disable-link:hover {
    color: #e06c00 !important; /* Darker orange */
}
table td.actions a.enable-link {
    color: var(--neumorphic-success-color) !important; 
}
table td.actions a.enable-link:hover {
    color: #1e7e34 !important; /* Darker green */
}


.admin-section .options-textarea {
    min-height: 80px;
    font-size: 0.9em;
    width: 100%; 
}

/* Styles for disabled question rows */
.disabled-question td {
    color: #99aabb; 
    background-color: var(--neumorphic-bg) !important; 
    opacity: 0.6; /* Slightly less opacity to still see it's there */
    /* text-decoration: line-through; */ /* Optional: if you prefer line-through */
}
.disabled-question td .actions a:not(.enable-link) { /* Dim all actions except "Enable" */
    opacity: 0.4;
    pointer-events: none; 
}
.disabled-question td .actions a.enable-link { /* Ensure enable link is fully visible and clickable */
    opacity: 1;
    pointer-events: auto;
    color: var(--neumorphic-success-color) !important;
}


/* Styles for the "Order" column and move arrows in tables */
table th.sort-order-header, 
table td.sort-order-cell {
    text-align: center; 
    white-space: nowrap; 
}

table td.sort-order-cell .sort-order-number {
    display: inline-block;
    min-width: 20px; 
    text-align: center;
    margin: 0 5px; /* Add margin around the number */
}

table td.sort-order-cell a.move-arrow {
    display: inline-block;
    text-decoration: none;
    color: var(--neumorphic-primary-color);
    font-weight: bold;
    font-size: 1.3em; 
    padding: 2px 5px; 
    border-radius: 8px; 
    background-color: var(--neumorphic-bg);
    box-shadow: 1px 1px 3px var(--neumorphic-shadow-dark), -1px -1px 3px var(--neumorphic-shadow-light);
    transition: all 0.2s ease-in-out;
    line-height: 1; 
    /* margin: 0 3px; Removed to rely on sort-order-number margin */
}

table td.sort-order-cell a.move-arrow:hover {
    color: var(--neumorphic-primary-color-darker);
    box-shadow: inset 1px 1px 2px var(--neumorphic-shadow-dark), inset -1px -1px 2px var(--neumorphic-shadow-light);
}

table td.sort-order-cell span.move-arrow.disabled {
    display: inline-block;
    color: var(--neumorphic-bg-darker); 
    font-weight: bold;
    font-size: 1.3em;
    padding: 2px 5px;
    line-height: 1;
    /* margin: 0 3px; */
    cursor: default; 
}


/* Star Rating Styles - Neumorphic attempt */
.stars-rating-group {
    display: flex;
    flex-direction: row-reverse; 
    justify-content: flex-end;  
    margin-bottom: 15px;
}

.stars-rating-group .star-radio {
    display: none; 
}

.stars-rating-group .star-label {
    font-size: 2em; 
    color: var(--neumorphic-bg-darker); 
    cursor: pointer;
    padding: 0 3px; 
    transition: color 0.2s ease-in-out, text-shadow 0.2s ease-in-out;
    text-shadow: 1px 1px 2px var(--neumorphic-shadow-light), -1px -1px 2px var(--neumorphic-shadow-dark);
}

.stars-rating-group .star-label:hover,
.stars-rating-group .star-label:hover ~ .star-label {
    color: var(--neumorphic-primary-color); 
}

.stars-rating-group .star-radio:checked ~ .star-label {
    color: var(--neumorphic-primary-color); 
    text-shadow: 
      1px 1px 3px var(--neumorphic-shadow-light), 
      -1px -1px 3px var(--neumorphic-shadow-dark),
      0 0 5px var(--neumorphic-primary-color); 
}

/* Move to Top Button Styles */
#moveToTopBtn {
    display: none; 
    position: fixed;
    bottom: 25px; 
    right: 25px;
    z-index: 999; 
    border: none;
    outline: none;
    background-color: var(--neumorphic-bg);
    color: var(--neumorphic-text-color);
    cursor: pointer;
    padding: 0; 
    width: 50px;  
    height: 50px; 
    line-height: 50px; 
    text-align: center; 
    border-radius: 50%; 
    font-size: 24px; 
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
    transition: all 0.2s ease-out;
}

#moveToTopBtn:hover {
    color: var(--neumorphic-primary-color);
    box-shadow: 
        calc(var(--neumorphic-shadow-distance) - 2px) calc(var(--neumorphic-shadow-distance) - 2px) calc(var(--neumorphic-blur) - 4px) var(--neumorphic-shadow-dark),
        calc(-1 * (var(--neumorphic-shadow-distance) - 2px)) calc(-1 * (var(--neumorphic-shadow-distance) - 2px)) calc(var(--neumorphic-blur) - 4px) var(--neumorphic-shadow-light);
}
#moveToTopBtn:active {
     box-shadow: 
        inset var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        inset calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}


/* Submission Detail Page Specific Table */
.submission-answers-table {
}
.submission-answers-table th {
}
.submission-answers-table td:first-child { 
    font-weight: 500;
    color: var(--neumorphic-text-color);
}
.submission-answers-table td pre { 
    background-color: var(--neumorphic-bg);
    padding: 10px;
    border-radius: var(--neumorphic-border-radius);
    box-shadow: 
        inset 2px 2px 4px var(--neumorphic-shadow-dark),
        inset -2px -2px 4px var(--neumorphic-shadow-light);
    white-space: pre-wrap;       
    word-wrap: break-word;       
    color: var(--neumorphic-text-color);
    font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
}

/* Styles for sortable table headers in submissions list */
#submissionsTable th[data-sort-by] {
    cursor: pointer;
    position: relative; 
}
#submissionsTable th[data-sort-by]:hover {
    color: var(--neumorphic-primary-color);
}
#submissionsTable th .sort-arrow { 
    font-size: 0.8em;
    margin-left: 5px;
    color: var(--neumorphic-primary-color);
}

/* Styling for dynamic category sub-headers in the questionnaire */
.category-subheader {
    font-size: 1.5em; 
    color: var(--neumorphic-primary-color, #0056b3); 
    margin-top: 30px; 
    margin-bottom: 15px; 
    padding-bottom: 10px;
    border-bottom: 2px solid var(--neumorphic-primary-color, #0056b3);
    text-align: left; 
}

.questionnaire-title {
}

.question-item {
    margin-bottom: 20px; 
}

/* Category Sub-Header Navigation */
.category-navigation {
    margin-bottom: 25px;
    padding: 10px 0;
    border-bottom: 1px solid var(--neumorphic-bg-darker, #ccc); 
    text-align: center; 
}

.category-navigation ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
    display: flex; 
    flex-wrap: wrap; 
    justify-content: center; 
    gap: 10px; 
}

.category-navigation ul li {
    display: inline-block; 
}

.category-navigation ul li a {
    text-decoration: none;
    padding: 8px 15px;
    color: var(--neumorphic-text-color, #333); 
    background-color: var(--neumorphic-bg, #e0e5ec); 
    border-radius: var(--neumorphic-border-radius, 12px); 
    font-weight: 500;
    transition: all 0.3s ease;
    box-shadow: 
        3px 3px 6px var(--neumorphic-shadow-dark, rgba(163,177,198,0.6)),
        -3px -3px 6px var(--neumorphic-shadow-light, rgba(255,255,255,0.7));
}

.category-navigation ul li a:hover,
.category-navigation ul li a:focus { 
    color: var(--neumorphic-primary-color, #007bff); 
    box-shadow: 
        inset 2px 2px 5px var(--neumorphic-shadow-dark, rgba(163,177,198,0.6)),
        inset -2px -2px 5px var(--neumorphic-shadow-light, rgba(255,255,255,0.7));
}

.category-subheader, .step-category-header { 
    scroll-margin-top: 80px; 
    font-size: 1.5em; 
    color: var(--neumorphic-primary-color, #0056b3); 
    margin-top: 30px; 
    margin-bottom: 15px; 
    padding-bottom: 10px;
    border-bottom: 2px solid var(--neumorphic-primary-color, #0056b3);
    text-align: left; 
}

/* Progress Bar Styles */
.progress-bar-container {
    width: 100%;
    background-color: var(--neumorphic-bg-darker, #ddd); 
    border-radius: var(--neumorphic-border-radius, 12px);
    margin-bottom: 25px;
    padding: 3px; 
    box-shadow: 
        inset 2px 2px 5px var(--neumorphic-shadow-dark, rgba(163,177,198,0.6)),
        inset -2px -2px 5px var(--neumorphic-shadow-light, rgba(255,255,255,0.7));
}

.progress-bar {
    height: 25px;
    line-height: 25px; 
    text-align: center;
    font-weight: bold;
    color: white;
    background-color: var(--neumorphic-primary-color, #4CAF50); 
    border-radius: calc(var(--neumorphic-border-radius, 12px) - 3px); 
    transition: width 0.4s ease;
    box-shadow: 
        2px 2px 5px var(--neumorphic-shadow-dark, rgba(163,177,198,0.6)),
        -2px -2px 5px var(--neumorphic-shadow-light, rgba(255,255,255,0.7));
}


.form-navigation-buttons {
    margin-top: 30px; 
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.form-navigation-buttons button, .form-navigation-buttons .button-link {
    min-width: 120px; 
    text-align: center;
}

/* Visually hidden class for screen reader text */
.visually-hidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    white-space: nowrap; 
}
/* Styles for the "Order" column and move arrows in tables */
table th.sort-order-header, 
table td.sort-order-cell {
    text-align: center; /* Center the order number and arrows */
    white-space: nowrap; /* Prevent wrapping of arrows and number */
}

table td.sort-order-cell .sort-order-number {
    display: inline-block;
    min-width: 20px; /* Ensure some space for the number */
    text-align: center;
}

table td.sort-order-cell a.move-arrow {
    display: inline-block;
    text-decoration: none;
    color: var(--neumorphic-primary-color);
    font-weight: bold;
    font-size: 1.3em; /* Make arrows a bit larger */
    padding: 2px 5px; /* Small padding to make them easier to click */
    border-radius: 8px; /* Softer radius for arrows */
    background-color: var(--neumorphic-bg);
    box-shadow: 1px 1px 3px var(--neumorphic-shadow-dark), -1px -1px 3px var(--neumorphic-shadow-light);
    transition: all 0.2s ease-in-out;
    line-height: 1; /* Ensure arrow is centered vertically */
    margin: 0 3px; /* Space around arrows */
}

table td.sort-order-cell a.move-arrow:hover {
    color: var(--neumorphic-primary-color-darker);
    box-shadow: inset 1px 1px 2px var(--neumorphic-shadow-dark), inset -1px -1px 2px var(--neumorphic-shadow-light);
}

table td.sort-order-cell span.move-arrow.disabled {
    display: inline-block;
    color: var(--neumorphic-bg-darker); /* Muted color for disabled arrows */
    font-weight: bold;
    font-size: 1.3em;
    padding: 2px 5px;
    line-height: 1;
    margin: 0 3px;
    cursor: default; /* Indicate it's not clickable */
}

/* General styling for action links in tables (Edit, Enable/Disable) */
table td.actions a { 
    margin-right: 8px; /* Reduced from 10px to fit better with move arrows */
    /* Other action link styles remain as previously defined */
}

/* Toast Notification Styles */
/* #toast-notification-area is defined inline in edit_form.php for now */
/* You can move its positioning to CSS if preferred */

.toast-message {
    background-color: var(--neumorphic-bg-lighter, #f8f9fa);
    color: var(--neumorphic-text-color);
    padding: 15px 20px;
    margin-bottom: 10px;
    border-radius: var(--neumorphic-border-radius, 12px);
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
    opacity: 0;
    transform: translateY(-20px);
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
    display: flex;
    justify-content: space-between;
    align-items: center;
    min-width: 250px;
}

.toast-message.show {
    opacity: 1;
    transform: translateY(0);
}

.toast-message.success {
    /* background-color: #d4edda; */ /* Using neumorphic bg, color indicates type */
    color: var(--neumorphic-success-color, #155724);
    /* border-left: 5px solid var(--neumorphic-success-color, #28a745); */
}

.toast-message.error {
    color: var(--neumorphic-danger-color, #721c24);
    /* border-left: 5px solid var(--neumorphic-danger-color, #dc3545); */
}
.toast-message.orange { /* For warnings or less critical errors */
    color: var(--neumorphic-warning-color, #fd7e14);
}
.toast-message.info { /* Default, if no specific type */
    color: var(--neumorphic-primary-color, #007bff);
}


.toast-close-button {
    background: none;
    border: none;
    color: inherit; /* Inherit color from parent toast type */
    font-size: 1.5em;
    line-height: 1;
    cursor: pointer;
    padding: 0 0 0 15px; /* Space to the left of the X */
    opacity: 0.7;
    transition: opacity 0.2s ease;
}
.toast-close-button:hover {
    opacity: 1;
}

/* Visually hidden class for screen reader text (if not already present) */
.visually-hidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    white-space: nowrap; 
}
/* ============================================= */
/* Phase 3 - Form Editor Sections & DataTables  */
/* ============================================= */

/* --- Card Navigation / Tab System --- */
.admin-nav {
    display: flex;
    justify-content: center;
    gap: 15px;
    margin-bottom: 25px;
    border-bottom: 2px solid var(--neumorphic-bg-darker);
    padding-bottom: 15px;
}
.admin-nav .button-link {
    background-color: var(--neumorphic-bg);
    color: var(--neumorphic-text-color);
    padding: 10px 20px;
    border-radius: var(--neumorphic-border-radius);
    text-decoration: none;
    font-weight: 500;
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
    transition: all 0.2s ease-in-out;
}
.admin-nav .button-link.active,
.admin-nav .button-link:hover {
    box-shadow: 
        inset var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        inset calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
    color: var(--neumorphic-primary-color);
}
.admin-section {
    display: none;
    padding: 20px;
    margin-top: 15px;
    border-radius: var(--neumorphic-border-radius);
    background: var(--neumorphic-bg);
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}
.admin-section.active {
    display: block;
}


/* --- DataTables Neumorphic Styling --- */

/* Wrapper for the entire table controls */
.dataTables_wrapper {
    padding: 10px;
}

/* "Show X entries" dropdown and Search box styling */
.dataTables_length select,
.dataTables_filter input {
    background-color: var(--neumorphic-bg);
    border: none;
    padding: 8px 12px;
    border-radius: var(--neumorphic-border-radius);
    box-shadow: 
        inset 3px 3px 6px var(--neumorphic-bg-darker), 
        inset -3px -3px 6px var(--neumorphic-shadow-light);
    color: var(--neumorphic-text-color);
    margin: 0 5px;
}

.dataTables_length select:focus,
.dataTables_filter input:focus {
    outline: none;
    box-shadow: 
        inset var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        inset calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
}

/* Labels for "Show" and "Search" */
.dataTables_length label,
.dataTables_filter label {
    color: var(--neumorphic-text-color);
    font-weight: 500;
}

/* Pagination container */
.dataTables_paginate {
    padding-top: 15px;
}

/* Pagination buttons */
.dataTables_paginate .paginate_button {
    background: var(--neumorphic-bg);
    border: none !important; /* Override DataTables default border */
    border-radius: var(--neumorphic-border-radius) !important;
    box-shadow: 
        3px 3px 6px var(--neumorphic-shadow-dark),
        -3px -3px 6px var(--neumorphic-shadow-light);
    color: var(--neumorphic-text-color) !important;
    margin: 0 5px;
    padding: 8px 14px !important;
    transition: all 0.2s ease-in-out;
}

/* Hover state for pagination buttons */
.dataTables_paginate .paginate_button:hover {
    background: var(--neumorphic-bg-lighter);
    box-shadow: 
        1px 1px 3px var(--neumorphic-shadow-dark),
        -1px -1px 3px var(--neumorphic-shadow-light);
}

/* Active (current page) pagination button */
.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover {
    background: var(--neumorphic-primary-color) !important;
    color: #fff !important;
    box-shadow: 
        inset 2px 2px 4px var(--neumorphic-primary-color-darker),
        inset -2px -2px 4px #6496ff; /* A lighter shade for the inset highlight */
}

/* Disabled pagination buttons */
.dataTables_paginate .paginate_button.disabled,
.dataTables_paginate .paginate_button.disabled:hover {
    box-shadow: none;
    background: var(--neumorphic-bg-darker);
    color: #999 !important;
    cursor: default;
}

/* Table header sorting icons */
table.dataTable thead .sorting,
table.dataTable thead .sorting_asc,
table.dataTable thead .sorting_desc {
    background-image: none !important; /* Remove default arrow images */
}

table.dataTable thead th {
    position: relative;
    padding-right: 25px !important; /* Make space for our custom arrows */
}

table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.2em;
    opacity: 0.4;
}

table.dataTable thead .sorting:after { content: '↕'; }
table.dataTable thead .sorting_asc:after { content: '▲'; opacity: 1; color: var(--neumorphic-primary-color); }
table.dataTable thead .sorting_desc:after { content: '▼'; opacity: 1; color: var(--neumorphic-primary-color); }

/* ============================================= */
/* Form Status Badges                            */
/* ============================================= */

.status-badge {
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 0.85em;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #fff;
    vertical-align: middle;
    /* Adding a subtle shadow to lift the badge slightly */
    box-shadow: 1px 1px 2px rgba(0,0,0,0.1);
}

/* A neutral, muted gray for drafts */
.status-draft {
    background-color: #7a8b99; 
}

/* A clear, positive green for published forms */
.status-published {
    background-color: #28a745; 
}

/* A soft orange for archived forms to indicate they are inactive but available */
.status-archived {
    background-color: #fd7e14; 
}
/* ============================================= */
/* Sticky Header                                 */
/* ============================================= */

header {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1020; /* High z-index to stay on top of other content */
    background-color: var(--neumorphic-bg); /* Ensure it has a solid background */
    /* Add a subtle shadow to indicate it's a separate layer */
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); 
}

/* Add some top margin to the main container to prevent content from
   initially hiding behind the sticky header on page load */
.container {
    margin-top: 20px;
}
/* --- Draggable Category List Styling --- */
#manage-categories-section .category-list {
    list-style: none;
    padding: 0;
    max-width: 600px;
    margin: 20px auto;
}

#manage-categories-section .category-list li {
    background-color: var(--neumorphic-bg-lighter);
    padding: 15px;
    margin-bottom: 10px;
    border-radius: var(--neumorphic-border-radius);
    box-shadow: 
        var(--neumorphic-shadow-distance) var(--neumorphic-shadow-distance) var(--neumorphic-blur) var(--neumorphic-shadow-dark),
        calc(-1 * var(--neumorphic-shadow-distance)) calc(-1 * var(--neumorphic-shadow-distance)) var(--neumorphic-blur) var(--neumorphic-shadow-light);
    display: flex;
    align-items: center;
    gap: 15px;
    font-weight: 500;
    cursor: grab;
}

#manage-categories-section .category-list li:active {
    cursor: grabbing;
}

/* Style for the drag handle */
#manage-categories-section .drag-handle {
    font-size: 1.5em;
    color: #a0a0a0;
    display: inline-block;
    line-height: 1;
}
#manage-categories-section .drag-handle:before {
    content: '::'; /* A common drag handle icon */
    letter-spacing: -2px;
}


/* SortableJS ghost class for styling the item being dragged */
.sortable-ghost {
    opacity: 0.4;
    background: #c8ebfb;
}

.sortable-drag {
    opacity: 1 !important;
}

