/* Enhanced CSS styles for Network Tools Application - FIXED VERSION */

/* SIDEBAR SCROLLBAR FIX */
.sidebar {
    width: var(--sidebar-width);
    background: var(--sidebar-bg);
    color: var(--sidebar-text);
    position: fixed;
    left: 0;
    top: 0;
    height: 100vh;
    transition: all 0.3s ease;
    z-index: 1000;
    overflow-y: auto;
    overflow-x: hidden; /* FIXED: Prevent horizontal scrollbar */
    display: flex;
    flex-direction: column;
}

.sidebar.collapsed {
    width: var(--sidebar-collapsed-width);
    overflow-y: hidden; /* FIXED: Hide scrollbar when collapsed */
}

/* Enhanced sidebar hover for collapsed state */
.sidebar.collapsed.hover-expanded {
    width: var(--sidebar-width);
    box-shadow: 4px 0 12px rgba(0,0,0,0.15);
    z-index: 1001;
    overflow-y: auto; /* Re-enable scrollbar when expanded on hover */
}

.sidebar-header {
    padding: 20px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0; /* FIXED: Prevent header from shrinking */
    min-height: 60px; /* Ensure consistent header height */
}

.nav-menu {
    padding: 0;
    list-style: none;
    flex: 1; /* FIXED: Allow menu to take remaining space */
    overflow-y: auto; /* Allow scrolling within nav menu only */
    overflow-x: hidden;
}

.sidebar.collapsed .nav-menu {
    overflow-y: hidden; /* Hide scrolling when collapsed */
}

.sidebar.collapsed.hover-expanded .nav-menu {
    overflow-y: auto; /* Re-enable scrolling on hover */
}

.nav-item {
    display: block;
    padding: 16px 20px;
    color: var(--sidebar-text);
    text-decoration: none;
    border: none;
    background: none;
    width: 100%;
    text-align: left;
    cursor: pointer;
    transition: background 0.3s ease;
    font-size: 14px;
    position: relative;
    white-space: nowrap; /* FIXED: Prevent text wrapping */
    flex-shrink: 0; /* Prevent nav items from shrinking */
}

.nav-item .icon {
    display: inline-block;
    width: 20px;
    margin-right: 12px;
    text-align: center;
    flex-shrink: 0; /* FIXED: Prevent icon from shrinking */
}

.nav-item .text {
    transition: opacity 0.3s ease;
    display: inline-block;
}

.sidebar.collapsed .nav-item .text {
    opacity: 0;
    pointer-events: none; /* FIXED: Prevent interaction with hidden text */
    width: 0; /* Collapse text width */
    overflow: hidden;
}

.sidebar.collapsed.hover-expanded .nav-item .text {
    opacity: 1;
    pointer-events: auto;
    width: auto;
}

/* Enhanced form styling */
.form-input:invalid {
    border-color: var(--danger-color);
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1);
}

.form-input:valid {
    border-color: var(--success-color);
}

/* Enhanced button animations */
.btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

/* Enhanced table styles for results */
.data-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-primary);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    margin-top: 16px;
}

.data-table th,
.data-table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border-color);
    position: relative;
    word-wrap: break-word;
    max-width: 300px;
}

.data-table th {
    background: var(--bg-secondary);
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-primary);
    position: sticky;
    top: 0;
    z-index: 10;
    user-select: none;
}

.data-table th[onclick] {
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.data-table th[onclick]:hover {
    background: var(--border-color);
}

.data-table th.sortable-column {
    cursor: pointer;
}

.sortable-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
}

.sort-indicator {
    opacity: 0.7;
    font-size: 12px;
    line-height: 1;
    flex-shrink: 0;
}

.data-table td {
    cursor: pointer;
    transition: all 0.2s ease;
    color: var(--text-primary);
}

.data-table td:hover {
    background-color: var(--bg-secondary);
    transform: scale(1.02);
}

.data-table td.copyable-cell:hover::after {
    content: '📋';
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0.7;
    font-size: 12px;
}

.data-table tr:last-child td {
    border-bottom: none;
}

/* Search filter highlight */
.highlight {
    background-color: #ffeb3b;
    color: #000;
    padding: 2px 4px;
    border-radius: 3px;
    font-weight: bold;
}

/* Status legend */
.status-legend {
    margin-top: 20px;
    padding: 16px;
    background: var(--bg-secondary);
    border-radius: 8px;
    border: 1px solid var(--border-color);
}

.status-legend h4 {
    margin-bottom: 12px;
    color: var(--text-primary);
    font-size: 16px;
}

.legend-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 8px;
}

.legend-item {
    padding: 8px;
    font-size: 14px;
    color: var(--text-secondary);
}

/* Loading states for share button */
#shareLoading {
    display: none;
}

#shareLoading.show {
    display: inline;
    animation: spin 1s linear infinite;
}

#shareBtn {
    display: inline;
}

#shareBtn.hide {
    display: none;
}

/* Results panel styling */

.result-anchor-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 8px 10px;
    margin-bottom: 10px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 10px;
    background: rgba(248, 250, 252, 0.9);
}

.result-anchor-bar.is-compact {
    padding: 4px 0 6px;
    margin-bottom: 8px;
    border: 0;
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.result-anchor-bar.is-hidden-anchor {
    height: 1px;
    min-height: 1px;
    padding: 0;
    margin: 0;
    border: 0;
    background: transparent;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

.result-anchor-copy {
    min-width: 0;
    display: flex;
    align-items: center;
}

.result-anchor-kicker {
    display: none;
}

.result-anchor-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-primary);
    overflow-wrap: anywhere;
}

.result-anchor-state {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
    background: rgba(59, 130, 246, 0.12);
    color: #1d4ed8;
}

.result-anchor-state.is-loading,
.result-anchor-state.is-progress {
    background: rgba(245, 158, 11, 0.14);
    color: #92400e;
}

.result-anchor-state.is-done {
    background: rgba(16, 185, 129, 0.14);
    color: #065f46;
}

.result-anchor-state.is-error {
    background: rgba(239, 68, 68, 0.14);
    color: #991b1b;
}

.result-primary-action-flash {
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.18) !important;
    border-radius: 10px;
}

@media (max-width: 640px) {
    .result-anchor-bar {
        flex-direction: column;
        align-items: flex-start;
    }
}

.results-panel {
    margin-top: 32px;
    background: var(--bg-primary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
    overflow: hidden;
    display: none;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.results-panel.show {
    display: block;
}


.result-region-flash {
    animation: resultRegionFlash 1.6s ease;
}

@keyframes resultRegionFlash {
    0% { box-shadow: 0 0 0 0 rgba(37,99,235,.00); }
    20% { box-shadow: 0 0 0 4px rgba(37,99,235,.14); }
    100% { box-shadow: 0 0 0 0 rgba(37,99,235,.00); }
}

.results-header {
    padding: 20px 24px;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.results-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--text-primary);
}

.results-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
    --results-action-width: auto;
    --results-action-height: 42px;
}

.results-actions-mobile-sticky {
    display: none;
}

.results-actions-compact {
    gap: 10px;
}

.results-header-stacked-mobile {
    gap: 16px;
}
.results-header-no-title {
    justify-content: flex-end;
    padding-top: 14px;
    padding-bottom: 14px;
}


.export-menu-wrap {
    position: relative;
}

.results-actions > .btn,
.results-actions > .export-menu-wrap,
.results-actions > .domain-handoff-menu-wrap {
    flex: 0 0 auto;
    min-width: 0;
}

.results-actions .btn,
.results-actions .export-toggle,
.results-actions .domain-handoff-toggle {
    width: auto;
    min-height: var(--results-action-height);
    justify-content: center;
    padding: 10px 14px;
    font-size: 13px;
}

.export-toggle {
    white-space: nowrap;
}

.export-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 220px;
    padding: 8px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--bg-primary);
    box-shadow: 0 12px 30px rgba(0,0,0,0.14);
    display: none;
    z-index: 40;
}

.export-menu.show {
    display: grid;
    gap: 6px;
}

.export-menu button {
    appearance: none;
    border: 0;
    background: transparent;
    color: var(--text-primary);
    text-align: left;
    border-radius: 8px;
    padding: 10px 12px;
    cursor: pointer;
    font-size: 13px;
}

.export-menu button:hover {
    background: var(--bg-secondary);
}

.export-menu-divider {
    height: 1px;
    background: var(--border-color);
    margin: 4px 0;
}

.shared-insights {
    display: grid;
    gap: 16px;
    margin: 24px 0;
}

.shared-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
}

.shared-summary-card,
.shared-meta-box,
.shared-warning-box {
    border: 1px solid var(--border-color);
    border-radius: 14px;
    background: var(--bg-primary);
    box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}

.shared-summary-card {
    padding: 16px;
}

.shared-summary-label {
    font-size: 12px;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--text-secondary);
    font-weight: 700;
}

.shared-summary-value {
    margin-top: 8px;
    font-size: 20px;
    font-weight: 700;
    color: var(--text-primary);
    word-break: break-word;
}

.shared-meta-box {
    padding: 16px 18px;
    color: var(--text-primary);
    line-height: 1.55;
}

.shared-warning-box {
    padding: 16px 18px;
    border-color: rgba(255, 140, 0, 0.28);
    background: rgba(255, 140, 0, 0.08);
}

.shared-warning-title {
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 10px;
}

.shared-warning-list {
    margin: 0;
    padding-left: 18px;
    color: var(--text-primary);
}

.shared-warning-list li + li {
    margin-top: 6px;
}

.results-content {
    padding: 0;
}

/* No results message */
.no-results {
    padding: 40px 24px;
    text-align: center;
    color: var(--text-secondary);
    font-style: italic;
}

/* Status indicators */
.status-success {
    color: var(--success-color);
    font-weight: 600;
}

.status-danger {
    color: var(--danger-color);
    font-weight: 600;
}

.status-warning {
    color: var(--warning-color);
    font-weight: 600;
}

.status-info {
    color: var(--info-color);
    font-weight: 600;
}

.status-muted {
    color: var(--text-secondary);
    font-weight: 600;
}

/* Enhanced IP card styling */
/* NEW: Compact IP card styling */
.ip-card {
    text-align: center;
    padding: 48px 32px;
    background: linear-gradient(135deg, var(--primary-color), var(--info-color));
    color: white;
    border-radius: 16px;
    margin: 32px auto;
    max-width: 800px;
    width: 90%;
    box-shadow: 0 8px 32px rgba(0,123,255,0.3);
    display: block;
}

.ip-card:hover {
    transform: translateY(-2px);
}

.ip-number {
    font-size: 48px;
    font-weight: 700;
    margin-bottom: 16px;
    text-shadow: 0 2px 4px rgba(0,0,0,0.3);
    transition: all 0.2s ease;
}

.ip-number:hover {
    transform: scale(1.05);
    text-shadow: 0 4px 8px rgba(0,0,0,0.4);
}

.ip-subtitle {
    font-size: 18px;
    opacity: 0.9;
}

/* Password display styling */
.password-display {
    background: var(--bg-secondary);
    padding: 20px;
    border-radius: 8px;
    font-family: 'Monaco', 'Consolas', monospace;
    font-size: 18px;
    font-weight: 600;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 2px dashed var(--border-color);
}

.password-display:hover {
    background: var(--border-color);
    border-color: var(--primary-color);
    transform: scale(1.02);
}

.password-display::after {
    content: ' 📋';
    opacity: 0;
    transition: opacity 0.2s ease;
}

.password-display:hover::after {
    opacity: 1;
}

/* Image converter results styling */
.image-result {
    background: var(--bg-secondary);
    border-radius: 8px;
    padding: 20px;
    margin-top: 16px;
}

.image-result-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.image-result-title {
    font-weight: 600;
    color: var(--text-primary);
}

.download-btn {
    background: var(--success-color);
    color: white;
    padding: 12px 20px;
    border: none;
    border-radius: 8px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.download-btn:hover {
    background: #218838;
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

.image-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}

.info-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--border-color);
}

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

.info-label {
    font-weight: 600;
    color: var(--text-secondary);
    margin-right: 16px;
}

.info-value {
    color: var(--text-primary);
    font-weight: 500;
    text-align: right;
}

/* Loading state enhancements */
.loading-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255,255,255,0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
}

.loading-text {
    margin-left: 10px;
    color: var(--text-secondary);
}

.loading-spinner {
    display: none;
}

