/* ── Dashboard content container ────────────── */
/* Applied to the injected content wrapper in both sidepanel and standalone pages */
.admin-dashboard-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

/* ── PIN overlay ────────────────────────────── */
.admin-pin-overlay {
    position: fixed;
    inset: 0;
    background: var(--warm-white);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--space-xl);
    z-index: calc(var(--z-admin-panel) + 5);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--duration-normal) ease;
}

.admin-pin-overlay.active {
    opacity: 1;
    pointer-events: auto;
}

.admin-pin-modal {
    max-width: 280px;
    width: 100%;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-lg);
}

.admin-pin-title {
    font-size: var(--text-caption);
    font-weight: 300;
    letter-spacing: var(--ls-heading);
    text-transform: lowercase;
    color: var(--text-muted);
}

.admin-pin-input {
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-subheading);
    font-weight: 300;
    letter-spacing: 0.5em;
    color: var(--text-primary);
    background: none;
    border: none;
    border-bottom: 1px solid var(--accent);
    padding: var(--space-xs) 0;
    width: 8rem;
    text-align: center;
    outline: none;
    transition: border-color var(--duration-normal) ease;
    -webkit-text-security: disc;
    -moz-appearance: textfield;
}

.admin-pin-input::-webkit-outer-spin-button,
.admin-pin-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.admin-pin-input:focus {
    border-bottom-color: var(--text-primary);
}

.admin-pin-status {
    font-size: var(--text-small);
    color: var(--text-muted);
    letter-spacing: var(--ls-caption);
    font-style: italic;
    min-height: 1.2em;
}

.admin-pin-submit {
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-small);
    font-weight: 300;
    letter-spacing: var(--ls-button);
    text-transform: lowercase;
    background: none;
    border: 1px solid var(--accent);
    color: var(--text-primary);
    padding: var(--space-xs) var(--space-lg);
    cursor: pointer;
    transition: all var(--duration-normal) ease;
}

.admin-pin-submit:hover:not(:disabled) {
    background: var(--accent);
    color: var(--warm-white);
}

.admin-pin-submit:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* ── Shared admin styles ──────────────────────── */
.admin-session-status {
    font-size: var(--text-detail);
    font-weight: 300;
    letter-spacing: 0.06em;
    color: var(--text-muted);
    padding: 0.35rem var(--space-sm);
}

.admin-session-status.active {
    color: var(--accent);
}

.admin-divider {
    border: none;
    border-top: 1px solid var(--warm-grey);
    margin: var(--space-2xs) 0;
}

.admin-section-label {
    font-size: var(--text-detail);
    font-weight: 400;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--text-muted);
    opacity: 0.7;
}

.admin-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.admin-status-dot {
    width: 7px;
    height: 7px;
    border-radius: var(--radius-full);
    background: var(--warm-grey);
}

.admin-status-dot.alive {
    background: var(--success);
}

.admin-status-dot.unresponsive {
    background: var(--error);
}

.admin-metrics {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-small);
    letter-spacing: 0.06em;
    color: var(--text-muted);
    padding: var(--space-xs) var(--space-sm);
    background: rgba(0,0,0,0.03);
    border: 1px solid var(--warm-grey);
}

.admin-metrics .metric-value {
    font-variant-numeric: tabular-nums;
}

.admin-metrics .metric-warn {
    color: var(--error);
    font-weight: 500;
}

