/**
 * Frank Dead Link Checker - Admin Styles
 * Modern, beautiful admin interface
 */

/* ==================================================
   CSS Variables & Theme
   ================================================== */
:root {
    --frankdlc-primary: #3b82f6;
    --frankdlc-primary-dark: #2563eb;
    --frankdlc-success: #10b981;
    --frankdlc-success-dark: #059669;
    --frankdlc-warning: #f59e0b;
    --frankdlc-warning-dark: #d97706;
    --frankdlc-danger: #ef4444;
    --frankdlc-danger-dark: #dc2626;
    --frankdlc-gray-50: #f9fafb;
    --frankdlc-gray-100: #f3f4f6;
    --frankdlc-gray-200: #e5e7eb;
    --frankdlc-gray-300: #d1d5db;
    --frankdlc-gray-400: #9ca3af;
    --frankdlc-gray-500: #6b7280;
    --frankdlc-gray-600: #4b5563;
    --frankdlc-gray-700: #374151;
    --frankdlc-gray-800: #1f2937;
    --frankdlc-gray-900: #111827;
    --frankdlc-radius: 4px;
    --frankdlc-radius-lg: 6px;
    --frankdlc-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
    --frankdlc-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --frankdlc-transition: all 0.2s ease;
}

/* ==================================================
   Main Wrapper
   ================================================== */
.frankdlc-wrap {
    width: 100%;
    margin: 20px 20px 20px 0;
    padding: 20px;
    box-sizing: border-box;
}

/* Move WordPress admin notices outside our layout flow */
.frankdlc-wrap>.notice,
.frankdlc-wrap>.updated,
.frankdlc-wrap>.error,
.frankdlc-wrap>.update-nag,
.frankdlc-wrap>div.notice,
.frankdlc-wrap>div[class*="notice"]:not(.frankdlc-notices-container),
.frankdlc-header .notice,
.frankdlc-header .updated,
.frankdlc-header .error,
.frankdlc-header div[class*="notice"] {
    display: none !important;
}

/* Container for relocated notices - shown below header */
.frankdlc-notices-container {
    margin-bottom: 16px;
}

.frankdlc-notices-container>.notice,
.frankdlc-notices-container>.updated,
.frankdlc-notices-container>.error,
.frankdlc-notices-container>div[class*="notice"] {
    display: block !important;
    margin: 0 0 10px 0;
    border-radius: var(--frankdlc-radius);
}

.frankdlc-wrap h1 {
    font-size: 28px;
    font-weight: 600;
    color: var(--frankdlc-gray-800);
    margin: 0;
}

/* ==================================================
   Header
   ================================================== */
.frankdlc-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--frankdlc-gray-200);
    flex-wrap: wrap;
    gap: 16px;
}

.frankdlc-header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.frankdlc-header-left {
    display: flex;
    align-items: center;
    gap: 16px;
}

.frankdlc-last-scan {
    background: var(--frankdlc-gray-100);
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 13px;
    color: var(--frankdlc-gray-600);
}

.frankdlc-queue-status {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    cursor: help;
}

.frankdlc-queue-status .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

.frankdlc-queue-reliable {
    background: rgba(34, 197, 94, 0.15);
    color: var(--frankdlc-success-dark);
}

.frankdlc-queue-basic {
    background: rgba(234, 179, 8, 0.15);
    color: var(--frankdlc-warning-dark);
}

/* Export Dropdown */
.frankdlc-export-dropdown {
    position: relative;
    display: inline-block;
}

#frankdlc-export-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

#frankdlc-export-btn .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

#frankdlc-export-btn .dashicons-arrow-down-alt2 {
    font-size: 14px;
    width: 14px;
    height: 14px;
    margin-left: 2px;
}

.frankdlc-export-menu {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 4px;
    background: #fff;
    border: 1px solid var(--frankdlc-gray-200);
    border-radius: var(--frankdlc-radius);
    box-shadow: var(--frankdlc-shadow-lg);
    min-width: 180px;
    z-index: 1000;
    overflow: hidden;
}

.frankdlc-export-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    color: var(--frankdlc-gray-700);
    text-decoration: none;
    font-size: 13px;
    transition: background 0.15s;
}

.frankdlc-export-option:hover {
    background: var(--frankdlc-gray-100);
    color: var(--frankdlc-primary);
}

.frankdlc-export-option .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
    color: var(--frankdlc-gray-500);
}

.frankdlc-export-option:hover .dashicons {
    color: var(--frankdlc-primary);
}

/* Redirect Modal */
.frankdlc-redirect-info {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    background: rgba(59, 130, 246, 0.1);
    padding: 12px 14px;
    border-radius: var(--frankdlc-radius);
    margin-bottom: 8px;
    font-size: 13px;
    color: var(--frankdlc-primary-dark);
    line-height: 1.5;
}

.frankdlc-redirect-info .dashicons {
    flex-shrink: 0;
    margin-top: 2px;
}

.frankdlc-modal-body select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--frankdlc-gray-300);
    border-radius: var(--frankdlc-radius);
    font-size: 14px;
    background: #fff;
}

/* Redirect action button */
.frankdlc-action-btn.frankdlc-redirect {
    color: var(--frankdlc-primary);
}

.frankdlc-action-btn.frankdlc-redirect:hover {
    background: rgba(59, 130, 246, 0.1);
}

/* Help Tooltip */
.frankdlc-help-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin-left: 4px;
    cursor: help;
    vertical-align: middle;
}

.frankdlc-help-icon .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
    color: var(--frankdlc-gray-400);
    transition: color 0.2s;
}

.frankdlc-help-icon:hover .dashicons,
.frankdlc-help-icon:focus .dashicons {
    color: var(--frankdlc-primary);
}

.frankdlc-help-tooltip {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    width: 320px;
    padding: 16px;
    background: #fff;
    border-radius: var(--frankdlc-radius-lg);
    box-shadow: var(--frankdlc-shadow-lg);
    border: 1px solid var(--frankdlc-gray-200);
    text-align: left;
    font-weight: normal;
}