.loading-spinner.show {
    display: inline;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Result panel enhancements */
.results-panel .copy-indicator {
    position: absolute;
    top: 10px;
    right: 10px;
    background: var(--success-color);
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 12px;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.results-panel .copy-indicator.show {
    opacity: 1;
}

/* Pre-content styling for legacy fallbacks */
.pre-content {
    background: var(--bg-secondary);
    padding: 20px;
    border-radius: 8px;
    font-family: 'Monaco', 'Consolas', monospace;
    font-size: 13px;
    line-height: 1.5;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.pre-content:hover {
    background: var(--border-color);
}

/* NOTIFICATION FIX - Ensure notifications are completely hidden by default */
#copyNotification,
#shareNotification,
#pwaNotification {
    display: none !important;
    opacity: 0;
    visibility: hidden;
    transform: translateX(100%);
}

/* Show notifications only when explicitly shown */
#copyNotification.show,
#shareNotification.show,
#pwaNotification.show {
    display: block !important;
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
}

/* Enhanced mobile styles */
@media (max-width: 480px) {
    .content-wrapper {
        padding: 16px;
    }
    
    .tool-section {
        padding: 20px;
    }
    
    .section-title {
        font-size: 24px;
    }
    
    .form-input {
        padding: 14px;
        font-size: 16px; /* Prevents zoom on iOS */
    }
    
    .btn {
        padding: 14px 20px;
        font-size: 16px;
    }
    
    .data-table {
        font-size: 14px;
    }
    
    .data-table th,
    .data-table td {
        padding: 8px 12px;
    }
    
    .results-header {
        flex-direction: column;
        gap: 16px;
        align-items: stretch;
    }
    
    .results-actions {
        justify-content: center;
    }
    
    .ip-number {
        font-size: 36px;
    }
    
    .password-display {
        font-size: 16px;
        padding: 16px;
    }
    
    /* Mobile notification positioning */
    #copyNotification,
    #shareNotification,
    #pwaNotification {
        left: 10px;
        right: 10px;
        transform: translateY(-100%);
    }
    
    #copyNotification.show,
    #shareNotification.show,
    #pwaNotification.show {
        transform: translateY(0);
    }
    
    /* Mobile sidebar fixes */
    .sidebar {
        overflow-y: auto; /* Always allow scrolling on mobile */
    }
    
    .sidebar.collapsed {
        overflow-y: auto; /* Keep scrolling enabled on mobile even when collapsed */
    }
}

/* Enhanced mobile responsiveness for tables */
@media (max-width: 768px) {
    .data-table {
        font-size: 14px;
    }
    
    .data-table,
    .data-table thead,
    .data-table tbody,
    .data-table th,
    .data-table td,
    .data-table tr {
        display: block;
    }
    
    .data-table thead tr {
        position: absolute;
        top: -9999px;
        left: -9999px;
    }
    
    .data-table tr {
        border: 1px solid var(--border-color);
        border-radius: 8px;
        margin-bottom: 12px;
        padding: 12px;
        background: var(--bg-primary);
    }
    
    .data-table td {
        border: none;
        border-bottom: 1px solid var(--border-color);
        position: relative;
        padding-left: 50% !important;
        white-space: normal;
        text-align: left;
        max-width: none;
    }
    
    .data-table td:before {
        content: attr(data-label) ": ";
        position: absolute;
        left: 6px;
        width: 45%;
        padding-right: 10px;
        white-space: nowrap;
        font-weight: 600;
        color: var(--text-secondary);
        font-size: 12px;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }
    
    .data-table td:last-child {
        border-bottom: none;
    }
    
    /* Mobile image info grid */
    .image-info {
        grid-template-columns: 1fr;
    }
    
    .info-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }
    
    .info-value {
        text-align: left;
    }
}

/* Print styles */
@media print {
    .sidebar,
    .top-bar,
    .pwa-banner,
    .notification,
    .mobile-overlay,
    .results-actions,
    #copyNotification,
    #shareNotification,
    #pwaNotification {
        display: none !important;
    }
    
    .main-content {
        margin-left: 0 !important;
    }
    
    
.results-panel {
        box-shadow: none;
        border: 1px solid #ccc;
    }
    
    .pre-content,
    .password-display {
        background: #f8f9fa;
        border: 1px solid #dee2e6;
    }
    
    .data-table {
        box-shadow: none;
        border: 1px solid #ccc;
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    :root {
        --primary-color: #0000ff;
        --success-color: #008000;
        --danger-color: #ff0000;
        --warning-color: #ff8c00;
        --info-color: #4169e1;
    }
    
    .btn {
        border: 2px solid currentColor;
    }
    
    .form-input {
        border-width: 3px;
    }
    
    .data-table td:hover {
        background-color: #ffff00;
        color: #000000;
    }
}

/* Reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    
    .loading-spinner {
        animation: none;
    }
    
    .data-table td:hover {
        transform: none;
    }
    
    .ip-number:hover {
        transform: none;
    }
    
    .password-display:hover {
        transform: none;
    }
    
    .ip-card:hover {
        transform: none;
    }
    
    #copyNotification,
    #shareNotification,
    #pwaNotification {
        transition: none;
    }
}

/* Focus indicators for keyboard navigation */
.nav-item:focus,
.btn:focus,
.form-input:focus,
.toggle-btn:focus,
.data-table td:focus {
    outline: 3px solid var(--primary-color);
    outline-offset: 2px;
}

/* Skip link for accessibility */
.skip-link {
    position: absolute;
    top: -40px;
    left: 6px;
    background: var(--primary-color);
    color: white;
    padding: 8px;
    text-decoration: none;
    border-radius: 4px;
    z-index: 1000;
}

.skip-link:focus {
    top: 6px;
}

/* Enhanced error states */
.error-message {
    background: var(--danger-color);
    color: white;
    padding: 12px 16px;
    border-radius: 8px;
    margin: 16px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.error-message::before {
    content: '⚠️';
    font-size: 16px;
}

/* Success states */
.success-message {
    background: var(--success-color);
    color: white;
    padding: 12px 16px;
    border-radius: 8px;
    margin: 16px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.success-message::before {
    content: '✅';
    font-size: 16px;
}

/* Tooltip styles */
.tooltip {
    position: relative;
    cursor: help;
}

.tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    background: var(--text-primary);
    color: var(--bg-primary);
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease;
    z-index: 1000;
}

.tooltip:hover::after {
    opacity: 1;
    visibility: visible;
}

/* Status indicators with icons */
.status-indicator {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 500;
}

.status-indicator.online {
    background: rgba(40, 167, 69, 0.1);
    color: var(--success-color);
}

.status-indicator.offline {
    background: rgba(220, 53, 69, 0.1);
    color: var(--danger-color);
}

.status-indicator.warning {
    background: rgba(255, 193, 7, 0.1);
    color: var(--warning-color);
}

/* Progress bars */
.progress-bar {
    width: 100%;
    height: 8px;
    background: var(--border-color);
    border-radius: 4px;
    overflow: hidden;
    margin: 16px 0;
}

.progress-fill {
    height: 100%;
    background: var(--primary-color);
    transition: width 0.3s ease;
    border-radius: 4px;
}

/* Card layouts for results */
.result-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 16px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
    transition: box-shadow 0.3s ease;
}

.result-card:hover {
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.result-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}

.result-card-title {
    font-weight: 600;
    color: var(--text-primary);
}

.result-card-meta {
    font-size: 12px;
    color: var(--text-secondary);
}

/* Responsive grid for cards */
.results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 16px;
    margin-top: 24px;
}

/* Additional notification styling enhancements */
.notification {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 12px 20px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
    z-index: 2000;
    max-width: 300px;
    font-weight: 500;
    transition: all 0.3s ease;
}

.notification.copy {
    background: var(--success-color);
    color: white;
}

.notification.share {
    background: var(--info-color);
    color: white;
}

/* Ensure proper stacking and positioning */
#copyNotification {
    z-index: 2001;
}

#shareNotification {
    z-index: 2002;
}

#pwaNotification {
    z-index: 2003;
}

@media (max-width: 768px) {
    .results-grid {
        grid-template-columns: 1fr;
    }
    
    /* Mobile-specific table improvements */
    .data-table td:before {
        font-size: 12px;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }
    
    .data-table td {
        padding-top: 12px;
        padding-bottom: 12px;
    }
    
    .data-table tr:last-child td:last-child {
        border-bottom: none;
    }
}

/* Custom scrollbar styling for webkit browsers */
.sidebar::-webkit-scrollbar {
    width: 6px;
}

.sidebar::-webkit-scrollbar-track {
    background: rgba(255,255,255,0.1);
}

.sidebar::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.3);
    border-radius: 3px;
}

.sidebar::-webkit-scrollbar-thumb:hover {
    background: rgba(255,255,255,0.5);
}

.sidebar.collapsed::-webkit-scrollbar {
    width: 0px; /* Hide scrollbar when collapsed */
}

.nav-menu::-webkit-scrollbar {
    width: 4px;
}

.nav-menu::-webkit-scrollbar-track {
    background: transparent;
}

.nav-menu::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.2);
    border-radius: 2px;
}

/* Firefox scrollbar styling */
.sidebar {
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.3) rgba(255,255,255,0.1);
}

.sidebar.collapsed {
    scrollbar-width: none; /* Hide scrollbar when collapsed */
}

/* Ensure nav menu scrolling works properly */
.nav-menu {
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.2) transparent;
}

@media (max-width: 768px) {
    .export-menu {
        left: 0;
        right: auto;
        min-width: 200px;
    }

    .shared-summary-grid {
        grid-template-columns: 1fr;
    }
}

/* ==============================
   Phase 1 UI
   ============================== */
.optional-text {
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 500;
}

.phase-results-stack {
    display: grid;
    gap: 18px;
    padding: 18px;
}

.phase-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 14px;
}

.phase-metric-card,
.phase-section-card,
.phase-warning-box {
    border: 1px solid var(--border-color);
    border-radius: 14px;
    background: var(--bg-primary);
    box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}

.phase-metric-card {
    padding: 16px;
}

.phase-metric-card-success {
    border-color: rgba(40, 167, 69, 0.28);
    background: rgba(40, 167, 69, 0.08);
}

.phase-metric-card-warning {
    border-color: rgba(255, 193, 7, 0.28);
    background: rgba(255, 193, 7, 0.09);
}

.phase-metric-card-danger {
    border-color: rgba(220, 53, 69, 0.28);
    background: rgba(220, 53, 69, 0.08);
}

.phase-metric-card-info {
    border-color: rgba(13, 110, 253, 0.24);
    background: rgba(13, 110, 253, 0.07);
}

.phase-metric-card-neutral {
    border-color: rgba(108, 117, 125, 0.24);
    background: rgba(108, 117, 125, 0.07);
}

.phase-metric-label {
    font-size: 12px;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--text-secondary);
    font-weight: 700;
}

.phase-metric-value {
    margin-top: 8px;
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    word-break: break-word;
    line-height: 1.3;
    overflow-wrap: anywhere;
}

.phase-metric-value-clamp,
.phase-inline-note,
.phase-badge {
    overflow-wrap: anywhere;
}

.phase-warning-box {
    padding: 16px 18px;
    border-color: rgba(255, 140, 0, 0.28);
    background: rgba(255, 140, 0, 0.08);
}

.phase-warning-title,
.phase-section-title {
    font-weight: 700;
    color: var(--text-primary);
}

.phase-warning-title {
    margin-bottom: 10px;
}

.phase-warning-list {
    margin: 0;
    padding-left: 18px;
    color: var(--text-primary);
}

.phase-warning-list li + li {
    margin-top: 6px;
}

.phase-section-card {
    padding: 16px;
}

.phase-section-title {
    margin-bottom: 12px;
}
.phase-section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}

.phase-section-title-row .phase-section-title {
    margin-bottom: 0;
}

.phase-section-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}


.dns-results-table-header .phase-section-actions {
    gap: 4px;
}


.phase-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 74px;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    border: 1px solid currentColor;
    background: rgba(255,255,255,0.6);
}

.phase-badge-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.phase-badge {
    display: inline-flex;
    align-items: center;
    padding: 7px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.phase-badge-success {
    color: var(--success-color);
    border-color: rgba(40, 167, 69, 0.28);
    background: rgba(40, 167, 69, 0.08);
}

.phase-badge-danger {
    color: var(--danger-color);
    border-color: rgba(220, 53, 69, 0.28);
    background: rgba(220, 53, 69, 0.08);
}

.phase-badge-info {
    color: var(--info-color);
    border-color: rgba(23, 162, 184, 0.28);
    background: rgba(23, 162, 184, 0.08);
}

.phase-badge-neutral {
    color: var(--text-primary);
}


.phase-inline-note {
    color: var(--text-secondary);
    font-size: 12px;
}

.phase-header-list {
    display: grid;
    gap: 8px;
    min-width: 220px;
}

.phase-header-row {
    display: grid;
    gap: 4px;
    padding: 8px 10px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background: var(--bg-secondary);
}

.phase-header-key {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--text-secondary);
    letter-spacing: .04em;
}

.phase-header-value {
    font-size: 12px;
    color: var(--text-primary);
    word-break: break-word;
}


/* Phase 1 UI menu enhancements */
.sidebar-header {
    position: sticky;
    top: 0;
    z-index: 5;
    background: var(--sidebar-bg);
    backdrop-filter: blur(10px);
}

.sidebar-brand {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.sidebar-subtitle {
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.68);
    font-weight: 700;
}


.sidebar-meta-line {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.app-version-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 9px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.03em;
    background: rgba(255,255,255,0.14);
    color: #ffffff;
    border: 1px solid rgba(255,255,255,0.16);
}