/* Audio level meter */
.admin-audio-meter {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.admin-level-bars {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.admin-level-track {
    height: 4px;
    background: rgba(0, 0, 0, 0.06);
    border-radius: 2px;
    overflow: hidden;
}

.admin-level-fill {
    height: 100%;
    width: 0%;
    background: var(--accent-active);
    border-radius: 2px;
    transition: width var(--duration-fast) ease-out;
}

.admin-level-fill.hot {
    background: var(--error);
}

/* Recording indicator */
.admin-record-indicator {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-detail);
    font-weight: 300;
    letter-spacing: var(--ls-body);
    color: var(--text-muted);
    flex-shrink: 0;
}

.record-dot {
    display: inline-block;
    width: 7px;
    height: 7px;
    border-radius: var(--radius-full);
    background: var(--text-muted);
    transition: background var(--duration-normal) ease;
}

.admin-record-indicator.recording {
    color: var(--error);
}

.admin-record-indicator.recording .record-dot {
    background: var(--error);
    animation: record-pulse 1.5s ease-in-out infinite;
}

@keyframes record-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

/* Toggle switch */
.admin-toggle-switch {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    cursor: pointer;
    user-select: none;
}

.admin-toggle-switch input { display: none; }

.toggle-slider {
    position: relative;
    width: 36px;
    height: 20px;
    background: var(--warm-grey);
    border-radius: 10px;
    transition: background var(--duration-normal) ease;
    flex-shrink: 0;
}

.toggle-slider::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    background: var(--warm-white);
    border-radius: var(--radius-full);
    transition: transform var(--duration-normal) ease;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.admin-toggle-switch input:checked + .toggle-slider {
    background: var(--error);
}

.admin-toggle-switch input:checked + .toggle-slider::after {
    transform: translateX(16px);
}

.admin-toggle-switch input:disabled + .toggle-slider {
    opacity: 0.4;
}

.admin-toggle-switch.toggle-neutral input:checked + .toggle-slider {
    background: var(--accent-active);
}

.toggle-label {
    font-size: var(--text-small);
    letter-spacing: var(--ls-body);
    color: var(--text-muted);
    font-style: italic;
}

/* sclang trigger lock */
.admin-sclang-lock {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-2xs) 0;
    margin-left: var(--space-2xs);
}

.admin-sclang-lock-reason {
    font-size: var(--text-small);
    font-style: italic;
    color: var(--accent-active);
    letter-spacing: 0.06em;
}

.admin-sclang-lock-clear {
    font-size: var(--text-detail);
    padding: 0.15rem var(--space-xs);
}

/* Onboarding thresholds */
.admin-onboarding-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.15rem 0;
}

.admin-onboarding-label {
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-detail);
    letter-spacing: var(--ls-heading);
    text-transform: uppercase;
    color: var(--text-muted);
}

/* Action buttons */
.admin-action-btn {
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-small);
    font-weight: 300;
    letter-spacing: var(--ls-button);
    text-transform: lowercase;
    background: none;
    border: 1px solid var(--accent);
    color: var(--text-primary);
    padding: 0.625rem var(--space-lg);
    cursor: pointer;
    transition: all var(--duration-normal) ease;
    text-align: center;
    width: 100%;
}

@media (hover: hover) {
    .admin-action-btn:hover:not(:disabled) {
        background: var(--accent);
        color: var(--warm-white);
    }
}

.admin-action-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.admin-action-danger {
    border-color: var(--error);
    color: var(--error);
}

@media (hover: hover) {
    .admin-action-danger:hover:not(:disabled) {
        background: var(--error);
        color: var(--warm-white);
    }
}

.admin-action-btn:focus { outline: none; }

.admin-action-btn.waiting {
    opacity: 0.6;
    cursor: not-allowed;
    font-style: italic;
}

.admin-action-btn.success {
    border-color: var(--success);
    color: var(--success);
}

/* ── Utility classes ────────────────────────── */

.admin-row {
    display: flex;
    gap: var(--space-xs);
}

.admin-field-label {
    font-size: var(--text-detail);
    color: var(--text-muted);
}

.admin-muted-text {
    font-size: var(--text-small);
    color: var(--text-muted);
}

.admin-btn-compact {
    width: auto;
    padding: 0 var(--space-md);
}

.admin-btn-tiny {
    font-size: var(--text-detail);
    padding: var(--space-2xs);
}

.admin-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-xs);
    font-size: var(--text-small);
    padding: var(--space-2xs) 0;
    border-bottom: 1px solid var(--warm-grey);
}