.frankdlc-help-icon:hover .frankdlc-help-tooltip,
.frankdlc-help-icon:focus .frankdlc-help-tooltip {
    display: block;
}

.frankdlc-help-tooltip h4 {
    margin: 0 0 12px 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--frankdlc-gray-900);
    border-bottom: 1px solid var(--frankdlc-gray-200);
    padding-bottom: 8px;
}

.frankdlc-help-tooltip dl {
    margin: 0;
    max-height: 300px;
    overflow-y: auto;
}

.frankdlc-help-tooltip dt {
    font-weight: 600;
    font-size: 13px;
    margin-top: 8px;
    padding: 2px 8px;
    border-radius: 4px;
    display: inline-block;
}

.frankdlc-help-tooltip dd {
    margin: 4px 0 0 0;
    font-size: 12px;
    color: var(--frankdlc-gray-600);
    line-height: 1.4;
}

.frankdlc-help-tooltip dt.frankdlc-status-good {
    background: rgba(34, 197, 94, 0.15);
    color: var(--frankdlc-success-dark);
}

.frankdlc-help-tooltip dt.frankdlc-status-redirect {
    background: rgba(234, 179, 8, 0.15);
    color: var(--frankdlc-warning-dark);
}

.frankdlc-help-tooltip dt.frankdlc-status-bad {
    background: rgba(239, 68, 68, 0.15);
    color: var(--frankdlc-error-dark);
}