.sidebar-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.nav-search-wrap {
    padding: 14px 14px 12px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    position: sticky;
    top: 77px;
    z-index: 4;
    background: linear-gradient(180deg, rgba(0,0,0,0.16), rgba(0,0,0,0.04));
    backdrop-filter: blur(10px);
}

.nav-search-box {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.08);
    padding: 0 10px;
}

.nav-search-icon {
    flex-shrink: 0;
    opacity: 0.82;
}

.nav-search-input {
    flex: 1;
    border: none;
    background: transparent;
    color: #fff;
    font-size: 14px;
    min-width: 0;
    outline: none;
}

.nav-search-input::placeholder {
    color: rgba(255,255,255,0.58);
}

.nav-search-clear,
.mobile-close-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border: none;
    border-radius: 999px;
    cursor: pointer;
    transition: background .2s ease, transform .2s ease;
}

.nav-search-clear {
    visibility: hidden;
    opacity: 0;
    background: rgba(255,255,255,0.12);
    color: #fff;
}

.nav-search-clear.show {
    visibility: visible;
    opacity: 1;
}

.nav-search-clear:hover,
.mobile-close-btn:hover {
    background: rgba(255,255,255,0.18);
    transform: translateY(-1px);
}

.mobile-close-btn {
    display: none;
    background: rgba(255,255,255,0.12);
    color: #fff;
}

.nav-group {
    padding: 10px 10px 0;
}

.nav-group + .nav-group {
    margin-top: 4px;
}

.nav-group-hidden {
    display: none;
}

.nav-group-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
    border: none;
    background: transparent;
    color: rgba(255,255,255,0.76);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-weight: 800;
    cursor: pointer;
    border-radius: 8px;
}

.nav-group-toggle:hover {
    background: rgba(255,255,255,0.08);
    color: #fff;
}

.nav-group-label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.nav-group-chevron {
    transition: transform .2s ease;
    font-size: 12px;
    flex-shrink: 0;
}

.nav-group.collapsed .nav-group-chevron {
    transform: rotate(-90deg);
}

.nav-group-items {
    display: grid;
    gap: 2px;
    padding: 4px 0 2px;
}

.nav-group.collapsed .nav-group-items {
    display: none;
}

.sidebar-utility {
    padding: 12px 10px 16px;
    border-top: 1px solid rgba(255,255,255,0.08);
    flex-shrink: 0;
}

.sidebar-utility-title {
    padding: 6px 12px 10px;
    color: rgba(255,255,255,0.72);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.nav-utility-link {
    border-radius: 12px;
}

.sidebar.collapsed .sidebar-utility-title {
    display: none;
}

.nav-item {
    border-radius: 12px;
}

.nav-item:hover,
.nav-item.active {
    background: rgba(255,255,255,0.12);
}

.nav-item.active {
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.16);
}

.sidebar.collapsed .sidebar-subtitle,
.sidebar.collapsed .sidebar-meta-line,
.sidebar.collapsed .app-version-badge,
.sidebar.collapsed .nav-search-wrap,
.sidebar.collapsed .nav-group-toggle {
    opacity: 0;
    pointer-events: none;
    height: 0;
    padding-top: 0;
    padding-bottom: 0;
    overflow: hidden;
    border: none;
}

.sidebar.collapsed.hover-expanded .sidebar-subtitle,
.sidebar.collapsed.hover-expanded .sidebar-meta-line,
.sidebar.collapsed.hover-expanded .app-version-badge,
.sidebar.collapsed.hover-expanded .nav-search-wrap,
.sidebar.collapsed.hover-expanded .nav-group-toggle {
    opacity: 1;
    pointer-events: auto;
    height: auto;
    border-bottom-width: 1px;
}

.sidebar.collapsed .nav-group {
    padding-left: 6px;
    padding-right: 6px;
}

.sidebar.collapsed.hover-expanded .nav-group {
    padding-left: 10px;
    padding-right: 10px;
}

body.menu-open {
    overflow: hidden;
}

.phase-section-card .data-table {
    margin-top: 0;
}

@media (max-width: 768px) {
    .sidebar {
        width: min(88vw, 340px);
        box-shadow: 10px 0 24px rgba(0,0,0,0.2);
    }

    .sidebar-header {
        padding-top: calc(20px + env(safe-area-inset-top, 0px));
    }

    .nav-search-wrap {
        top: calc(76px + env(safe-area-inset-top, 0px));
    }

    .mobile-close-btn {
        display: inline-flex;
    }

    .toggle-btn {
        display: none;
    }

    .mobile-menu-btn {
        padding: 10px 16px;
        border-radius: 10px;
        font-weight: 700;
        box-shadow: 0 6px 14px rgba(0,0,0,0.14);
    }

    .nav-group {
        padding-left: 12px;
        padding-right: 12px;
    }

    .nav-item {
        padding-top: 15px;
        padding-bottom: 15px;
        font-size: 15px;
    }

    .top-bar {
        position: sticky;
        top: 0;
        z-index: 30;
        background: rgba(255,255,255,0.92);
        backdrop-filter: blur(12px);
    }

    body.theme-dark .top-bar,
    body.theme-black .top-bar,
    body.theme-ocean .top-bar,
    body.theme-matrix .top-bar,
    body.theme-purple .top-bar {
        background: rgba(18,18,18,0.9);
    }
}

@media (min-width: 769px) {
    .mobile-close-btn {
        display: none !important;
    }

    .nav-menu {
        padding-bottom: 18px;
    }

    .main-content {
        min-width: 0;
    }
}


/* Phase 1 mobile/header follow-up tuning */
.top-bar {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
}

.page-title {
    min-width: 0;
    margin: 0;
    line-height: 1.08;
}

.mobile-menu-btn {
    display: none;
    align-items: center;
    justify-content: center;
    gap: 8px;
    white-space: nowrap;
}

.mobile-menu-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    line-height: 1;
}

.mobile-menu-label {
    line-height: 1;
}

.theme-switcher {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.theme-toggle-btn {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--bg-primary);
    color: var(--text-primary);
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.theme-toggle-btn:hover,
.theme-toggle-btn:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(0,0,0,0.10);
    border-color: var(--primary-color);
    outline: none;
}

.theme-toggle-icon {
    font-size: 20px;
    line-height: 1;
}

.theme-popover {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    width: min(260px, calc(100vw - 32px));
    display: none;
    padding: 12px;
    border: 1px solid var(--border-color);
    border-radius: 16px;
    background: var(--bg-primary);
    box-shadow: 0 18px 38px rgba(0,0,0,0.18);
    z-index: 80;
}

.theme-switcher.open .theme-popover {
    display: block;
}

.theme-popover-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.theme-popover-title {
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.theme-popover-close {
    width: 30px;
    height: 30px;
    border: none;
    border-radius: 999px;
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
}

.theme-option-grid {
    display: grid;
    gap: 8px;
}

.theme-option-btn {
    width: 100%;
    display: grid;
    grid-template-columns: 18px 1fr;
    align-items: center;
    gap: 10px;
    padding: 11px 12px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--bg-primary);
    color: var(--text-primary);
    text-align: left;
    cursor: pointer;
    transition: border-color .18s ease, background-color .18s ease, transform .18s ease;
}

.theme-option-btn:hover,
.theme-option-btn:focus-visible {
    border-color: var(--primary-color);
    background: var(--bg-secondary);
    transform: translateY(-1px);
    outline: none;
}

.theme-option-btn.is-active {
    border-color: var(--primary-color);
    box-shadow: inset 0 0 0 1px rgba(0,123,255,0.16);
    background: var(--bg-secondary);
}

.theme-option-text {
    font-size: 14px;
    font-weight: 600;
}

.theme-swatch {
    width: 16px;
    height: 16px;
    border-radius: 999px;
    display: inline-block;
    border: 1px solid rgba(0,0,0,0.15);
}