/* Capacity */
.admin-capacity-value {
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-small);
    font-weight: 300;
    letter-spacing: var(--ls-body);
    color: var(--text-primary);
    cursor: pointer;
    padding: 0.125rem var(--space-xs);
    border-bottom: 1px dashed var(--accent);
    transition: color var(--duration-fast) ease;
}

.admin-capacity-value:hover {
    color: var(--accent-active);
}

.admin-capacity-value.updating {
    color: var(--text-muted);
    font-style: italic;
    border-bottom-color: transparent;
    cursor: default;
}

.admin-capacity-editor {
    display: none;
    align-items: center;
    gap: var(--space-xs);
}

.admin-capacity-editor.active {
    display: flex;
}

.admin-capacity-edit-input {
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-caption);
    font-weight: 300;
    color: var(--text-primary);
    background: none;
    border: none;
    border-bottom: 1px solid var(--accent);
    padding: 0.375rem 0;
    width: 3.5rem;
    text-align: center;
    outline: none;
    -moz-appearance: textfield;
}

.admin-capacity-edit-input::-webkit-outer-spin-button,
.admin-capacity-edit-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.admin-capacity-ok {
    width: auto !important;
    padding: var(--space-xs) var(--space-sm) !important;
    font-size: var(--text-small) !important;
}

/* Filtered dropdown */
.admin-dropdown-wrapper {
    position: relative;
}

.admin-dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    max-height: 180px;
    overflow-y: auto;
    background: var(--warm-white);
    border: 1px solid var(--warm-grey);
    z-index: 10;
}

.admin-dropdown.open {
    display: block;
}

.admin-dropdown-item {
    padding: var(--space-xs) var(--space-sm);
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-small);
    color: var(--text-primary);
    cursor: pointer;
}

.admin-dropdown-item.highlighted {
    background: var(--accent-subtle);
}

/* Lead sheet */
.admin-lead-sheet-section {
    margin-top: var(--space-xs);
}

.admin-lead-sheet-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-2xs);
    margin-top: var(--space-xs);
}

.admin-lead-sheet-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-2xs) var(--space-xs);
    border: 1px solid var(--border);
    font-size: var(--text-small);
    font-family: 'Cormorant', Georgia, serif;
    color: var(--text-secondary);
}

.admin-lead-sheet-item.active {
    border-color: var(--accent);
    color: var(--accent);
}

.admin-lead-sheet-name {
    flex: 1;
}

.admin-lead-sheet-remove {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: var(--text-caption);
    padding: 0 var(--space-2xs);
    opacity: 0.5;
}

.admin-lead-sheet-remove:hover {
    opacity: 1;
    color: var(--accent);
}

.admin-lead-sheet-status {
    margin-top: var(--space-xs);
    font-size: var(--text-small);
    color: var(--text-secondary);
    font-family: 'Cormorant', Georgia, serif;
}

/* Modal buttons row */
.admin-modal-buttons {
    display: flex;
    gap: var(--space-xs);
}

.admin-modal-buttons .admin-action-btn {
    flex: 1;
}

/* Alert */
.admin-alert {
    position: fixed;
    top: var(--space-xl);
    left: 50%;
    transform: translateX(-50%);
    background: var(--warm-white);
    border: 1px solid var(--error);
    padding: var(--space-md) var(--space-xl);
    z-index: var(--z-toast);
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-caption);
    letter-spacing: var(--ls-body);
    color: var(--error);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--duration-normal) ease;
}

.admin-alert.visible {
    opacity: 1;
    pointer-events: auto;
}

/* Toast */
.admin-toast {
    position: fixed;
    bottom: var(--space-xl);
    left: 50%;
    transform: translateX(-50%);
    background: var(--text-primary);
    color: var(--warm-white);
    padding: var(--space-xs) var(--space-lg);
    font-size: var(--text-small);
    letter-spacing: 0.06em;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--duration-normal) ease;
    z-index: var(--z-toast);
}

.admin-toast.visible {
    opacity: 1;
}

/* ── Modals (trigger, feature, geofence) ────── */
.admin-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-lg);
    z-index: var(--z-toast);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--duration-normal) ease;
}