.frankdlc-help-tooltip dt.frankdlc-status-error {
    background: rgba(239, 68, 68, 0.2);
    color: var(--frankdlc-error);
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .button-hero {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: 44px;
    padding: 0 20px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    border-radius: var(--frankdlc-radius);
    border: 1px solid var(--frankdlc-gray-300);
    background: #fff;
    color: var(--frankdlc-gray-700);
    box-shadow: var(--frankdlc-shadow);
    transition: var(--frankdlc-transition);
    cursor: pointer;
    box-sizing: border-box;
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .button-hero:hover {
    background: var(--frankdlc-gray-50);
    border-color: var(--frankdlc-gray-400);
    color: var(--frankdlc-gray-900);
    transform: translateY(-1px);
    box-shadow: var(--frankdlc-shadow-lg);
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .button-hero.button-primary {
    background: linear-gradient(135deg, var(--frankdlc-primary), var(--frankdlc-primary-dark));
    border: none;
    color: #fff;
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .button-hero.button-primary:hover {
    background: linear-gradient(135deg, var(--frankdlc-primary-dark), #1d4ed8);
    color: #fff;
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .button-hero:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .button-hero .dashicons {
    font-size: 18px;
    width: 18px;
    height: 18px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .button-hero .dashicons-arrow-down-alt2 {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

/* Stop Scan Button */
#wpbody-content .frankdlc-wrap .frankdlc-header-actions .frankdlc-stop-btn {
    background: linear-gradient(135deg, var(--frankdlc-danger), var(--frankdlc-danger-dark));
    color: #fff;
    border: none;
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .frankdlc-stop-btn:hover {
    background: linear-gradient(135deg, var(--frankdlc-danger-dark), #b91c1c);
    color: #fff;
}

#wpbody-content .frankdlc-wrap .frankdlc-header-actions .frankdlc-stop-btn .dashicons {
    color: #fff;
}

/* ==================================================
   Stats Grid
   ================================================== */
.frankdlc-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 24px;
}

@media (max-width: 1200px) {
    .frankdlc-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .frankdlc-stats-grid {
        grid-template-columns: 1fr;
    }
}

.frankdlc-stat-card {
    background: #fff;
    border-radius: var(--frankdlc-radius-lg);
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 16px;
    box-shadow: var(--frankdlc-shadow);
    transition: var(--frankdlc-transition);
    border: 1px solid var(--frankdlc-gray-200);
}

.frankdlc-stat-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--frankdlc-shadow-lg);
}

.frankdlc-stat-icon {
    width: 56px;
    height: 56px;
    border-radius: var(--frankdlc-radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
}

.frankdlc-stat-icon .dashicons {
    font-size: 28px;
    width: 28px;
    height: 28px;
    color: #fff;
}

.frankdlc-stat-broken .frankdlc-stat-icon {
    background: linear-gradient(135deg, var(--frankdlc-danger), var(--frankdlc-danger-dark));
}

.frankdlc-stat-warning .frankdlc-stat-icon {
    background: linear-gradient(135deg, var(--frankdlc-warning), var(--frankdlc-warning-dark));
}

.frankdlc-stat-working .frankdlc-stat-icon {
    background: linear-gradient(135deg, var(--frankdlc-success), var(--frankdlc-success-dark));
}

.frankdlc-stat-total .frankdlc-stat-icon {
    background: linear-gradient(135deg, var(--frankdlc-primary), var(--frankdlc-primary-dark));
}

.frankdlc-stat-content {
    flex: 1;
}

.frankdlc-stat-value {
    display: block;
    font-size: 32px;
    font-weight: 700;
    color: var(--frankdlc-gray-800);
    line-height: 1;
    margin-bottom: 4px;
}

.frankdlc-stat-label {
    font-size: 14px;
    color: var(--frankdlc-gray-500);
    font-weight: 500;
}

/* ==================================================
   Scan Progress
   ================================================== */
.frankdlc-scan-progress {
    background: #fff;
    border-radius: var(--frankdlc-radius);
    padding: 20px;
    margin-bottom: 24px;
    box-shadow: var(--frankdlc-shadow);
    border: 1px solid var(--frankdlc-gray-200);
}

.frankdlc-progress-bar {
    height: 8px;
    background: var(--frankdlc-gray-200);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 10px;
}

.frankdlc-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--frankdlc-primary), var(--frankdlc-success));
    border-radius: 4px;
    transition: width 0.3s ease;
    width: 0%;
}

.frankdlc-progress-text {
    font-size: 14px;
    color: var(--frankdlc-gray-600);
}

/* ==================================================
   Filter Tabs
   ================================================== */
.frankdlc-filters {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 16px;
}

.frankdlc-filter-tabs {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 4px;
    background: var(--frankdlc-gray-100);
    border-radius: var(--frankdlc-radius);
    overflow: hidden;
    gap: 4px;
}

.frankdlc-filter-tabs li {
    margin: 0;
}

.frankdlc-filter-tabs a {
    display: block;
    padding: 8px 16px;
    text-decoration: none;
    color: var(--frankdlc-gray-600);
    font-weight: 500;
    font-size: 14px;
    transition: var(--frankdlc-transition);
    border-radius: 6px;
    white-space: nowrap;
}

.frankdlc-filter-tabs a:hover {
    color: var(--frankdlc-gray-800);
    background: rgba(255, 255, 255, 0.5);
}

.frankdlc-filter-tabs a.active {
    background: #fff;
    color: var(--frankdlc-primary);
    box-shadow: var(--frankdlc-shadow);
}

.frankdlc-filter-tabs a span {
    opacity: 0.6;
    margin-left: 4px;
}

.frankdlc-search-form {
    display: flex;
    gap: 8px;
}

.frankdlc-search-form input[type="search"] {
    min-width: 250px;
}

/* ==================================================
   Advanced Filters
   ================================================== */
.frankdlc-advanced-filters {
    background: var(--frankdlc-gray-50);
    border: 1px solid var(--frankdlc-gray-200);
    border-radius: var(--frankdlc-radius);
    padding: 16px;
    margin-bottom: 16px;
}

.frankdlc-filter-form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
}

.frankdlc-filter-group {
    display: flex;
    align-items: center;
    gap: 8px;
}

.frankdlc-filter-group label {
    font-size: 13px;
    font-weight: 500;
    color: var(--frankdlc-gray-600);
    white-space: nowrap;
}

.frankdlc-filter-group input[type="date"] {
    width: 130px;
}

.wp-core-ui .frankdlc-wrap .frankdlc-clear-filters {
    color: var(--frankdlc-danger);
}

/* ==================================================
   Sortable Headers
   ================================================== */
.frankdlc-links-table th.sortable a,
.frankdlc-links-table th.sorted a {
    display: flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
    padding: 14px 16px;
}

.frankdlc-links-table th .sorting-indicator {
    display: inline-block;
    width: 0;
    height: 0;
    margin-left: 6px;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    opacity: 0.3;
    border-bottom: 4px solid currentColor;
}

.frankdlc-links-table th.sortable:hover .sorting-indicator {
    opacity: 0.6;
}

.frankdlc-links-table th.sorted .sorting-indicator {
    opacity: 1;
}

.frankdlc-links-table th.sorted.asc .sorting-indicator {
    border-bottom: 4px solid currentColor;
    border-top: none;
}

.frankdlc-links-table th.sorted.desc .sorting-indicator {
    border-top: 4px solid currentColor;
    border-bottom: none;
}

.frankdlc-col-checked {
    width: 110px;
}

.frankdlc-unchecked {
    color: var(--frankdlc-gray-400);
    font-style: italic;
}

/* ==================================================
   Bulk Actions
   ================================================== */
.frankdlc-bulk-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}

.frankdlc-bulk-actions select {
    min-width: 150px;
}

.frankdlc-bulk-result {
    margin-left: 10px;
    font-size: 14px;
    color: var(--frankdlc-success);
}

/* ==================================================
   Links Table
   ================================================== */
.frankdlc-links-table {
    background: #fff;
    border-radius: var(--frankdlc-radius-lg);
    overflow: hidden;
    box-shadow: var(--frankdlc-shadow);
    border: 1px solid var(--frankdlc-gray-200);
}

.frankdlc-links-table thead th {
    background: var(--frankdlc-gray-50);
    padding: 14px 16px;
    font-weight: 600;
    color: var(--frankdlc-gray-700);
    border-bottom: 1px solid var(--frankdlc-gray-200);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.frankdlc-links-table tbody td {
    padding: 14px 16px;
    vertical-align: middle;
    border-bottom: 1px solid var(--frankdlc-gray-100);
}

.frankdlc-links-table tbody tr:hover {
    background: var(--frankdlc-gray-50);
}

.frankdlc-links-table tbody tr:last-child td {
    border-bottom: none;
}

.frankdlc-col-status {
    width: 80px;
}

.frankdlc-col-type {
    width: 100px;
}

.frankdlc-col-source {
    width: 200px;
}

.frankdlc-col-actions {
    width: 140px;
    text-align: right;
}

/* Checkbox Column Fix */
.wp-list-table.frankdlc-links-table thead th.check-column,
.wp-list-table.frankdlc-links-table tbody td.check-column {
    width: 40px;
    padding: 14px 8px 14px 16px;
    vertical-align: middle;
}

.frankdlc-links-table .check-column input[type="checkbox"] {
    margin: 0;
    vertical-align: middle;
}

/* Status Badges */
.frankdlc-status-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

.frankdlc-status-broken {
    background: #fef2f2;
    color: var(--frankdlc-danger);
}

.frankdlc-status-warning {
    background: #fffbeb;
    color: var(--frankdlc-warning-dark);
}

.frankdlc-status-ok {
    background: #ecfdf5;
    color: var(--frankdlc-success);
}

.frankdlc-status-unchecked {
    background: var(--frankdlc-gray-100);
    color: var(--frankdlc-gray-500);
}

/* Type Badges */
.frankdlc-type-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
    background: var(--frankdlc-gray-100);
    color: var(--frankdlc-gray-600);
}

.frankdlc-type-external {
    background: #eff6ff;
    color: #1d4ed8;
}

.frankdlc-type-internal {
    background: #f0fdf4;
    color: #15803d;
}

.frankdlc-type-image {
    background: #fdf4ff;
    color: #a21caf;
}

/* URL Column */
.frankdlc-url-wrap a {
    color: var(--frankdlc-gray-800);
    text-decoration: none;
    font-weight: 500;
    word-break: break-all;
}

.frankdlc-url-wrap a:hover {
    color: var(--frankdlc-primary);
}

.frankdlc-redirect-info,
.frankdlc-anchor-text {
    display: block;
    font-size: 12px;
    color: var(--frankdlc-gray-500);
    margin-top: 4px;
}

.frankdlc-redirect-info {
    color: var(--frankdlc-warning-dark);
}

/* Action Buttons */
.frankdlc-actions-wrap {
    display: flex;
    gap: 6px;
    justify-content: flex-end;
}

.frankdlc-action-btn {
    width: 32px;
    height: 32px;
    border: none;
    background: var(--frankdlc-gray-100);
    border-radius: var(--frankdlc-radius);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--frankdlc-transition);
    color: var(--frankdlc-gray-600);
}