.swatch-default { background: linear-gradient(135deg, #ffffff, #dfe7f4); }
.swatch-dark { background: linear-gradient(135deg, #121212, #3b3b3b); border-color: rgba(255,255,255,0.18); }
.swatch-blue { background: linear-gradient(135deg, #1976d2, #66a6ff); border-color: rgba(255,255,255,0.18); }
.swatch-terminal { background: linear-gradient(135deg, #050505, #00ff66); border-color: rgba(255,255,255,0.18); }
.swatch-purple { background: linear-gradient(135deg, #673ab7, #c09bff); border-color: rgba(255,255,255,0.18); }

.action-button-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

body.theme-dark .theme-toggle-btn,
body.theme-blue .theme-toggle-btn,
body.theme-terminal .theme-toggle-btn,
body.theme-purple .theme-toggle-btn,
body.theme-dark .theme-popover,
body.theme-blue .theme-popover,
body.theme-terminal .theme-popover,
body.theme-purple .theme-popover {
    box-shadow: 0 18px 38px rgba(0,0,0,0.28);
}

@media (max-width: 768px) {
    .top-bar {
        padding: 12px 14px;
        gap: 10px;
        grid-template-columns: auto minmax(0, 1fr) auto;
    }

    .page-title {
        font-size: 18px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .mobile-menu-btn {
        display: inline-flex;
        min-width: 46px;
        min-height: 42px;
        padding: 8px 12px;
        border-radius: 12px;
        font-weight: 700;
    }

    .mobile-menu-label {
        font-size: 14px;
    }

    .theme-toggle-btn {
        width: 42px;
        height: 42px;
        border-radius: 12px;
    }

    .theme-popover {
        position: fixed;
        top: calc(72px + env(safe-area-inset-top, 0px));
        right: 12px;
        left: auto;
        width: min(280px, calc(100vw - 24px));
    }
}

@media (max-width: 480px) {
    .content-wrapper {
        padding: 12px;
    }

    .top-bar {
        padding: 10px 12px;
        gap: 8px;
    }

    .page-title {
        font-size: 17px;
    }

    .mobile-menu-btn {
        display: inline-flex;
        min-width: 40px;
        min-height: 40px;
        padding: 8px 10px;
        border-radius: 10px;
        box-shadow: 0 4px 10px rgba(0,0,0,0.10);
    }

    .mobile-menu-label {
        display: none;
    }

    .theme-toggle-btn {
        width: 40px;
        height: 40px;
        border-radius: 10px;
    }

    .tool-section {
        padding: 18px;
    }

    .section-title {
        font-size: 22px;
        margin-bottom: 18px;
    }

    .action-button-row {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: stretch;
    }

    .action-button-row .btn {
        width: 100%;
        justify-content: center;
    }

    .action-button-row .btn.btn-secondary {
        white-space: nowrap;
        min-width: 110px;
    }
}

.propagation-meta-note {
    margin-top: -6px;
    margin-bottom: 10px;
    font-size: 12px;
}


body.modal-open {
    overflow: hidden;
}

.share-dialog-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    z-index: 2500;
}

.share-dialog-overlay.show {
    display: flex;
}

.share-dialog {
    width: min(640px, 100%);
    background: var(--bg-primary);
    color: var(--text-primary);
    border-radius: 16px;
    border: 1px solid var(--border-color);
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
    overflow: hidden;
}

.share-dialog-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--border-color);
}

.share-dialog-title {
    font-size: 22px;
    margin: 0 0 6px;
}

.share-dialog-subtitle,
.share-dialog-help {
    color: var(--text-secondary);
    font-size: 13px;
}

.share-dialog-close {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.share-dialog-body {
    padding: 20px 24px 8px;
}

.share-dialog-check-wrap {
    margin-top: 4px;
}

.share-dialog-check {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    cursor: pointer;
}

.share-dialog-check input {
    width: 16px;
    height: 16px;
    margin: 0;
}

.share-dialog-textarea {
    min-height: 120px;
    resize: vertical;
}

.share-dialog-warning {
    margin-bottom: 16px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid rgba(245, 158, 11, 0.35);
    background: rgba(245, 158, 11, 0.12);
    color: var(--text-primary);
    font-size: 13px;
    line-height: 1.5;
}


.share-dialog-result {
    margin: 12px 0 18px;
    padding: 14px;
    border: 1px solid var(--border-color);
    border-radius: 14px;
    background: var(--bg-secondary);
}

.share-dialog-result-row {
    display: flex;
    gap: 10px;
    align-items: center;
}

.share-dialog-result-input {
    flex: 1;
    min-width: 0;
    font-size: 14px;
}

.share-dialog-copy-btn {
    min-width: 52px;
    justify-content: center;
    padding-left: 16px;
    padding-right: 16px;
}

.member-snapshot-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid rgba(40, 167, 69, 0.22);
    background: rgba(40, 167, 69, 0.10);
}

.member-snapshot-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.member-snapshot-text {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.45;
}

.member-snapshot-btn {
    white-space: nowrap;
}

.share-dialog-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 0 24px 24px;
}

.shared-tag-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
}

.shared-tag-list {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
}

.shared-tag {
    display: inline-flex;
    align-items: center;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(23, 162, 184, 0.14);
    color: var(--text-primary);
    border: 1px solid rgba(23, 162, 184, 0.25);
    font-size: 12px;
    font-weight: 600;
}

@media (max-width: 768px) {
    .share-dialog-overlay {
        padding: 16px;
        align-items: flex-end;
    }

    .share-dialog {
        width: 100%;
    }

    .share-dialog-actions {
        flex-direction: column-reverse;
    }

    .share-dialog-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .share-dialog-result-row,
    .member-snapshot-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .share-dialog-copy-btn,
    .member-snapshot-btn {
        width: 100%;
    }
}

/* Member portal entry points */
.top-bar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-left: auto;
}

.top-bar-utility {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    margin-left: auto;
}

.member-topbar {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.member-topbar-header {
    flex-wrap: nowrap;
}

.member-topbar-link,
.member-topbar-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid var(--border-color);
    background: var(--bg-primary);
    color: var(--text-primary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
}

.member-topbar-link-primary {
    padding: 8px 11px;
}

.member-topbar-label {
    line-height: 1;
}

.member-topbar-chip {
    background: var(--bg-secondary);
}

.share-member-note {
    margin-top: 10px;
    padding: 12px 14px;
    border-radius: 10px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    font-size: 13px;
    line-height: 1.45;
}

.share-member-note a {
    color: var(--primary-color);
    font-weight: 600;
}

@media (max-width: 768px) {
    .top-bar-actions {
        width: 100%;
        justify-content: space-between;
        margin-left: 0;
    }

    .member-topbar {
        width: 100%;
        justify-content: flex-start;
    }
}

.password-share-note {
    margin-top: 14px;
    padding: 12px 14px;
    border-radius: 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    font-size: 13px;
    line-height: 1.5;
}

.shared-secret-warning {
    margin-bottom: 16px;
    padding: 14px 16px;
    border-radius: 12px;
    border: 1px solid rgba(239, 68, 68, 0.22);
    background: rgba(239, 68, 68, 0.1);
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.5;
}

.shared-secret-warning strong {
    display: block;
    margin-bottom: 4px;
}

.shared-secret-warning.used {
    border-color: rgba(107, 114, 128, 0.28);
    background: rgba(107, 114, 128, 0.12);
}

.shared-secret-meta {
    margin-top: 8px;
    color: var(--text-secondary);
    font-size: 12px;
}

.shared-secret-empty {
    padding: 18px;
    border-radius: 12px;
    border: 1px dashed var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-secondary);
    text-align: center;
}


/* ==============================
   v1.6.2 Mobile experience refresh
   ============================== */
html {
    -webkit-text-size-adjust: 100%;
}

body.menu-open,
body.modal-open {
    overscroll-behavior: none;
}

@media (max-width: 768px) {
    body {
        padding-bottom: env(safe-area-inset-bottom, 0px);
    }

    .top-bar {
        grid-template-columns: auto minmax(0, 1fr) auto;
        grid-template-areas: "menu title utility";
        align-items: center;
    }

    .mobile-menu-btn {
        grid-area: menu;
    }

    .page-title {
        grid-area: title;
    }

    .top-bar-utility {
        grid-area: utility;
        gap: 8px;
    }

    .member-topbar {
        display: flex;
        width: auto;
        min-width: 0;
    }

    .member-topbar-link,
    .member-topbar-chip {
        min-height: 40px;
        padding: 8px 11px;
    }

    .member-topbar-label {
        display: none;
    }

    .content-wrapper {
        padding: 14px;
    }

    .tool-section {
        padding: 20px;
        border-radius: 16px;
    }

    .section-title {
        font-size: 22px;
        line-height: 1.2;
        margin-bottom: 20px;
    }

    .tool-section > .btn {
        width: 100%;
        min-height: 48px;
        justify-content: center;
    }

    .tool-section > .btn + 
.results-panel {
        margin-top: 20px;
    }

    .form-group {
        margin-bottom: 16px;
    }

    .form-label {
        font-size: 13px;
    }

    .form-input {
        min-height: 48px;
    }

    select.form-input {
        padding-right: 40px;
    }

    textarea.form-input {
        min-height: 140px;
    }

    
.results-panel {
        margin-top: 20px;
        border-radius: 14px;
    }

    .results-header {
        padding: 16px;
    }

    .results-title {
        font-size: 17px;
        line-height: 1.25;
    }

    .results-header {
        padding: 16px 18px;
    }

    .results-actions {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .results-actions-mobile-sticky {
        position: sticky;
        bottom: calc(10px + env(safe-area-inset-bottom, 0px));
        display: grid;
        margin-top: 14px;
        padding: 12px;
        border: 1px solid rgba(0, 0, 0, 0.08);
        border-radius: 14px;
        background: rgba(255, 255, 255, 0.94);
        backdrop-filter: blur(12px);
        box-shadow: 0 8px 24px rgba(0,0,0,0.14);
        z-index: 55;
    }

    .results-actions > .btn,
    .results-actions > .export-menu-wrap {
        width: 100%;
        min-width: 0;
    }

    .results-actions .btn,
    .results-actions .export-toggle {
        width: 100%;
        justify-content: center;
    }

    .export-menu {
        position: fixed;
        left: 12px;
        right: 12px;
        bottom: calc(12px + env(safe-area-inset-bottom, 0px));
        top: auto;
        min-width: 0;
        max-height: min(50vh, 360px);
        overflow: auto;
        z-index: 2600;
    }

    .phase-results-stack {
        padding: 14px;
    }

    .phase-card-grid,
    .shared-summary-grid {
        grid-template-columns: 1fr;
    }

    .phase-header-list {
        min-width: 0;
    }

    .password-display {
        font-size: 16px;
        padding: 16px;
        overflow-x: auto;
        white-space: nowrap;
    }

    .shared-secret-layout {
        padding: 24px 16px calc(28px + env(safe-area-inset-bottom, 0px));
    }

    .shared-secret-page-title {
        font-size: 28px;
    }

    .shared-secret-actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .shared-secret-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .share-dialog-overlay {
        padding: 0;
        align-items: flex-end;
    }

    .share-dialog {
        width: 100%;
        max-width: none;
        max-height: min(90vh, 860px);
        border-radius: 20px 20px 0 0;
        display: flex;
        flex-direction: column;
    }

    .share-dialog-header {
        padding: 18px 18px 14px;
    }

    .share-dialog-title {
        font-size: 20px;
    }

    .share-dialog-body {
        padding: 16px 18px 12px;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .share-dialog-textarea {
        min-height: 132px;
    }

    .share-dialog-actions {
        padding: 14px 18px calc(18px + env(safe-area-inset-bottom, 0px));
        background: var(--bg-primary);
        border-top: 1px solid var(--border-color);
        position: sticky;
        bottom: 0;
    }

    .share-member-note,
    .password-share-note,
    .shared-secret-warning {
        font-size: 13px;
        line-height: 1.5;
    }

    .notification {
        left: 12px;
        right: 12px;
        top: 12px;
        max-width: none;
    }
}

@media (max-width: 560px) {
    .top-bar {
        padding: 10px 12px;
    }

    .page-title {
        font-size: 17px;
    }

    .tool-section {
        padding: 16px;
    }

    .results-header {
        align-items: stretch;
        padding: 14px 16px;
    }

    .results-actions {
        grid-template-columns: 1fr;
    }

    .results-actions-mobile-sticky {
        padding: 10px;
        margin-top: 12px;
    }

    .phase-results-stack {
        padding: 12px;
        gap: 14px;
    }

    .phase-card-grid {
        gap: 12px;
    }

    .phase-metric-card,
    .phase-section-card,
    .phase-warning-box {
        border-radius: 12px;
    }

    .phase-metric-card,
    .phase-section-card {
        padding: 14px;
    }

    .phase-metric-value {
        font-size: 17px;
    }

    .member-snapshot-bar {
        padding: 12px 14px;
    }

    .form-input {
        font-size: 16px;
    }

    .data-table tr {
        padding: 10px;
    }

    .data-table td {
        padding-left: 44% !important;
    }

    .data-table td:before {
        width: 40%;
        left: 0;
        padding-right: 8px;
    }
}

/* Layer 2 route / toast / loading refresh */
.toast-container {
    position: fixed;
    top: 18px;
    right: 18px;
    z-index: 3200;
    display: flex;
    flex-direction: column;
    gap: 12px;
    pointer-events: none;
    width: min(360px, calc(100vw - 24px));
}

.toast {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: rgba(18, 18, 18, 0.94);
    color: #fff;
    box-shadow: 0 18px 40px rgba(0,0,0,0.22);
    opacity: 0;
    transform: translateY(-8px) scale(0.98);
    transition: opacity 0.2s ease, transform 0.2s ease;
    pointer-events: auto;
}

.toast.show {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.toast-success { background: rgba(18, 130, 74, 0.96); }
.toast-info { background: rgba(20, 97, 173, 0.96); }
.toast-warning { background: rgba(181, 120, 0, 0.96); }
.toast-danger { background: rgba(179, 47, 62, 0.97); }

.toast-icon {
    font-size: 18px;
    line-height: 1.2;
    margin-top: 1px;
}

.toast-copy {
    flex: 1;
    min-width: 0;
}

.toast-title {
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 3px;
}

.toast-message {
    font-size: 13px;
    line-height: 1.45;
    opacity: 0.96;
}

.toast-close {
    background: transparent;
    border: none;
    color: inherit;
    font-size: 21px;
    line-height: 1;
    cursor: pointer;
    opacity: 0.85;
}

.results-loading-card {
    border: 1px solid var(--border-color);
    border-radius: 16px;
    background: linear-gradient(180deg, var(--bg-primary), var(--bg-secondary));
    padding: 20px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.results-loading-header {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 16px;
}

.results-loading-spinner {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid rgba(0, 123, 255, 0.18);
    border-top-color: var(--primary-color);
    animation: spin 0.9s linear infinite;
}

.results-loading-bars {
    display: grid;
    gap: 10px;
}

.results-loading-bar {
    height: 12px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(0,0,0,0.05), rgba(0,0,0,0.11), rgba(0,0,0,0.05));
    background-size: 220% 100%;
    animation: ntShimmer 1.4s ease infinite;
}

.results-loading-bar.is-wide { width: 100%; }
.results-loading-bar.is-medium { width: 74%; }
.results-loading-bar:not(.is-wide):not(.is-medium) { width: 86%; }

@keyframes ntShimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.field-inline-validation {
    display: none;
    margin-top: 8px;
    font-size: 13px;
    line-height: 1.45;
}
.field-inline-validation.warning { color: #8a6500; }
.field-inline-validation.danger { color: var(--danger-color); }
.form-input.input-warning { border-color: rgba(255, 193, 7, 0.8); box-shadow: 0 0 0 3px rgba(255, 193, 7, 0.12); }
.form-input.input-danger { border-color: rgba(220, 53, 69, 0.8); box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.12); }

.ip-secondary {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 16px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,0.18);
    border: 1px solid rgba(255,255,255,0.24);
}
.ip-secondary-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    opacity: 0.9;
}
.ip-secondary-value {
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
}

#shareDialogSecretExpiryWrap {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(220px, 0.95fr);
    gap: 16px;
    align-items: start;
}
#shareDialogSecretExpiryWrap .form-group.narrow {
    min-width: 0;
    margin-bottom: 0;
}
#shareDialogSecretExpireMode,
#shareDialogSecretExpireDays {
    min-height: 48px;
}

@media (max-width: 768px) {
    .toast-container {
        left: 12px;
        right: 12px;
        width: auto;
        top: 12px;
    }

    #shareDialogSecretExpiryWrap {
        grid-template-columns: 1fr;
    }

    .ip-secondary {
        flex-direction: column;
        border-radius: 14px;
    }
}

/* v1.13.0 polish pack */
.result-meta-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 14px;
}
.result-meta-chip {
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid var(--border-color);
    background: var(--bg-primary);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 700;
}
.result-highlight-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
    margin-bottom: 16px;
}
.result-highlight-card {
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid var(--border-color);
    background: var(--bg-primary);
    box-shadow: 0 6px 18px rgba(0,0,0,0.04);
}
.result-highlight-card.is-success { border-color: rgba(40,167,69,0.28); background: rgba(40,167,69,0.08); }
.result-highlight-card.is-warning { border-color: rgba(245,158,11,0.28); background: rgba(245,158,11,0.10); }
.result-highlight-card.is-danger { border-color: rgba(220,53,69,0.28); background: rgba(220,53,69,0.08); }
.result-highlight-label {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
}
.result-highlight-value {
    margin-top: 6px;
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    word-break: break-word;
}
.results-loading-card-rich {
    display: grid;
    gap: 16px;
}
.results-loading-shell-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 12px;
}
.results-loading-shell-card,
.results-loading-table-row span {
    border-radius: 14px;
    background: linear-gradient(90deg, rgba(0,0,0,0.05), rgba(0,0,0,0.11), rgba(0,0,0,0.05));
    background-size: 220% 100%;
    animation: ntShimmer 1.4s ease infinite;
}
.results-loading-shell-card {
    min-height: 84px;
}
.results-loading-table {
    display: grid;
    gap: 10px;
}
.results-loading-table-row {
    display: grid;
    grid-template-columns: 1.25fr 0.7fr 0.9fr;
    gap: 12px;
}
.results-loading-table-row span {
    height: 16px;
}
.results-loading-header {
    margin-bottom: 0;
}
.share-dialog {
    width: min(720px, 100%);
}
.share-dialog-body {
    padding: 22px 24px 12px;
}
.share-dialog .form-group {
    margin-bottom: 18px;
}
.share-dialog-result {
    margin-top: 16px;
}
.share-dialog-check-wrap {
    margin-top: 10px;
}
#shareDialogSecretExpiryWrap {
    gap: 18px;
}
#shareDialogSecretExpireMode,
#shareDialogSecretExpireDays {
    width: 100%;
}
.nav-item-disabled {
    opacity: 0.62;
    position: relative;
    filter: grayscale(0.18);
}
.nav-item-disabled:hover {
    opacity: 0.72;
}
.nav-item-disabled .icon,
.nav-item-disabled .text {
    color: var(--text-secondary);
}
.nav-disabled-badge { display:none !important; }
.tool-disabled-banner,
.tool-unavailable-route-card {
    display: grid;
    grid-template-columns: 64px 1fr;
    gap: 16px;
    align-items: center;
    margin: 14px 0 18px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid rgba(220, 53, 69, 0.22);
    background: rgba(220, 53, 69, 0.08);
    color: var(--text-primary);
    line-height: 1.5;
}
.tool-disabled-banner-icon,
.tool-unavailable-route-icon {
    width: 64px;
    height: 64px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: rgba(220, 53, 69, 0.12);
    color: #b42318;
}
.tool-disabled-banner-icon svg,
.tool-unavailable-route-icon svg {
    width: 34px;
    height: 34px;
    fill: currentColor;
}
.tool-disabled-banner-copy,
.tool-unavailable-route-copy {
    min-width: 0;
}
.tool-disabled-banner-title,
.tool-unavailable-route-title {
    font-size: 1.05rem;
    font-weight: 800;
    margin-bottom: 4px;
}
.tool-disabled-banner-text,
.tool-unavailable-route-copy {
    font-size: 0.95rem;
    color: var(--text-primary);
}
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
@media (max-width: 640px) {
    .tool-disabled-banner,
    .tool-unavailable-route-card {
        grid-template-columns: 1fr;
        text-align: left;
    }
    .tool-disabled-banner-icon,
    .tool-unavailable-route-icon {
        width: 56px;
        height: 56px;
    }
}