.admin-modal-overlay.active {
    opacity: 1;
    pointer-events: auto;
}

.admin-modal {
    background: var(--warm-white);
    border: 1px solid var(--warm-grey);
    max-width: 480px;
    width: 100%;
    max-height: 80vh;
    overflow-y: auto;
    padding: var(--space-lg);
}

.admin-modal.admin-modal--compact {
    max-height: 70vh;
}

.admin-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-md);
}

.admin-panel-title {
    font-size: var(--text-small);
    font-weight: 300;
    letter-spacing: var(--ls-heading);
    text-transform: lowercase;
    color: var(--text-muted);
}

.admin-close {
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-2xs);
    color: var(--text-muted);
    transition: color var(--duration-normal) ease;
}

@media (hover: hover) {
    .admin-close:hover {
        color: var(--text-primary);
    }
}

.admin-close svg {
    width: 16px;
    height: 16px;
    stroke-width: 1.5;
}

.admin-modal table {
    width: 100%;
    border-collapse: collapse;
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-small);
    letter-spacing: 0.04em;
}

.admin-modal th {
    font-size: var(--text-detail);
    font-weight: 400;
    letter-spacing: var(--ls-button);
    text-transform: uppercase;
    color: var(--text-muted);
    text-align: left;
    padding: var(--space-2xs) var(--space-xs);
    border-bottom: 1px solid var(--warm-grey);
}

.admin-modal td {
    padding: 0.4rem var(--space-xs);
    color: var(--text-primary);
    vertical-align: middle;
    border-bottom: 1px solid rgba(0, 0, 0, 0.04);
}

.admin-modal .admin-toggle-switch {
    gap: 0;
}

.admin-modal-play-btn {
    width: auto !important;
    padding: var(--space-2xs) 0.6rem !important;
    font-size: var(--text-small) !important;
}

.spawn-controls {
    display: inline-flex;
    align-items: center;
    gap: 2px;
}

.spawn-btn {
    width: 22px;
    height: 22px;
    border: 1px solid var(--warm-grey);
    border-radius: var(--radius-sm);
    background: none;
    color: var(--text-primary);
    font-size: var(--text-small);
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}

.spawn-btn:disabled {
    opacity: 0.3;
    cursor: default;
}

.spawn-count {
    display: inline-block;
    min-width: 18px;
    text-align: center;
    font-size: var(--text-small);
    color: var(--text-muted);
}

/* Detail view */
.detail-back-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-small);
    letter-spacing: var(--ls-caption);
    cursor: pointer;
    padding: var(--space-2xs) 0;
    margin-bottom: var(--space-xs);
}

.detail-title {
    font-size: var(--text-caption);
    font-weight: 400;
    letter-spacing: var(--ls-body);
    margin-bottom: 0.15rem;
}

.detail-code {
    font-size: var(--text-small);
    color: var(--text-muted);
    letter-spacing: 0.04em;
    margin-bottom: var(--space-md);
}

.detail-fields {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.detail-field {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-xs);
}

.detail-field-label {
    font-size: var(--text-small);
    color: var(--text-muted);
    letter-spacing: 0.04em;
    flex: 1;
}

.stepper {
    display: inline-flex;
    align-items: center;
    gap: 0;
}

.stepper-btn {
    width: 44px;
    height: 44px;
    border: 1px solid var(--warm-grey);
    background: none;
    color: var(--text-primary);
    font-size: var(--text-button);
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}

.stepper-minus { border-radius: 4px 0 0 4px; }
.stepper-plus { border-radius: 0 4px 4px 0; }
.stepper-btn:active { background: var(--warm-grey); }

.stepper-input {
    width: 52px;
    height: 44px;
    border: 1px solid var(--warm-grey);
    border-left: none;
    border-right: none;
    background: none;
    text-align: center;
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-small);
    color: var(--text-primary);
    -moz-appearance: textfield;
}

.stepper-input::-webkit-inner-spin-button,
.stepper-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.detail-apply-btn {
    width: 100%;
    margin-top: var(--space-xs);
}