.frankdlc-action-btn:hover {
    background: var(--frankdlc-gray-200);
    color: var(--frankdlc-gray-800);
}

.frankdlc-action-btn.frankdlc-recheck:hover {
    background: #dbeafe;
    color: var(--frankdlc-primary);
}

.frankdlc-action-btn.frankdlc-edit:hover {
    background: #d1fae5;
    color: var(--frankdlc-success);
}

.frankdlc-action-btn.frankdlc-delete:hover {
    background: #fee2e2;
    color: var(--frankdlc-danger);
}

.frankdlc-action-btn .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

/* No Items */
.frankdlc-links-table tbody td.frankdlc-no-items {
    text-align: center;
    padding: 60px 20px;
    color: var(--frankdlc-gray-500);
}

.frankdlc-no-items .dashicons {
    font-size: 48px;
    width: 48px;
    height: 48px;
    color: var(--frankdlc-success);
    display: block;
    margin: 0 auto 16px;
}

/* ==================================================
   Pagination
   ================================================== */
.frankdlc-pagination {
    margin-top: 20px;
    text-align: center;
}

.frankdlc-pagination .page-numbers {
    display: inline-block;
    padding: 8px 14px;
    margin: 0 3px;
    background: #fff;
    border: 1px solid var(--frankdlc-gray-300);
    border-radius: var(--frankdlc-radius);
    text-decoration: none;
    color: var(--frankdlc-gray-700);
    transition: var(--frankdlc-transition);
}

.frankdlc-pagination .page-numbers:hover {
    background: var(--frankdlc-gray-100);
}

.frankdlc-pagination .page-numbers.current {
    background: var(--frankdlc-primary);
    border-color: var(--frankdlc-primary);
    color: #fff;
}

/* ==================================================
   Modal
   ================================================== */
.frankdlc-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(4px);
}

.frankdlc-modal-content {
    background: #fff;
    border-radius: var(--frankdlc-radius-lg);
    width: 100%;
    max-width: 500px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    animation: modalIn 0.2s ease;
}

@keyframes modalIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.frankdlc-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid var(--frankdlc-gray-200);
}

.frankdlc-modal-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
}

.frankdlc-modal-close {
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    color: var(--frankdlc-gray-400);
    transition: var(--frankdlc-transition);
}

.frankdlc-modal-close:hover {
    color: var(--frankdlc-gray-600);
}

.frankdlc-modal-body {
    padding: 24px;
}

.frankdlc-modal-body label {
    display: block;
    font-weight: 500;
    margin-bottom: 6px;
    color: var(--frankdlc-gray-700);
}

.frankdlc-modal-body input {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--frankdlc-gray-300);
    border-radius: var(--frankdlc-radius);
    font-size: 14px;
    margin-bottom: 16px;
}

.frankdlc-modal-body input:focus {
    border-color: var(--frankdlc-primary);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    outline: none;
}

.frankdlc-modal-body input[readonly] {
    background: var(--frankdlc-gray-100);
    color: var(--frankdlc-gray-600);
}

.frankdlc-modal-footer {
    padding: 16px 24px;
    border-top: 1px solid var(--frankdlc-gray-200);
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

/* ==================================================
   Settings Page
   ================================================== */
.frankdlc-settings-page .frankdlc-settings-tabs {
    background: #fff;
    border-radius: var(--frankdlc-radius-lg);
    box-shadow: var(--frankdlc-shadow);
    border: 1px solid var(--frankdlc-gray-200);
    margin-top: 20px;
}

.frankdlc-tabs-nav {
    display: flex;
    border-bottom: 1px solid var(--frankdlc-gray-200);
    padding: 0 20px;
}

.frankdlc-tabs-nav a {
    padding: 16px 20px;
    text-decoration: none;
    color: var(--frankdlc-gray-600);
    font-weight: 500;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: var(--frankdlc-transition);
}

.frankdlc-tabs-nav a:hover {
    color: var(--frankdlc-gray-800);
}

.frankdlc-tabs-nav a.active {
    color: var(--frankdlc-primary);
    border-bottom-color: var(--frankdlc-primary);
}

.frankdlc-tabs-content {
    padding: 30px;
}

.frankdlc-tab-panel {
    display: none;
}

.frankdlc-tab-panel.active {
    display: block;
}

.frankdlc-settings-page .form-table th {
    width: 220px;
    padding: 20px 10px 20px 0;
}

.frankdlc-settings-page .form-table td {
    padding: 15px 10px;
}

/* ==================================================
   Settings Page - Input & Button Consistency
   ================================================== */
/* ==================================================
   Input, Select & Button Consistency
   ================================================== */
.wp-core-ui .frankdlc-wrap input[type="text"],
.wp-core-ui .frankdlc-wrap input[type="search"],
.wp-core-ui .frankdlc-wrap input[type="number"],
.wp-core-ui .frankdlc-wrap input[type="email"],
.wp-core-ui .frankdlc-wrap input[type="url"],
.wp-core-ui .frankdlc-wrap input[type="date"],
.wp-core-ui .frankdlc-wrap select:not([multiple]) {
    height: 32px;
    box-sizing: border-box;
    font-size: 13px;
    border-radius: var(--frankdlc-radius);
    border: 1px solid var(--frankdlc-gray-300);
    background-color: #fff;
    color: var(--frankdlc-gray-800);
    padding: 0 10px;
    vertical-align: middle;
    transition: var(--frankdlc-transition);
}

.wp-core-ui .frankdlc-wrap select:not([multiple]) {
    padding: 0 24px 0 10px;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2212%22%20height%3D%2212%22%20viewBox%3D%220%200%2012%2012%22%3E%3Cpath%20fill%3D%22%234b5563%22%20d%3D%22M2.4%204.5L6%208.1l3.6-3.6z%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 10px;
    cursor: pointer;
}

.wp-core-ui .frankdlc-wrap textarea {
    box-sizing: border-box;
    font-size: 13px;
    border-radius: var(--frankdlc-radius);
    border: 1px solid var(--frankdlc-gray-300);
    background-color: #fff;
    color: var(--frankdlc-gray-800);
    padding: 10px;
    transition: var(--frankdlc-transition);
}

.wp-core-ui .frankdlc-wrap input[type="text"]:focus,
.wp-core-ui .frankdlc-wrap input[type="search"]:focus,
.wp-core-ui .frankdlc-wrap input[type="number"]:focus,
.wp-core-ui .frankdlc-wrap input[type="email"]:focus,
.wp-core-ui .frankdlc-wrap input[type="url"]:focus,
.wp-core-ui .frankdlc-wrap input[type="date"]:focus,
.wp-core-ui .frankdlc-wrap select:not([multiple]):focus,
.wp-core-ui .frankdlc-wrap textarea:focus {
    border-color: var(--frankdlc-primary);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    outline: none;
}

.wp-core-ui .frankdlc-wrap input[type="checkbox"],
.wp-core-ui .frankdlc-wrap input[type="radio"] {
    margin-top: -3px;
    margin-right: 6px;
    vertical-align: middle;
    border: 1px solid var(--frankdlc-gray-300);
}

.wp-core-ui .frankdlc-wrap label {
    font-size: 13px;
    color: var(--frankdlc-gray-700);
}

.wp-core-ui .frankdlc-wrap .button,
.wp-core-ui .frankdlc-wrap button.button {
    height: 32px;
    line-height: 30px;
    padding: 0 12px;
    box-sizing: border-box;
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--frankdlc-radius);
    border: 1px solid var(--frankdlc-gray-300);
    background: #fff;
    color: var(--frankdlc-gray-700);
    transition: var(--frankdlc-transition);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
}