.tool-section-disabled {
    opacity: 1;
}
.tool-section-disabled .tool-disabled-content {
    display: none !important;
}
.tool-section-disabled .results-panel {
    opacity: 1;
}
.btn-clear-action {
    white-space: nowrap;
}
.open-in-tool-btn {
    margin-right: 10px;
}
@media (max-width: 768px) {
    .result-highlight-grid {
        grid-template-columns: 1fr;
    }
    .results-loading-table-row {
        grid-template-columns: 1fr;
    }
    .share-dialog-overlay {
        padding: 12px;
    }
    .share-dialog {
        border-radius: 18px 18px 0 0;
        max-height: min(92vh, 860px);
        overflow: auto;
    }
    .share-dialog-header,
    .share-dialog-body,
    .share-dialog-actions {
        padding-left: 18px;
        padding-right: 18px;
    }
    .share-dialog-result-row {
        gap: 12px;
    }
    .share-dialog-result-input,
    .share-dialog-copy-btn,
    #shareDialogSecretExpireMode,
    #shareDialogSecretExpireDays {
        min-height: 48px;
    }
}


/* v1.14.0 recent runs drawer */
.section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 18px;
}
.section-title-row .section-title {
    margin-bottom: 0;
}
.section-title-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.tool-info-trigger {
    width: 30px;
    height: 30px;
    min-width: 30px;
    padding: 0;
    border-radius: 999px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease, background-color 0.16s ease, color 0.16s ease;
}
.tool-info-trigger:hover {
    transform: translateY(-1px);
    border-color: rgba(0, 123, 255, 0.32);
    color: var(--primary-color);
    box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}
.tool-info-trigger[aria-expanded="true"] {
    border-color: rgba(0, 123, 255, 0.32);
    background: rgba(0, 123, 255, 0.08);
    color: var(--primary-color);
}
.tool-info-trigger-icon {
    font-size: 14px;
    font-weight: 800;
    font-style: normal;
    line-height: 1;
}
.tool-info-drawer {
    display: none;
    margin: -4px 0 18px;
    padding: 14px 16px;
    border-radius: 14px;
    border: 1px solid var(--border-color);
    background: linear-gradient(180deg, rgba(0, 123, 255, 0.04), rgba(255,255,255,0.02));
    box-shadow: 0 12px 28px rgba(0,0,0,0.05);
}
.tool-info-drawer.open {
    display: block;
}
.tool-info-drawer-title {
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: var(--text-primary);
}
.tool-info-text {
    margin: 10px 0 0;
    color: var(--text-primary);
    line-height: 1.6;
}
.tool-info-meta {
    margin-top: 12px;
}
.tool-info-meta-label {
    display: inline-block;
    margin-bottom: 6px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--text-secondary);
}
.tool-info-list {
    margin: 0;
    padding-left: 18px;
    color: var(--text-primary);
}
.tool-info-list li + li {
    margin-top: 4px;
}
.section-icon-button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
    transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease, background-color 0.16s ease;
}
.section-icon-button:hover {
    transform: translateY(-1px);
    border-color: rgba(0, 123, 255, 0.32);
    box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}
.recent-runs-icon {
    font-size: 15px;
    line-height: 1;
}
.recent-runs-label {
    font-size: 13px;
    font-weight: 700;
}
.recent-runs-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    border-radius: 999px;
    background: rgba(0, 123, 255, 0.12);
    color: var(--primary-color);
    font-size: 12px;
    font-weight: 700;
}
.recent-runs-drawer {
    display: none;
    margin: -4px 0 18px;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    background: linear-gradient(180deg, rgba(0, 123, 255, 0.04), rgba(255,255,255,0.02));
    box-shadow: 0 14px 28px rgba(0,0,0,0.06);
}
.recent-runs-drawer.open {
    display: block;
}
.recent-runs-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}
.recent-runs-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-primary);
}
.recent-runs-subtitle {
    margin-top: 3px;
    font-size: 12px;
    color: var(--text-secondary);
}
.recent-runs-list {
    display: grid;
    gap: 10px;
}
.recent-run-item {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid var(--border-color);
    background: var(--bg-primary);
    color: var(--text-primary);
    text-align: left;
    cursor: pointer;
    transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}
.recent-run-item:hover {
    transform: translateY(-1px);
    border-color: rgba(0, 123, 255, 0.28);
    box-shadow: 0 12px 22px rgba(0,0,0,0.07);
}
.recent-run-primary {
    font-weight: 700;
    word-break: break-word;
}
.recent-run-meta {
    flex-shrink: 0;
    color: var(--text-secondary);
    font-size: 12px;
    white-space: nowrap;
}
@media (max-width: 768px) {
    .section-title-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .section-title-actions {
        width: 100%;
        justify-content: flex-end;
    }

    .recent-runs-header,
    .recent-run-item {
        flex-direction: column;
        align-items: stretch;
    }

    .recent-run-meta {
        white-space: normal;
    }
}


.dns-column-manager {
    margin: 4px 0 0;
    padding: 8px 10px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--bg-secondary);
}

.dns-column-manager-collapsed {
    box-shadow: none;
}

.dns-column-manager-head,
.dns-result-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.dns-column-manager-head-compact {
    gap: 10px;
}

.dns-column-manager-head-inline {
    justify-content: flex-end;
    gap: 8px;
}

.dns-column-manager-inline {
    margin-top: 0;
}

.dns-column-manager-copy-inline {
    margin-right: auto;
    overflow: hidden;
}

.dns-column-manager-copy {
    min-width: 0;
}

.dns-column-manager-title {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.1;
}

.dns-column-manager-text,
.dns-result-toolbar-copy {
    font-size: 0.78rem;
    color: var(--text-secondary);
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dns-column-manager-actions-compact {
    flex-shrink: 0;
}

.dns-column-toggle-icon {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    background: var(--bg-primary);
    color: var(--text-primary);
    cursor: pointer;
    transition: border-color .18s ease, background-color .18s ease, transform .18s ease;
}

.dns-column-toggle-icon:hover,
.dns-column-toggle-icon:focus-visible,
.dns-column-toggle-icon.is-active {
    border-color: var(--primary-color);
    background: var(--bg-secondary);
    outline: none;
}

.dns-column-toggle-icon:hover,
.dns-column-toggle-icon:focus-visible {
    transform: translateY(-1px);
}

.dns-column-customizer {
    margin-top: 4px;
    padding-top: 6px;
    border-top: 1px solid var(--border-color);
}

.dns-column-customizer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 6px 10px;
}

.dns-column-option {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 8px;
    align-items: start;
    font-size: 0.9rem;
    color: var(--text-primary);
}

.dns-column-customizer-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

.dns-result-toolbar {
    margin: 0 0 8px;
}

.action-button-row-compact {
    margin-top: 0;
}

#dns-lookup 
.results-panel {
    margin-top: 6px;
}

#dns-lookup .phase-card-grid {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
    margin-bottom: 6px;
}

#dns-lookup .phase-metric-card {
    padding: 12px;
}

#dns-lookup .phase-metric-value {
    margin-top: 6px;
    font-size: 16px;
}

#dns-lookup .phase-inline-note {
    margin-top: 4px;
    margin-bottom: 4px;
}

#dns-lookup .data-table {
    margin-top: 6px;
}

.dns-result-note-compact {
    font-size: 0.78rem;
}

.dns-results-table-card {
    padding-top: 10px;
}

.dns-results-table-card .dns-column-manager {
    margin-bottom: 4px;
}

.dns-results-table-header {
    margin-bottom: 4px;
}

@media (max-width: 768px) {
    .dns-column-manager {
        padding: 8px 9px;
        margin-top: 6px;
    }

    .dns-column-manager-head {
        align-items: center;
    }

    .phase-section-title-row {
        gap: 8px;
    }

    .dns-column-customizer-actions {
        width: 100%;
    }

    .dns-column-customizer-actions .btn {
        width: 100%;
    }

    .dns-column-toggle-icon {
        width: 28px;
        height: 28px;
        border-radius: 8px;
    }

    #dns-lookup 
.results-panel {
        margin-top: 8px;
    }
}


.member-header-menu {
    position: relative;
}

.member-header-menu summary {
    list-style: none;
    cursor: pointer;
}

.member-header-menu summary::-webkit-details-marker {
    display: none;
}

.member-header-menu[open] .member-topbar-link {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.12);
}

.member-header-menu-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 220px;
    padding: 10px;
    border-radius: 14px;
    border: 1px solid var(--border-color);
    background: var(--bg-primary);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
    display: grid;
    gap: 8px;
    z-index: 40;
}

.member-header-menu-panel a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 10px;
    color: var(--text-primary);
    text-decoration: none;
    font-weight: 600;
}

.member-header-menu-panel a:hover {
    background: var(--bg-secondary);
}

.phase-header-toggle {
    border: 1px solid var(--border-color);
    border-radius: 10px;
    background: var(--bg-secondary);
    padding: 8px 10px;
}