.detail-link {
    cursor: pointer;
    text-decoration: underline;
    text-decoration-color: var(--warm-grey);
    text-underline-offset: 2px;
}

.admin-status {
    font-size: var(--text-small);
    letter-spacing: var(--ls-body);
    color: var(--text-muted);
    font-style: italic;
}

/* ── Sensor lab recordings ─────────────────── */

.sensor-recordings-section {
    margin-top: var(--space-xs);
}

.sensor-recordings-toggle {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    background: none;
    border: none;
    padding: 0.2rem 0;
    cursor: pointer;
    width: 100%;
}

.sensor-recordings-chevron {
    transition: transform var(--duration-fast) ease;
    color: var(--text-muted);
    flex-shrink: 0;
}

.sensor-recordings-toggle.open .sensor-recordings-chevron {
    transform: rotate(90deg);
}

.sensor-recordings-title {
    font-size: var(--text-detail);
    letter-spacing: var(--ls-button);
    color: var(--text-muted);
    text-transform: lowercase;
}

.sensor-recordings-count {
    font-size: var(--text-detail);
    color: var(--text-muted);
}

.sensor-recordings-refresh-btn {
    margin-left: auto;
    background: none;
    border: none;
    padding: 0.2rem;
    cursor: pointer;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    border-radius: var(--radius-sm);
}
.sensor-recordings-refresh-btn:hover {
    color: var(--text-primary);
    background: rgba(0, 0, 0, 0.05);
}

.sensor-recordings-body {
    margin-top: 0.4rem;
}

.sensor-recordings-list {
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid var(--warm-grey);
    border-radius: 4px;
    background: var(--warm-white);
}

.sensor-recordings-empty {
    display: block;
    padding: var(--space-sm);
    font-size: var(--text-small);
    color: var(--text-muted);
    font-style: italic;
    text-align: center;
}

.sensor-recording-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-xs) 0.6rem;
    gap: var(--space-xs);
    border-bottom: 1px solid var(--warm-grey);
}

.sensor-recording-item:last-child {
    border-bottom: none;
}

.sensor-recording-info {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.sensor-recording-name {
    font-size: var(--text-small);
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sensor-recording-date {
    font-size: var(--text-detail);
    color: var(--text-muted);
}

.sensor-recording-actions {
    display: flex;
    gap: 0.4rem;
    flex-shrink: 0;
}

.sensor-recording-icon-btn {
    background: none;
    border: none;
    padding: var(--space-2xs);
    cursor: pointer;
    color: var(--text-muted);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
}

.sensor-recording-icon-btn:hover {
    color: var(--text-primary);
    background: rgba(0, 0, 0, 0.05);
}

.sensor-recording-delete:hover {
    color: var(--error-red, #c44);
}

/* ── Debug log categories ────────────────── */
.debug-log-categories {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-2xs);
}
.debug-cat-cell {
    font-family: 'Cormorant', Georgia, serif;
    font-size: var(--text-small);
    letter-spacing: 0.06em;
    text-align: center;
    padding: 0.35rem var(--space-2xs);
    border: 1px solid var(--warm-grey);
    background: none;
    color: var(--text-muted);
    cursor: pointer;
    transition: all var(--duration-fast) ease;
}
.debug-cat-cell.selected {
    background: var(--accent-active);
    border-color: var(--accent-active);
    color: var(--warm-white);
}
.debug-cat-cell.throttled {
    background: none;
    border-color: var(--accent-active);
    border-style: dashed;
    color: var(--accent-active);
}

/* ── Debug stop button (floating, lower left) ── */
.debug-stop-btn {
    position: fixed;
    bottom: var(--space-lg);
    left: var(--space-lg);
    z-index: 10000;
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    border: 2px solid rgba(255, 60, 60, 0.6);
    background: rgba(0, 0, 0, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.debug-stop-dot {
    width: 12px;
    height: 12px;
    border-radius: var(--radius-full);
    background: #e33;
    animation: debug-pulse 1.2s ease-in-out infinite;
}
@keyframes debug-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}