.wp-core-ui .frankdlc-wrap .button:hover,
.wp-core-ui .frankdlc-wrap button.button:hover {
    background: var(--frankdlc-gray-50);
    border-color: var(--frankdlc-gray-400);
    color: var(--frankdlc-gray-900);
}

.wp-core-ui .frankdlc-wrap .button:focus,
.wp-core-ui .frankdlc-wrap button.button:focus {
    border-color: var(--frankdlc-primary);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    outline: none;
}

.wp-core-ui .frankdlc-wrap .button .dashicons,
.wp-core-ui .frankdlc-wrap .button-secondary .dashicons,
.wp-core-ui .frankdlc-wrap .button-primary .dashicons {
    line-height: 1;
    font-size: 16px;
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: middle;
    margin: 0;
}

.wp-core-ui .frankdlc-wrap .frankdlc-search-form .button {
    width: 32px;
    padding: 0;
    flex-shrink: 0;
}

.wp-core-ui .frankdlc-wrap .frankdlc-clear-filters {
    color: var(--frankdlc-danger);
    border-color: rgba(239, 68, 68, 0.2);
}

.wp-core-ui .frankdlc-wrap .frankdlc-clear-filters:hover {
    background: #fef2f2;
    border-color: var(--frankdlc-danger);
    color: var(--frankdlc-danger-dark);
}

.wp-core-ui .frankdlc-settings-page input[type="submit"]#submit {
    height: 36px;
    line-height: 34px;
    padding: 0 20px;
    font-size: 14px;
    font-weight: 500;
    border-radius: var(--frankdlc-radius);
    border: none;
    background: linear-gradient(135deg, var(--frankdlc-primary), var(--frankdlc-primary-dark));
    color: #fff;
    cursor: pointer;
    box-shadow: var(--frankdlc-shadow);
    transition: var(--frankdlc-transition);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}

.wp-core-ui .frankdlc-settings-page input[type="submit"]#submit:hover {
    background: linear-gradient(135deg, var(--frankdlc-primary-dark), #1d4ed8);
    color: #fff;
    box-shadow: var(--frankdlc-shadow-lg);
    transform: translateY(-1px);
}