.phase-header-toggle summary {
    cursor: pointer;
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.phase-header-toggle[open] summary {
    margin-bottom: 10px;
}

.phase-header-toggle .phase-header-list {
    margin-top: 0;
}

@media (max-width: 768px) {
    .member-header-menu {
        width: 100%;
    }

    .member-header-menu-panel {
        left: 0;
        right: auto;
        min-width: min(260px, calc(100vw - 32px));
    }
}


.tool-state-return-banner {
    margin: 14px 0 18px;
}
.tool-state-return-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    z-index: 3000;
}
.tool-state-return-modal {
    width: min(520px, 100%);
}
.domain-snapshot-compare-backdrop,
.domain-snapshot-picker-backdrop {
    z-index: 3600;
}
.domain-snapshot-compare-modal {
    width: min(1280px, calc(100vw - 24px));
    max-height: calc(100vh - 24px);
}
.domain-snapshot-modal-card {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 22px;
}
.domain-snapshot-compare-shell {
    max-height: calc(100vh - 24px);
    background: #ffffff;
}
.domain-snapshot-compare-shell .phase-card-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.domain-snapshot-compare-header-row {
    align-items: flex-start;
}
.domain-snapshot-compare-subtitle {
    color: var(--text-secondary);
    margin-top: 6px;
    font-size: 0.96rem;
}
.domain-snapshot-compare-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.domain-snapshot-compare-results {
    margin-top: 0;
    padding: 0 2px 4px;
    max-height: min(74vh, 840px);
    overflow: auto;
}
.domain-snapshot-diff-section {
    border: 1px solid var(--border-color);
    border-radius: 16px;
    background: #ffffff;
    padding: 16px;
    box-shadow: 0 6px 16px rgba(0,0,0,0.05);
}
.domain-snapshot-diff-section + .domain-snapshot-diff-section {
    margin-top: 14px;
}
.domain-snapshot-diff-section-header h3 {
    margin: 0;
    font-size: 1rem;
}
.domain-snapshot-diff-section-meta {
    margin-top: 6px;
    color: var(--text-secondary);
    font-size: 0.92rem;
}
.domain-snapshot-diff-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 14px;
    margin-top: 14px;
}
.domain-snapshot-diff-block {
    border: 1px solid var(--border-color);
    border-radius: 14px;
    overflow: hidden;
    background: #ffffff;
}
.domain-snapshot-diff-block.is-added {
    border-color: rgba(25, 135, 84, 0.26);
    background: rgba(25, 135, 84, 0.06);
}
.domain-snapshot-diff-block.is-removed {
    border-color: rgba(220, 53, 69, 0.26);
    background: rgba(220, 53, 69, 0.06);
}
.domain-snapshot-diff-block.is-changed {
    border-color: rgba(255, 193, 7, 0.32);
    background: rgba(255, 193, 7, 0.10);
}
.domain-snapshot-diff-block-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 12px 14px 0;
}
.domain-snapshot-diff-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    border: 1px solid currentColor;
    background: #fff;
}
.domain-snapshot-diff-badge.is-added {
    color: #146c43;
}
.domain-snapshot-diff-badge.is-removed {
    color: #b02a37;
}
.domain-snapshot-diff-badge.is-changed {
    color: #997404;
}
.domain-snapshot-diff-count {
    font-weight: 700;
    color: var(--text-secondary);
}
.domain-snapshot-diff-block .phase-section-card {
    background: transparent;
    box-shadow: none;
    border: none;
    padding: 12px 14px 14px;
}
.domain-snapshot-diff-block .data-table {
    background: #fff;
}
.domain-snapshot-diff-empty {
    border: 1px dashed var(--border-color);
    border-radius: 14px;
    padding: 18px;
    color: var(--text-secondary);
    background: #fff;
}
.tool-progress-card {
    background: #ffffff;
}
.tool-state-return-card {
    background: #ffffff;
    border: 1px solid var(--border-color, #d9d9d9);
    border-radius: 16px;
    box-shadow: 0 16px 40px rgba(0,0,0,0.16);
    padding: 16px;
}
body.theme-dark .domain-snapshot-compare-shell,
body.theme-blue .domain-snapshot-compare-shell,
body.theme-terminal .domain-snapshot-compare-shell,
body.theme-purple .domain-snapshot-compare-shell,
body.theme-dark .tool-progress-card,
body.theme-blue .tool-progress-card,
body.theme-terminal .tool-progress-card,
body.theme-purple .tool-progress-card {
    background: var(--bg-primary);
    color: var(--text-primary);
    border-color: var(--border-color);
}
body.theme-dark .domain-snapshot-diff-section,
body.theme-blue .domain-snapshot-diff-section,
body.theme-terminal .domain-snapshot-diff-section,
body.theme-purple .domain-snapshot-diff-section,
body.theme-dark .domain-snapshot-diff-block,
body.theme-blue .domain-snapshot-diff-block,
body.theme-terminal .domain-snapshot-diff-block,
body.theme-purple .domain-snapshot-diff-block,
body.theme-dark .domain-snapshot-diff-empty,
body.theme-blue .domain-snapshot-diff-empty,
body.theme-terminal .domain-snapshot-diff-empty,
body.theme-purple .domain-snapshot-diff-empty,
body.theme-dark .domain-snapshot-diff-block .data-table,
body.theme-blue .domain-snapshot-diff-block .data-table,
body.theme-terminal .domain-snapshot-diff-block .data-table,
body.theme-purple .domain-snapshot-diff-block .data-table {
    background: var(--bg-primary);
    color: var(--text-primary);
    border-color: var(--border-color);
}
.tool-state-return-title {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 6px;
}
.tool-state-return-message {
    color: var(--text-muted, #666);
    margin-bottom: 14px;
}
.tool-state-return-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.tool-state-return-remember {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    font-size: 0.95rem;
}
@media (max-width: 768px) {
    .tool-state-return-actions {
        flex-direction: column;
    }
    .tool-state-return-actions .btn {
        width: 100%;
    }
}


@media (max-width: 768px) {
    .domain-snapshot-compare-modal {
        width: min(100vw - 12px, 100%);
        max-height: calc(100vh - 12px);
    }

    .domain-snapshot-modal-card {
        padding: 14px;
    }

    .domain-snapshot-diff-grid {
        grid-template-columns: 1fr;
    }

    .domain-snapshot-compare-results {
        max-height: min(68vh, 640px);
    }
}

#global-upgrade-alert {
    position: sticky;
    top: 10px;
    z-index: 40;
    margin: 12px 0 0;
}

.admin-global-upgrade-alert {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    border-width: 2px;
    box-shadow: 0 10px 28px rgba(0,0,0,0.10);
}

.admin-global-upgrade-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .admin-global-upgrade-alert {
        flex-direction: column;
        align-items: stretch;
    }

    .admin-global-upgrade-actions {
        width: 100%;
    }

    .admin-global-upgrade-actions .btn {
        width: 100%;
    }
}


.domain-handoff-menu-wrap {
    position: relative;
}

.results-actions > .domain-handoff-menu-wrap {
    flex: 0 0 36px;
    min-width: 36px;
    width: 36px;
}

.domain-handoff-toggle {
    min-width: 36px;
    min-height: 36px;
    padding: 6px;
    gap: 0;
    justify-content: center;
}

.results-actions .domain-handoff-toggle {
    width: 36px;
    min-height: 36px;
    padding: 6px;
}

.domain-handoff-icon {
    font-size: 12px;
    line-height: 1;
    font-weight: 700;
}

.domain-handoff-menu {
    min-width: 220px;
}

.domain-handoff-menu-title {
    padding: 6px 12px 4px;
    font-size: 12px;
    font-weight: 700;
    color: var(--text-secondary);
}

@media (max-width: 768px) {
    .results-header .results-actions:not(.results-actions-mobile-sticky) {
        display: flex;
        flex-wrap: wrap;
        align-items: stretch;
        justify-content: flex-start;
    }

    .results-header .results-actions:not(.results-actions-mobile-sticky) > .btn,
    .results-header .results-actions:not(.results-actions-mobile-sticky) > .export-menu-wrap {
        flex: 1 1 calc(50% - 10px);
        min-width: min(180px, calc(50% - 10px));
        width: auto;
    }

    .results-header .results-actions:not(.results-actions-mobile-sticky) > .domain-handoff-menu-wrap {
        flex: 0 0 40px;
        min-width: 40px;
        width: 40px;
        margin-left: auto;
    }

    .results-header .results-actions:not(.results-actions-mobile-sticky) .domain-handoff-toggle {
        width: 40px;
        min-width: 40px;
        flex: 0 0 40px;
    }

    .tool-info-summary {
        align-items: flex-start;
        flex-direction: column;
    }

    .tool-info-summary-hint {
        font-size: 11px;
    }
}

.tool-progress-card {
  margin-bottom: 16px;
  background: var(--bg-primary, #ffffff);
  color: var(--text-primary, #212529);
  border: 1px solid var(--border-color, #dee2e6);
}
.tool-progress-bar {
  width: 100%;
  height: 12px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.10);
  overflow: hidden;
  margin: 10px 0 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
}
.tool-progress-bar-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #0ea5e9 0%, var(--primary-color, #2563eb) 100%);
  transition: width .25s ease;
}
.tool-progress-steps {
  display: grid;
  gap: 8px;
}
.tool-progress-step {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--text-primary, #212529);
}
.tool-progress-step-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(15, 23, 42, 0.20);
  flex: 0 0 10px;
}
.tool-progress-step.is-done .tool-progress-step-dot {
  background: #16a34a;
}
.tool-progress-step.is-active .tool-progress-step-dot {
  background: var(--primary-color, #2563eb);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.15);
}
.tool-progress-step.is-pending {
  color: var(--text-secondary, rgba(15,23,42,.62));
}
.tool-progress-percent {
  font-weight: 800;
  color: var(--primary-color, #2563eb);
}
.tool-progress-detail {
  margin-top: 12px;
}
body.theme-dark .tool-progress-card,
body.theme-blue .tool-progress-card,
body.theme-terminal .tool-progress-card,
body.theme-purple .tool-progress-card {
  box-shadow: 0 14px 32px rgba(0,0,0,.18);
}
body.theme-dark .tool-progress-bar,
body.theme-terminal .tool-progress-bar {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.14);
}
body.theme-blue .tool-progress-bar,
body.theme-purple .tool-progress-bar {
  background: rgba(255,255,255,.50);
  border-color: rgba(0,0,0,.08);
}
body.theme-dark .tool-progress-step-dot,
body.theme-terminal .tool-progress-step-dot {
  background: rgba(255,255,255,.24);
}
body.theme-terminal .tool-progress-bar-fill,
body.theme-terminal .tool-progress-step.is-active .tool-progress-step-dot {
  background: #00ff88;
}
body.theme-terminal .tool-progress-percent {
  color: #00ff88;
}
body.theme-terminal .tool-progress-step.is-active .tool-progress-step-dot {
  box-shadow: 0 0 0 4px rgba(0,255,136,.18);
}
.snapshot-picker-grid {
  display: grid;
  gap: 12px;
}
.snapshot-picker-grid label {
  display: grid;
  gap: 6px;
  font-weight: 600;
}
@media (min-width: 760px) {
  .snapshot-picker-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.dns-watch-preview-panel,
.dns-watch-results-panel {
    display: block;
    margin-top: 20px;
}

.dns-watch-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 12px;
    margin-bottom: 16px;
}

.dns-watch-summary-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.dns-watch-summary-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 14px;
}

.dns-watch-summary-kicker {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

.dns-watch-summary-value {
    font-size: 16px;
    font-weight: 600;
    word-break: break-word;
}

.dns-watch-preview-text {
    margin-bottom: 10px;
}

.dns-watch-list {
    display: grid;
    gap: 14px;
}

.dns-watch-card {
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 16px;
    background: var(--bg-primary);
}

.dns-watch-card-head {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: start;
    margin-bottom: 10px;
}

.dns-watch-title {
    font-size: 18px;
    font-weight: 600;
}

.dns-watch-record-chip {
    display: inline-block;
    font-size: 12px;
    padding: 3px 8px;
    border-radius: 999px;
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    vertical-align: middle;
}

.dns-watch-meta-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 8px 12px;
    font-size: 14px;
    margin-bottom: 12px;
}

.dns-watch-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}

.dns-watch-detail-panel {
    background: var(--bg-secondary);
    border-radius: 10px;
    padding: 14px;
    margin-top: 8px;
}

.dns-watch-detail-columns {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 14px;
}

.dns-watch-run-list,
.dns-watch-event-list {
    display: grid;
    gap: 10px;
}

.dns-watch-run-item,
.dns-watch-attempt-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 10px;
}

.dns-watch-attempt-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
    margin-top: 10px;
}

.dns-watch-attempt-card.ok {
    border-color: rgba(40,167,69,.45);
}

.dns-watch-attempt-card.warn {
    border-color: rgba(255,193,7,.55);
}

.dns-watch-shortcut-btn {
    white-space: nowrap;
}

.btn-danger {
    background: var(--danger-color);
    color: #fff;
}

.launch-session-card .dns-watch-summary-value {
    min-height: 22px;
}

.launch-session-schedule-row .form-group {
    min-width: 180px;
}


.dns-watch-group-builder {
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 16px;
    background: rgba(15, 23, 42, 0.03);
}

.dns-watch-group-condition-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.dns-watch-group-condition {
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 14px;
    background: #fff;
}


/* Port Scanner */
#port-scanner code {
    display: inline-block;
    max-width: 100%;
    overflow-wrap: anywhere;
}

.port-scan-action-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: flex-start;
}

.port-scan-action-wrap .btn {
    white-space: nowrap;
}

.port-scan-banner {
    width: 100%;
    margin-top: 6px;
    overflow-wrap: anywhere;
}

@media (max-width: 768px) {
    .port-scan-action-wrap .btn {
        white-space: normal;
    }
}

/* v1.39.0 Reports */
.report-builder-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
}

.report-builder-card {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 20px;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.report-builder-kicker,
.dns-tools-report-kicker,
.report-mini-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.report-builder-title,
.dns-tools-report-title {
    margin: 8px 0 10px;
    font-size: 1.35rem;
    line-height: 1.25;
}

.report-builder-copy,
.dns-tools-report-subtitle,
.report-section-lead {
    color: var(--text-secondary);
    line-height: 1.6;
}

.report-copy-block,
.report-table-cell {
    display: block;
    max-width: 100%;
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.report-builder-success {
    display: grid;
    gap: 16px;
}

.report-builder-success-shell {
    padding: 20px;
    border: 1px solid rgba(37, 99, 235, 0.16);
    border-radius: 18px;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.12), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.98));
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.07);
}

.report-builder-success-head {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    flex-wrap: wrap;
}

.report-builder-success-copy {
    flex: 1 1 320px;
    min-width: 0;
}