/* Tools / Maintenance button sizing */
.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools h2 {
    margin-top: 0;
    border-bottom: 1px solid var(--frankdlc-gray-200);
    padding-bottom: 10px;
    font-size: 18px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools h2 .dashicons {
    color: #e91e63;
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools td:first-child {
    width: 180px;
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools td:last-child {
    width: 160px;
    text-align: right;
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools tr.frankdlc-danger-row {
    background: #fff5f5;
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools tr.frankdlc-danger-row td strong {
    color: #dc3545;
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools .button {
    height: 32px;
    width: 150px;
    padding: 0 14px;
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--frankdlc-radius);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    transition: var(--frankdlc-transition);
    cursor: pointer;
    border: 1px solid var(--frankdlc-gray-300);
    background: #fff;
    color: var(--frankdlc-gray-700);
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools .button:hover {
    background: var(--frankdlc-gray-50);
    border-color: var(--frankdlc-gray-400);
    color: var(--frankdlc-gray-900);
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools #frankdlc-force-stop-btn {
    color: var(--frankdlc-warning-dark);
    border-color: var(--frankdlc-warning);
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools #frankdlc-force-stop-btn:hover {
    background: rgba(245, 158, 11, 0.1);
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools #frankdlc-full-reset-btn {
    color: var(--frankdlc-danger);
    border-color: var(--frankdlc-danger);
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools #frankdlc-full-reset-btn:hover {
    background: rgba(239, 68, 68, 0.1);
}

.wp-core-ui .frankdlc-settings-page .frankdlc-tab-panel#tools .button .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
    line-height: 1;
    margin-right: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* ==================================================
   Toast Notifications
   ================================================== */
.frankdlc-toast {
    position: fixed;
    bottom: 30px;
    right: 30px;
    padding: 14px 24px;
    background: var(--frankdlc-gray-800);
    color: #fff;
    border-radius: var(--frankdlc-radius);
    box-shadow: var(--frankdlc-shadow-lg);
    z-index: 999999;
    animation: toastIn 0.3s ease;
}

.frankdlc-toast.success {
    background: var(--frankdlc-success);
}

.frankdlc-toast.error {
    background: var(--frankdlc-danger);
}

@keyframes toastIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ==================================================
   Scan Status Badges (Logs page)
   ================================================== */
.frankdlc-scan-completed {
    color: var(--frankdlc-success);
    font-weight: 500;
}

.frankdlc-scan-running {
    color: var(--frankdlc-primary);
    font-weight: 500;
}

.frankdlc-scan-pending {
    color: var(--frankdlc-warning-dark);
    font-weight: 500;
}

.frankdlc-scan-cancelled {
    color: var(--frankdlc-danger);
    font-weight: 500;
}

/* ==================================================
   Responsive
   ================================================== */
/* ==================================================
   Responsive - Tablet (max-width: 1024px)
   ================================================== */
@media (max-width: 1024px) {
    .frankdlc-wrap {
        margin: 10px 10px 10px 0;
    }

    /* Responsive table wrapper */
    .frankdlc-table-responsive {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .frankdlc-links-table {
        min-width: 800px;
    }

    .frankdlc-scan-history-table {
        min-width: 700px;
    }
}

/* ==================================================
   Responsive - Mobile (max-width: 782px)
   ================================================== */
@media (max-width: 782px) {
    .frankdlc-wrap {
        margin: 10px 5px 10px 0;
    }

    .frankdlc-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .frankdlc-filters {
        flex-direction: column;
        align-items: stretch;
    }

    .frankdlc-filter-tabs {
        flex-wrap: wrap;
    }

    .frankdlc-search-form {
        width: 100%;
    }

    .frankdlc-search-form input[type="search"] {
        flex: 1;
        min-width: 0;
    }

    .frankdlc-tabs-nav {
        overflow-x: auto;
    }

    /* Stats grid mobile */
    .frankdlc-stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }

    .frankdlc-stat-card {
        padding: 16px;
        gap: 10px;
    }

    .frankdlc-stat-icon {
        width: 40px;
        height: 40px;
    }

    .frankdlc-stat-icon .dashicons {
        font-size: 20px;
        width: 20px;
        height: 20px;
    }

    .frankdlc-stat-value {
        font-size: 24px;
    }

    .frankdlc-stat-label {
        font-size: 12px;
    }

    /* Bulk actions mobile */
    .frankdlc-bulk-actions {
        flex-wrap: wrap;
        gap: 8px;
    }

    .frankdlc-bulk-actions select {
        min-width: 120px;
    }

    /* Advanced filters mobile */
    .frankdlc-filter-form {
        flex-direction: column;
        align-items: stretch;
    }

    .frankdlc-filter-group {
        flex-wrap: wrap;
    }

    /* Settings page mobile */
    .frankdlc-tabs-content {
        padding: 15px;
    }

    .frankdlc-settings-page .form-table th {
        width: 100%;
        display: block;
        padding: 10px 0 5px 0;
    }

    .frankdlc-settings-page .form-table td {
        display: block;
        padding: 5px 0 15px 0;
    }
}

/* ==================================================
   Responsive - Small Mobile (max-width: 480px)
   ================================================== */
@media (max-width: 480px) {
    .frankdlc-wrap {
        margin: 5px 0 5px 0;
    }

    .frankdlc-wrap h1 {
        font-size: 22px;
    }

    /* Stats grid small mobile */
    .frankdlc-stats-grid {
        grid-template-columns: 1fr;
    }

    /* Header actions */
    .frankdlc-header-actions .button-hero {
        padding: 10px 16px;
        font-size: 13px;
    }

    /* Filter tabs small mobile */
    .frankdlc-filter-tabs {
        padding: 2px;
        gap: 2px;
    }

    .frankdlc-filter-tabs a {
        padding: 6px 10px;
        font-size: 12px;
    }

    /* Modal mobile */
    .frankdlc-modal-content {
        margin: 10px;
        max-width: calc(100% - 20px);
    }

    .frankdlc-modal-header,
    .frankdlc-modal-body,
    .frankdlc-modal-footer {
        padding: 15px;
    }

    /* Last scan text */
    .frankdlc-last-scan {
        font-size: 11px;
        padding: 4px 8px;
    }

    /* Help page mobile */
    .frankdlc-help-container {
        padding: 0 10px;
    }

    .frankdlc-card {
        padding: 15px !important;
    }
}

/* Help Tab Styles */
.frankdlc-help-section {
    padding: 20px 0;
}

.frankdlc-help-section h2 {
    margin: 0 0 10px 0;
    font-size: 24px;
    color: var(--frankdlc-gray-900);
}

.frankdlc-help-intro {
    font-size: 14px;
    color: var(--frankdlc-gray-600);
    margin-bottom: 24px;
    max-width: 700px;
}

.frankdlc-status-codes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 20px;
}

.frankdlc-status-category {
    background: #fff;
    border-radius: var(--frankdlc-radius-lg);
    padding: 20px;
    border: 1px solid var(--frankdlc-gray-200);
}

.frankdlc-status-category h3 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 16px 0;
    font-size: 15px;
    font-weight: 600;
    padding-bottom: 12px;
    border-bottom: 2px solid;
}

.frankdlc-status-category h3 .dashicons {
    font-size: 18px;
    width: 18px;
    height: 18px;
}

.frankdlc-status-category dl {
    margin: 0;
}

.frankdlc-status-category dt {
    font-weight: 600;
    font-size: 14px;
    margin-top: 12px;
    color: var(--frankdlc-gray-800);
}

.frankdlc-status-category dt:first-child {
    margin-top: 0;
}

.frankdlc-status-category dd {
    margin: 4px 0 0 0;
    font-size: 13px;
    color: var(--frankdlc-gray-600);
    line-height: 1.5;
}

/* Category Colors */
.frankdlc-status-category-success h3 {
    color: var(--frankdlc-success-dark);
    border-color: var(--frankdlc-success);
}

.frankdlc-status-category-redirect h3 {
    color: var(--frankdlc-warning-dark);
    border-color: var(--frankdlc-warning);
}

.frankdlc-status-category-client h3 {
    color: var(--frankdlc-error-dark);
    border-color: var(--frankdlc-error);
}

.frankdlc-status-category-server h3 {
    color: var(--frankdlc-error-dark);
    border-color: #ef4444;
}

.frankdlc-status-category-connection h3 {
    color: var(--frankdlc-gray-700);
    border-color: var(--frankdlc-gray-400);
}

/* Network Dashboard Styles */
.frankdlc-network-dashboard h1 {
    margin-bottom: 24px;
}

.frankdlc-network-summary {
    display: flex;
    gap: 20px;
    margin-bottom: 32px;
}

.frankdlc-network-stat {
    background: #fff;
    border-radius: var(--frankdlc-radius-lg);
    padding: 24px 32px;
    text-align: center;
    box-shadow: var(--frankdlc-shadow);
    flex: 1;
    max-width: 200px;
}

.frankdlc-network-stat .frankdlc-stat-number {
    display: block;
    font-size: 36px;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 8px;
}

.frankdlc-network-stat .frankdlc-stat-label {
    font-size: 14px;
    color: var(--frankdlc-gray-600);
}

.frankdlc-network-stat-total .frankdlc-stat-number {
    color: var(--frankdlc-primary);
}

.frankdlc-network-stat-broken .frankdlc-stat-number {
    color: var(--frankdlc-error);
}

.frankdlc-network-stat-sites .frankdlc-stat-number {
    color: var(--frankdlc-success);
}

.frankdlc-network-sites {
    background: #fff;
    border-radius: var(--frankdlc-radius-lg);
    padding: 24px;
    box-shadow: var(--frankdlc-shadow);
}

.frankdlc-network-sites h2 {
    margin: 0 0 20px 0;
    font-size: 18px;
}

.frankdlc-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 13px;
    font-weight: 600;
}

.frankdlc-badge-error {
    background: rgba(239, 68, 68, 0.15);
    color: var(--frankdlc-error-dark);
}

.frankdlc-badge-warning {
    background: rgba(234, 179, 8, 0.15);
    color: var(--frankdlc-warning-dark);
}

.frankdlc-badge-success {
    background: rgba(34, 197, 94, 0.15);
    color: var(--frankdlc-success-dark);
}

/* ==================================================
   UI Consistency Fixes
   ================================================== */

/* Actions column - center alignment */
.frankdlc-links-table th.frankdlc-col-actions {
    text-align: center;
}

.frankdlc-actions-wrap {
    justify-content: center;
}

/* Filter bar spacing improvements */
.frankdlc-filter-group:last-child {
    margin-left: auto;
}

.frankdlc-filter-form .button {
    margin-left: 8px;
}

/* Date range inputs spacing */
.frankdlc-filter-group input[type="date"]+span {
    margin: 0 8px;
}

/* Redirect info consistent styling */
.frankdlc-url-wrap .frankdlc-redirect-info {
    display: inline-flex;
    align-items: center;
    background: rgba(234, 179, 8, 0.1);
    padding: 4px 8px;
    border-radius: 4px;
    margin-top: 6px;
    color: var(--frankdlc-warning-dark);
}

/* Scan History table styling */
.frankdlc-scan-history-table {
    width: 100%;
    border-collapse: collapse;
}

.frankdlc-scan-history-table th,
.frankdlc-scan-history-table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--frankdlc-gray-200);
}

.frankdlc-scan-history-table th {
    background: var(--frankdlc-gray-50);
    font-weight: 600;
    color: var(--frankdlc-gray-700);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.frankdlc-scan-history-table tbody tr:hover {
    background: var(--frankdlc-gray-50);
}

.frankdlc-scan-history-table tbody tr:last-child td {
    border-bottom: none;
}

/* Scan status badges */
.frankdlc-scan-running {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    background: #dbeafe;
    color: var(--frankdlc-primary);
}

.frankdlc-scan-completed {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    background: #ecfdf5;
    color: var(--frankdlc-success);
}

.frankdlc-scan-cancelled {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    background: #fef2f2;
    color: var(--frankdlc-danger);
}

/* Type column center alignment */
.frankdlc-links-table th.frankdlc-col-type,
.frankdlc-links-table td.frankdlc-col-type {
    text-align: center;
}

/* Bulk actions alignment */
.frankdlc-bulk-actions {
    margin-top: 16px;
}

/* Page header consistency */
.frankdlc-settings-page>h1 {
    font-size: 28px;
    font-weight: 600;
    color: var(--frankdlc-gray-800);
    margin: 0 0 20px 0;
}

/* Final Responsive Fixes */
.frankdlc-wrap {
    overflow-x: auto !important;
}

.frankdlc-links-table {
    table-layout: auto !important;
    width: 100% !important;
    min-width: 800px !important;
}

.frankdlc-url-wrap a {
    word-break: break-word !important;
    min-width: 150px !important;
    display: inline-block !important;
}

@media (max-width: 782px) {
    .frankdlc-links-table {
        min-width: 600px !important;
    }
}

@media (max-width: 480px) {
    .frankdlc-links-table {
        min-width: 500px !important;
    }
}

/* ==================================================
   Tablet & Mobile Audit Fixes
   ================================================== */

/* Dashboard Hero Buttons - Stack on mobile */
@media (max-width: 480px) {
    .frankdlc-header-actions {
        display: flex;
        flex-direction: column;
        width: 100%;
        gap: 10px;
    }

    .frankdlc-header-actions .button-hero {
        width: 100%;
        justify-content: center;
    }

    .frankdlc-export-dropdown,
    #frankdlc-export-btn {
        width: 100%;
    }

    #frankdlc-export-btn {
        justify-content: center;
    }
}