.report-builder-status-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.report-builder-status-pill,
.dns-tools-report-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(37, 99, 235, 0.18);
    background: rgba(239, 246, 255, 0.95);
    color: #1d4ed8;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.report-builder-actions,
.report-builder-export-actions,
.report-shared-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.report-builder-actions,
.report-shared-actions {
    justify-content: flex-end;
}

.report-builder-export-strip {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
    flex-wrap: wrap;
    padding-top: 16px;
    border-top: 1px solid rgba(148, 163, 184, 0.2);
}

.report-builder-export-label {
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 600;
}

.report-builder-note {
    margin: 0;
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(15, 23, 42, 0.04);
    color: var(--text-secondary);
}

.report-builder-placeholder {
    display: grid;
    gap: 10px;
    padding: 24px;
    border: 1px dashed rgba(148, 163, 184, 0.45);
    border-radius: 16px;
    background:
        radial-gradient(circle at top left, rgba(14, 165, 233, 0.1), transparent 32%),
        linear-gradient(180deg, rgba(248,250,252,0.96), rgba(255,255,255,0.98));
}

.report-builder-placeholder-title {
    margin: 0;
    font-size: 1.05rem;
}

.report-mini-card-grid,
.report-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
}

.report-mini-card,
.report-summary-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px 16px;
    min-width: 0;
}

.report-summary-card[data-accent="success"] {
    border-color: rgba(34, 197, 94, 0.35);
}

.report-summary-card[data-accent="warning"] {
    border-color: rgba(245, 158, 11, 0.45);
}

.report-summary-card[data-accent="danger"] {
    border-color: rgba(239, 68, 68, 0.45);
}

.report-mini-value,
.report-summary-value {
    margin-top: 8px;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--text-primary);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.dns-tools-report-shell {
    display: grid;
    gap: 18px;
}

.dns-tools-report-head {
    display: grid;
    gap: 18px;
}

.dns-tools-report-headcard {
    padding: 20px;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 18px;
    background:
        radial-gradient(circle at top right, rgba(37, 99, 235, 0.1), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.98));
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
}

.dns-tools-report-headtop {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

.dns-tools-report-meta-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}

.dns-tools-report-meta-item {
    display: grid;
    gap: 4px;
    min-width: 160px;
    padding: 10px 12px;
    border-radius: 12px;
    background: rgba(255,255,255,0.88);
    border: 1px solid rgba(148, 163, 184, 0.2);
}

.dns-tools-report-meta-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.dns-tools-report-meta-value {
    color: var(--text-primary);
    font-size: 0.95rem;
}

.dns-tools-report-sections {
    display: grid;
    gap: 18px;
}

.report-section {
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 20px;
    min-width: 0;
}

.report-section-header {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin-bottom: 4px;
}

.report-section-title {
    margin: 0;
    font-size: 1.08rem;
}

.report-kv-list {
    display: grid;
    gap: 8px;
    margin-top: 12px;
}

.report-kv-item {
    display: grid;
    grid-template-columns: minmax(160px, 220px) 1fr;
    gap: 12px;
    padding: 10px 0;
    border-top: 1px solid var(--border-color);
}

.report-kv-item:first-child {
    border-top: 0;
    padding-top: 0;
}

.report-kv-label {
    font-weight: 700;
    color: var(--text-primary);
}

.report-kv-value {
    color: var(--text-primary);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.report-bullet-list {
    display: grid;
    gap: 10px;
    margin: 14px 0 0;
    padding-left: 20px;
}

.report-table-wrap {
    overflow: auto;
    margin-top: 14px;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 14px;
    background: rgba(248, 250, 252, 0.9);
}

.report-data-table {
    width: 100%;
    min-width: 0;
    table-layout: fixed;
    border-collapse: collapse;
}

.report-data-table th,
.report-data-table td {
    overflow-wrap: anywhere;
    word-break: break-word;
    vertical-align: top;
}

.report-shared-banner {
    display: grid;
    gap: 12px;
}

.report-shared-panel {
    overflow: hidden;
    border-radius: 18px;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.08);
}

.report-shared-shell-head {
    align-items: flex-start;
    gap: 16px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.98)),
        radial-gradient(circle at top right, rgba(14, 165, 233, 0.12), transparent 34%);
}

.report-shared-shell-copy {
    display: grid;
    gap: 8px;
    min-width: 0;
}

.report-shared-panel .results-content {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.03), transparent 40%),
        linear-gradient(180deg, rgba(248,250,252,0.92), rgba(255,255,255,0.98));
}

.report-empty-state {
    color: var(--text-secondary);
    margin-top: 12px;
}

.report-menu-wrap .export-toggle {
    min-width: 92px;
}

@media (max-width: 768px) {
    .report-builder-success-head,
    .report-section-header {
        flex-direction: column;
        align-items: stretch;
    }

    .report-builder-actions,
    .report-shared-actions {
        justify-content: flex-start;
    }

    .report-builder-export-strip,
    .dns-tools-report-headtop {
        flex-direction: column;
        align-items: stretch;
    }

    .report-kv-item {
        grid-template-columns: 1fr;
    }
}

@media print {
    .report-shared-panel {
        box-shadow: none;
        border-color: rgba(148, 163, 184, 0.28);
    }

    .report-shared-shell-head,
    .report-shared-panel .results-content {
        background: #fff;
    }

    .report-builder-success-shell {
        box-shadow: none;
        background: #fff;
    }
}

/* v1.41.0 Deep HTTP Diagnostics */
#headerResult table td,
#statusResult table td {
    overflow-wrap: anywhere;
    word-break: break-word;
    vertical-align: top;
}
#headerResult .phase-section-card,
#statusResult .phase-section-card {
    max-width: 100%;
}
#headerResult code,
#statusResult code {
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}
.advanced-settings-block .field-help-text,
.advanced-settings-block .muted {
    line-height: 1.4;
}

/* v1.41.1 Deep HTTP Diagnostics hardening */
#headerResult .results-table,
#statusResult .results-table,
#headerResult table,
#statusResult table {
    table-layout: fixed;
    width: 100%;
}
#headerResult th,
#headerResult td,
#statusResult th,
#statusResult td {
    max-width: 420px;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
}
#headerResult .phase-inline-note,
#statusResult .phase-inline-note,
.http-baseline-comparison-card {
    overflow-wrap: anywhere;
}
#statusFailedRouteSetTable td,
#statusRouteSetTable td,
#headerRawTable td,
#headerCorsTable td,
#headerCacheTable td,
#headerRiskTable td {
    line-height: 1.35;
}
.http-baseline-comparison-card .metric-card-grid {
    margin: 10px 0 12px;
}
@media (max-width: 900px) {
    #headerResult th,
    #headerResult td,
    #statusResult th,
    #statusResult td {
        max-width: 260px;
    }
}

/* v1.42.3 member preference tabs and maintenance mode */
.member-account-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 16px;
}
.member-account-tab {
    border: 1px solid var(--border-color);
    background: var(--card-bg);
    color: var(--text-primary);
    border-radius: 999px;
    padding: 8px 14px;
    cursor: pointer;
    font-weight: 700;
}
.member-account-tab.is-active {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: #fff;
}
.member-account-tab-panel {
    display: none;
}
.member-account-tab-panel.is-active {
    display: block;
}
.maintenance-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 32px 18px;
    background: radial-gradient(circle at top, rgba(59, 130, 246, 0.12), transparent 42%), var(--bg-color);
}
.maintenance-card {
    width: min(680px, 100%);
    text-align: center;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 24px;
    box-shadow: var(--shadow-lg);
    padding: 42px 32px;
}
.maintenance-icon {
    font-size: clamp(4rem, 12vw, 8rem);
    line-height: 1;
    margin-bottom: 18px;
}
.maintenance-title {
    font-size: clamp(1.8rem, 4vw, 3rem);
    margin: 0 0 12px;
}
.maintenance-message {
    font-size: 1.08rem;
    color: var(--text-secondary);
    line-height: 1.7;
    margin: 0 auto;
    max-width: 48rem;
}

/* v1.44.4 member preference bridge: compact result density */
.member-pref-compact-results .results-content,
.member-pref-compact-results .results-panel,
.member-pref-compact-results .enhanced-results-table th,
.member-pref-compact-results .enhanced-results-table td,
.member-pref-compact-results .phase-table th,
.member-pref-compact-results .phase-table td {
    font-size: 0.92rem;
}
.member-pref-compact-results .result-card,
.member-pref-compact-results .summary-card,
.member-pref-compact-results .metric-card,
.member-pref-compact-results .results-panel {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

/* v1.45.1 maintenance editor and rendered message polish */
.maintenance-editor-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 8px;
}
.maintenance-rich-editor {
    min-height: 170px;
    padding: 14px 16px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    background: var(--input-bg, var(--card-bg));
    color: var(--text-primary);
    line-height: 1.6;
    outline: none;
}
.maintenance-rich-editor:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.16);
}
.maintenance-preview-panel .maintenance-message,
.maintenance-card .maintenance-message {
    text-align: left;
}
.maintenance-message h1,
.maintenance-message h2,
.maintenance-message h3,
.maintenance-message h4,
.maintenance-rich-editor h1,
.maintenance-rich-editor h2,
.maintenance-rich-editor h3,
.maintenance-rich-editor h4 {
    color: var(--text-primary);
    line-height: 1.2;
    margin: 0.25em 0 0.45em;
}
.maintenance-message p,
.maintenance-rich-editor p {
    margin: 0 0 0.8em;
}
.maintenance-message ul,
.maintenance-message ol,
.maintenance-rich-editor ul,
.maintenance-rich-editor ol {
    margin: 0.4em 0 0.9em;
    padding-left: 1.4em;
}
.maintenance-message a,
.maintenance-rich-editor a {
    color: var(--primary-color);
    font-weight: 700;
}

/* v1.45.2 PWA polish and maintenance editor hardening */
.pwa-update-banner {
    position: fixed;
    left: 50%;
    bottom: 22px;
    transform: translate(-50%, 24px);
    opacity: 0;
    z-index: 10050;
    display: flex;
    align-items: center;
    gap: 16px;
    max-width: min(720px, calc(100vw - 28px));
    padding: 14px 16px;
    border: 1px solid var(--border-color, rgba(148, 163, 184, .4));
    border-radius: 18px;
    background: var(--bg-primary, #fff);
    color: var(--text-primary, #1f2937);
    box-shadow: 0 18px 48px rgba(15, 23, 42, .24);
    transition: transform .2s ease, opacity .2s ease;
}
.pwa-update-banner.show { opacity: 1; transform: translate(-50%, 0); }
.pwa-update-copy { display: grid; gap: 2px; min-width: 0; }
.pwa-update-copy span { color: var(--text-secondary, #64748b); font-size: .9rem; }
.pwa-update-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.pwa-standalone body,
body.pwa-standalone { min-height: 100dvh; }
body.pwa-standalone .top-bar { padding-top: max(12px, env(safe-area-inset-top)); }
.maintenance-icon-choice-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.maintenance-icon-choice {
    width: 44px;
    height: 44px;
    display: inline-grid;
    place-items: center;
    border-radius: 14px;
    border: 1px solid var(--border-color, #d1d5db);
    background: var(--bg-primary, #fff);
    color: var(--text-primary, #111827);
    font-size: 1.35rem;
    cursor: pointer;
}
.maintenance-icon-choice:hover,
.maintenance-icon-choice:focus { border-color: var(--primary-color, #2563eb); outline: none; box-shadow: 0 0 0 3px rgba(37, 99, 235, .16); }
.maintenance-icon-choice.is-active { background: var(--primary-color, #2563eb); color: #fff; border-color: var(--primary-color, #2563eb); }
.pwa-offline-page .maintenance-card { max-width: 720px; }
@media (max-width: 640px) {
    .pwa-update-banner { align-items: stretch; flex-direction: column; }
    .pwa-update-actions .btn { flex: 1 1 auto; }
}

/* v1.45.3 PWA preset theme picker and maintenance editor hardening */
.pwa-settings-hero {
    margin: 16px;
    padding: 20px;
    border: 1px solid color-mix(in srgb, var(--pwa-hero-theme, #2563eb) 36%, var(--border-color, #dbe4f0));
    border-radius: 22px;
    background:
        radial-gradient(circle at 18% 15%, color-mix(in srgb, var(--pwa-hero-accent, #60a5fa) 28%, transparent), transparent 34%),
        linear-gradient(135deg, color-mix(in srgb, var(--pwa-hero-bg, #fff) 88%, #fff), color-mix(in srgb, var(--pwa-hero-theme, #2563eb) 16%, var(--bg-primary, #fff)));
    color: color-mix(in srgb, var(--pwa-hero-text, #0f172a) 88%, var(--text-primary, #0f172a));
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 280px);
    gap: 20px;
    align-items: center;
    overflow: hidden;
}
.pwa-settings-hero h3 { margin: 4px 0 8px; font-size: 1.35rem; color: inherit; }
.pwa-settings-hero p { margin: 0; max-width: 760px; color: color-mix(in srgb, currentColor 72%, transparent); line-height: 1.55; }
.pwa-kicker { display: inline-flex; align-items: center; gap: 6px; font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; font-weight: 800; color: var(--pwa-hero-theme, #2563eb); }
.pwa-device-preview {
    min-height: 168px;
    border-radius: 26px;
    padding: 10px;
    background: color-mix(in srgb, var(--pwa-hero-theme, #2563eb) 20%, rgba(255,255,255,.72));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.42), 0 24px 60px rgba(15, 23, 42, .18);
}
.pwa-device-bar { height: 34px; border-radius: 18px 18px 8px 8px; background: var(--pwa-hero-theme, #2563eb); position: relative; }
.pwa-device-bar::after { content: ''; position: absolute; left: 14px; top: 11px; width: 44px; height: 8px; border-radius: 99px; background: color-mix(in srgb, var(--pwa-hero-accent, #60a5fa) 60%, white); opacity: .86; }
.pwa-device-body { min-height: 110px; border-radius: 10px 10px 20px 20px; padding: 18px; background: var(--pwa-hero-bg, #fff); color: var(--pwa-hero-text, #0f172a); display: grid; align-content: center; gap: 8px; }
.pwa-device-body strong { font-size: 1.18rem; }
.pwa-device-body span { color: color-mix(in srgb, var(--pwa-hero-text, #0f172a) 62%, transparent); font-size: .9rem; }
.pwa-preset-section { margin: 0 16px 16px; }
.pwa-section-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 12px; }
.pwa-section-heading h4 { margin: 0 0 4px; }
.pwa-section-heading p { margin: 0; color: var(--text-secondary, #64748b); }
.pwa-preset-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 12px; }
.pwa-preset-card {
    appearance: none;
    border: 1px solid color-mix(in srgb, var(--pwa-preset-theme, #2563eb) 28%, var(--border-color, #dbe4f0));
    border-radius: 18px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--pwa-preset-bg, #fff) 88%, #fff), color-mix(in srgb, var(--pwa-preset-theme, #2563eb) 14%, var(--bg-primary, #fff)));
    color: var(--pwa-preset-text, var(--text-primary, #0f172a));
    padding: 14px;
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 12px;
    text-align: left;
    cursor: pointer;
    position: relative;
    min-height: 122px;
    box-shadow: 0 10px 26px rgba(15, 23, 42, .08);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.pwa-preset-card:hover, .pwa-preset-card:focus { transform: translateY(-2px); border-color: var(--pwa-preset-theme, #2563eb); box-shadow: 0 18px 42px rgba(15, 23, 42, .14); outline: none; }
.pwa-preset-card.is-active { border-width: 2px; box-shadow: 0 0 0 3px color-mix(in srgb, var(--pwa-preset-accent, #60a5fa) 24%, transparent), 0 18px 42px rgba(15, 23, 42, .16); }
.pwa-preset-swatch { width: 54px; height: 54px; border-radius: 16px; background: var(--pwa-preset-theme, #2563eb); display: grid; place-items: center; box-shadow: inset 0 1px 0 rgba(255,255,255,.35); }
.pwa-preset-swatch span { width: 26px; height: 26px; border-radius: 9px; background: var(--pwa-preset-accent, #60a5fa); box-shadow: 12px 10px 0 -4px var(--pwa-preset-bg, #fff); }
.pwa-preset-copy { display: grid; gap: 5px; padding-right: 62px; }
.pwa-preset-copy strong { color: inherit; }
.pwa-preset-copy small { color: color-mix(in srgb, var(--pwa-preset-text, #0f172a) 66%, transparent); line-height: 1.38; }
.pwa-preset-chip { position: absolute; top: 12px; right: 12px; font-size: .72rem; font-weight: 800; border-radius: 999px; padding: 4px 8px; background: color-mix(in srgb, var(--pwa-preset-theme, #2563eb) 16%, var(--bg-primary, #fff)); color: var(--pwa-preset-theme, #2563eb); }
.pwa-preset-card.is-active .pwa-preset-chip { background: var(--pwa-preset-theme, #2563eb); color: #fff; }
.pwa-custom-colors { border-top: 1px solid var(--border-color, #dbe4f0); }
.maintenance-editor-heading-row { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; margin-bottom: 12px; }
.maintenance-template-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.maintenance-source-editor { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace; line-height: 1.5; }
.maintenance-editor-toolbar .btn.active,
#maintenanceSourceToggle.active { background: var(--primary-color, #2563eb); color: #fff; border-color: var(--primary-color, #2563eb); }
.maintenance-icon-choice { min-width: 70px; width: auto; height: 58px; padding: 6px 8px; gap: 2px; grid-auto-flow: row; }
.maintenance-icon-choice small { display: block; font-size: .68rem; line-height: 1; opacity: .78; }
.maintenance-rich-editor:empty::before { content: 'Type the maintenance message shown to visitors...'; color: var(--text-muted, #94a3b8); }
@media (max-width: 760px) {
    .pwa-settings-hero { grid-template-columns: 1fr; }
    .pwa-device-preview { max-width: 360px; width: 100%; }
    .maintenance-editor-heading-row { flex-direction: column; }
    .maintenance-template-actions { justify-content: flex-start; }
}

/* v1.45.3 Cron Health dashboard polish */
.cron-health-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px;
    border: 1px solid var(--border-color, #dbe4f0);
    border-radius: 18px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent-primary, #2563eb) 12%, var(--bg-primary, #fff)), var(--bg-secondary, #f8fafc));
    box-shadow: 0 14px 36px rgba(15, 23, 42, .08);
}
.cron-health-hero p { margin: 0; color: var(--text-secondary, #475569); max-width: 820px; }
.cron-health-meter {
    min-width: 118px;
    min-height: 88px;
    border-radius: 20px;
    display: grid;
    place-items: center;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .04em;
    border: 1px solid currentColor;
    background: color-mix(in srgb, currentColor 11%, transparent);
}
.cron-script-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(310px, 1fr)); gap: 14px; margin-top: 16px; }
.cron-script-card {
    border: 1px solid var(--border-color, #dbe4f0);
    border-radius: 18px;
    padding: 16px;
    background: var(--bg-primary, #fff);
    box-shadow: 0 10px 30px rgba(15, 23, 42, .06);
}
.cron-script-heading { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.cron-script-heading h4 { margin: 0 0 6px; }
.cron-script-badges { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 6px; }
.cron-command-details { margin-top: 12px; border-top: 1px solid var(--border-color, #dbe4f0); padding-top: 12px; }
.cron-command-details summary { cursor: pointer; font-weight: 800; color: var(--accent-primary, #2563eb); }
.status-badge { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 4px 9px; font-size: .72rem; font-weight: 800; border: 1px solid var(--border-color, #dbe4f0); background: var(--bg-secondary, #f8fafc); color: var(--text-secondary, #475569); }
.status-badge.status-ok { border-color: color-mix(in srgb, #16a34a 38%, var(--border-color, #dbe4f0)); color: #15803d; background: color-mix(in srgb, #22c55e 12%, var(--bg-primary, #fff)); }
.status-badge.status-danger { border-color: color-mix(in srgb, #dc2626 40%, var(--border-color, #dbe4f0)); color: #b91c1c; background: color-mix(in srgb, #ef4444 12%, var(--bg-primary, #fff)); }
.status-badge.status-badge-warning { border-color: color-mix(in srgb, #f59e0b 44%, var(--border-color, #dbe4f0)); color: #92400e; background: color-mix(in srgb, #f59e0b 14%, var(--bg-primary, #fff)); }
.theme-dark .cron-script-card,
.theme-blue .cron-script-card,
.theme-terminal .cron-script-card,
.theme-purple .cron-script-card { background: color-mix(in srgb, var(--bg-primary, #0f172a) 88%, #fff 4%); }
.theme-dark .status-badge.status-ok,
.theme-blue .status-badge.status-ok,
.theme-terminal .status-badge.status-ok,
.theme-purple .status-badge.status-ok { color: #86efac; }
.theme-dark .status-badge.status-danger,
.theme-blue .status-badge.status-danger,
.theme-terminal .status-badge.status-danger,
.theme-purple .status-badge.status-danger { color: #fecaca; }
.theme-dark .status-badge.status-badge-warning,
.theme-blue .status-badge.status-badge-warning,
.theme-terminal .status-badge.status-badge-warning,
.theme-purple .status-badge.status-badge-warning { color: #fde68a; }
@media (max-width: 760px) {
    .cron-health-hero { align-items: stretch; flex-direction: column; }
    .cron-health-meter { min-height: 64px; width: 100%; }
}

/* v1.45.6 Cron setup assistant and database backup/restore hardening */
.cron-setup-assistant {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
    gap: 16px;
    margin: 16px 0;
    padding: 16px;
    border: 1px solid var(--border-color, #dbe4f0);
    border-radius: 18px;
    background: color-mix(in srgb, var(--accent-primary, #2563eb) 7%, var(--bg-primary, #fff));
    box-shadow: 0 10px 30px rgba(15, 23, 42, .06);
}
.cron-command-primary {
    border-left: 4px solid var(--accent-primary, #2563eb);
    font-weight: 700;
}
.cron-setup-steps {
    margin: 8px 0 0;
    padding-left: 22px;
    color: var(--text-primary, #0f172a);
}
.cron-setup-steps li { margin: 6px 0; }
.database-danger-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 16px;
}
.database-action-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--border-color, #dbe4f0);
    border-radius: 18px;
    background: var(--bg-primary, #fff);
    box-shadow: 0 10px 30px rgba(15, 23, 42, .06);
}
.database-action-card h4 { margin: 0 0 6px; }
.database-action-icon {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: color-mix(in srgb, var(--accent-primary, #2563eb) 14%, var(--bg-secondary, #f8fafc));
    font-size: 1.35rem;
}
.database-action-card--restore {
    border-color: color-mix(in srgb, #dc2626 32%, var(--border-color, #dbe4f0));
}
.database-action-card--restore .database-action-icon {
    background: color-mix(in srgb, #dc2626 14%, var(--bg-secondary, #f8fafc));
}
.admin-inline-feedback--danger {
    background: color-mix(in srgb, #dc2626 12%, var(--bg-primary, #fff));
    border-color: color-mix(in srgb, #dc2626 36%, var(--border-color, #dbe4f0));
    color: color-mix(in srgb, #7f1d1d 80%, var(--text-primary, #0f172a));
}
.theme-dark .cron-setup-assistant,
.theme-blue .cron-setup-assistant,
.theme-terminal .cron-setup-assistant,
.theme-purple .cron-setup-assistant,
.theme-dark .database-action-card,
.theme-blue .database-action-card,
.theme-terminal .database-action-card,
.theme-purple .database-action-card {
    background: color-mix(in srgb, var(--bg-primary, #0f172a) 88%, #fff 4%);
}
.theme-dark .admin-inline-feedback--danger,
.theme-blue .admin-inline-feedback--danger,
.theme-terminal .admin-inline-feedback--danger,
.theme-purple .admin-inline-feedback--danger {
    color: #fecaca;
}
@media (max-width: 760px) {
    .cron-setup-assistant,
    .database-danger-grid,
    .database-action-card { grid-template-columns: 1fr; }
    .database-action-icon { width: 100%; }
}

/* v1.45.7 Cron cockpit and universal hosting-panel setup polish */
.cron-profile-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 14px;
    margin: 16px 0;
}
.cron-profile-card {
    border: 1px solid var(--border-color, #dbe4f0);
    border-radius: 18px;
    padding: 16px;
    background: var(--bg-primary, #fff);
    box-shadow: 0 12px 34px rgba(15, 23, 42, .07);
}
.cron-profile-card--recommended {
    border-color: color-mix(in srgb, var(--accent-primary, #2563eb) 42%, var(--border-color, #dbe4f0));
    box-shadow: 0 14px 38px color-mix(in srgb, var(--accent-primary, #2563eb) 14%, transparent);
}
.cron-field-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(48px, 1fr));
    gap: 8px;
    margin-top: 12px;
}
.cron-field-grid div {
    border: 1px solid var(--border-color, #dbe4f0);
    border-radius: 12px;
    padding: 8px;
    background: color-mix(in srgb, var(--accent-primary, #2563eb) 5%, var(--bg-primary, #fff));
    text-align: center;
}
.cron-field-grid span {
    display: block;
    color: var(--text-secondary, #64748b);
    font-size: .7rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.cron-field-grid strong {
    display: block;
    margin-top: 3px;
    font-size: 1.25rem;
    line-height: 1;
}
.cron-note-list {
    margin: 12px 0 0;
    padding-left: 18px;
    color: var(--text-secondary, #475569);
}
.cron-php-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 10px;
}
.cron-script-badges .status-badge + .status-badge { margin-left: 6px; }
.theme-dark .cron-profile-card,
.theme-blue .cron-profile-card,
.theme-terminal .cron-profile-card,
.theme-purple .cron-profile-card { background: color-mix(in srgb, var(--bg-primary, #0f172a) 88%, #fff 4%); }
@media (max-width: 760px) {
    .cron-field-grid { grid-template-columns: repeat(2, minmax(80px, 1fr)); }
}