/* Stats Grid - 1 col on small mobile */
@media (max-width: 480px) {
    .frankdlc-stats-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Dashboard Filters - Stack labels/inputs on mobile */
@media (max-width: 782px) {
    .frankdlc-filter-group {
        flex-direction: column;
        align-items: flex-start !important;
        width: 100%;
    }

    .frankdlc-filter-group label {
        margin-bottom: 4px;
    }

    .frankdlc-filter-group select,
    .frankdlc-filter-group input[type="date"] {
        width: 100% !important;
    }

    .frankdlc-filter-group:last-child {
        margin-left: 0;
    }
}

/* Help Page - Stack features on mobile */
@media (max-width: 768px) {
    .frankdlc-status-codes-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Fix for wrapping tabs in Dashboard */
@media (max-width: 600px) {
    .frankdlc-filter-tabs {
        overflow-x: auto;
        white-space: nowrap;
        justify-content: flex-start;
        -webkit-overflow-scrolling: touch;
        width: 100%;
    }

    .frankdlc-filter-tabs li {
        flex-shrink: 0;
    }
}

/* Table Responsive Improvement */
.frankdlc-wrap {
    overflow-x: hidden;
    /* Avoid double scrollbar on wrap */
}

.frankdlc-table-responsive {
    margin-top: 10px;
}

/* Header Mobile Stack */
@media (max-width: 600px) {
    .frankdlc-header {
        flex-direction: column !important;
        align-items: center !important;
        gap: 12px;
        text-align: center;
    }

    .frankdlc-header-left {
        flex-direction: column !important;
        align-items: center !important;
        gap: 8px !important;
        width: 100%;
        text-align: center;
    }

    .frankdlc-header-left h1 {
        font-size: 22px !important;
        text-align: center;
    }

    .frankdlc-header-actions {
        width: 100%;
        justify-content: center;
    }
}

/* Table Container Mobile Fix */
@media (max-width: 782px) {

    .frankdlc-settings-tabs,
    .frankdlc-tabs-content {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
    }

    .frankdlc-scan-history-table,
    .frankdlc-links-table {
        min-width: 600px;
    }

    /* Bulk actions stack on mobile */
    .frankdlc-bulk-actions {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 10px;
    }

    .frankdlc-bulk-actions select,
    .frankdlc-bulk-actions .button {
        width: 100% !important;
    }

    /* Pagination center on mobile */
    .frankdlc-pagination {
        justify-content: center !important;
        flex-wrap: wrap;
        gap: 5px;
    }
}

/* ==================================================
   Free vs Pro Table
   ================================================== */
.frankdlc-pricing-container {
    padding: 20px;
    background: #fff;
    border-radius: var(--frankdlc-radius);
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

.frankdlc-pricing-container h2 {
    font-size: 24px;
    margin-bottom: 10px;
    color: var(--frankdlc-gray-900);
}

.frankdlc-pricing-subtitle {
    font-size: 14px;
    color: var(--frankdlc-gray-600);
    margin-bottom: 30px;
}

.frankdlc-pricing-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border: 1px solid var(--frankdlc-gray-200);
    border-radius: var(--frankdlc-radius);
    overflow: hidden;
    box-shadow: var(--frankdlc-shadow);
}

.frankdlc-pricing-table thead th {
    background: #6d28d9; /* Deep Purple */
    color: #fff;
    padding: 15px;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 13px;
    letter-spacing: 0.5px;
    border-bottom: 1px solid #5b21b6;
}

.frankdlc-pricing-table thead th:first-child {
    text-align: left;
    width: 40%;
}

.frankdlc-pricing-table tbody td {
    padding: 12px 15px;
    border-bottom: 1px solid var(--frankdlc-gray-200);
    font-size: 14px;
    color: var(--frankdlc-gray-700);
}

.frankdlc-pricing-table tbody td:first-child {
    text-align: left;
    font-weight: 500;
}

.frankdlc-pricing-table tr:last-child td {
    border-bottom: none;
}

.frankdlc-pricing-table tr.frankdlc-section-header td {
    background: var(--frankdlc-gray-50);
    font-weight: 600;
    text-align: left;
    color: var(--frankdlc-gray-800);
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 0.5px;
    padding: 8px 15px;
    border-top: 1px solid var(--frankdlc-gray-200);
}

.frankdlc-yes {
    color: var(--frankdlc-success);
    font-weight: 900;
}

.frankdlc-no {
    color: var(--frankdlc-gray-400);
    opacity: 0.5;
}

.frankdlc-upgrade-btn {
    display: inline-block;
    padding: 14px 28px;
    background: linear-gradient(135deg, #6d28d9, #7c3aed);
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    font-size: 16px;
    border-radius: var(--frankdlc-radius);
    box-shadow: 0 4px 6px -1px rgba(109, 40, 217, 0.3);
    transition: transform 0.2s, box-shadow 0.2s;
}

.frankdlc-upgrade-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(109, 40, 217, 0.4);
    color: #fff;
}

/* Source Column Actions */
.frankdlc-source-cell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.frankdlc-source-title {
    color: var(--frankdlc-gray-800);
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-right: 8px;
    flex: 1;
}

.frankdlc-source-actions {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}

.frankdlc-source-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 4px;
    background: var(--frankdlc-gray-50);
    color: var(--frankdlc-gray-500);
    border: 1px solid var(--frankdlc-gray-200);
    transition: var(--frankdlc-transition);
}

.frankdlc-source-action-btn:hover {
    background: var(--frankdlc-gray-100);
    color: var(--frankdlc-gray-800);
    border-color: var(--frankdlc-gray-300);
}

.frankdlc-source-action-btn.frankdlc-source-edit:hover {
    background: #ecfdf5;
    color: var(--frankdlc-success);
    border-color: #a7f3d0;
}

.frankdlc-source-action-btn.frankdlc-source-view:hover {
    background: #eff6ff;
    color: var(--frankdlc-primary);
    border-color: #bfdbfe;
}

.frankdlc-source-action-btn .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
    line-height: 1;
}