/* Admin Panel Styles */

.admin-body { background: linear-gradient(135deg, var(--dark) 0%, #0f172a 100%); min-height: 100vh; color: white; }
.admin-header { background: rgba(0,0,0,0.4); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(255,255,255,0.1); padding: var(--space-md) var(--space-lg); }
.admin-icon { color: var(--accent-color); margin-right: var(--space-xs); }

.admin-badge {
    font-size: 0.75rem;
    background: var(--accent-gradient);
    color: var(--white);
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius-sm);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.admin-status { color: var(--white); font-weight: 500; opacity: 0.9; }
.admin-main { flex: 1; display: flex; flex-direction: column; padding: var(--space-xl); }

/* ===== LOGIN ===== */
.admin-login-section {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-xl);
    background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
}

.admin-login-card {
    background: var(--white);
    border-radius: var(--radius-2xl);
    padding: 0;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
    width: 100%;
    max-width: 440px;
    overflow: hidden;
}

.admin-login-header {
    text-align: center;
    padding: var(--space-xl) var(--space-xl) var(--space-lg);
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
}

.admin-login-icon {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-md);
    font-size: 2rem;
    color: white;
    border: 3px solid rgba(255, 255, 255, 0.3);
}

.admin-login-header h2 {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
}

.admin-login-header p {
    margin: 8px 0 0;
    opacity: 0.9;
    font-size: 0.95rem;
}

.admin-login-form {
    padding: var(--space-xl);
}

.admin-login-form .form-group {
    margin-bottom: var(--space-md);
}

.admin-login-form .form-group label {
    display: block;
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--dark);
    margin-bottom: 8px;
}

.admin-login-form .form-group input {
    width: 100%;
    padding: 14px 16px;
    border: 2px solid var(--gray-light);
    border-radius: var(--radius-lg);
    font-size: 1rem;
    transition: all var(--transition-fast);
}

.admin-login-form .form-group input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 4px rgba(102, 126, 234, 0.15);
}

.admin-login-form .btn {
    width: 100%;
    padding: 14px 24px;
    font-size: 1rem;
    font-weight: 600;
    margin-top: var(--space-sm);
}

.admin-login-message {
    margin-top: var(--space-md);
    padding: 12px 16px;
    border-radius: var(--radius-md);
    font-size: 0.9rem;
    text-align: center;
}
.admin-login-message.error {
    background: rgba(239, 68, 68, 0.1);
    color: var(--error-color);
    border: 1px solid rgba(239, 68, 68, 0.2);
}
.admin-login-message.success {
    background: rgba(16, 185, 129, 0.1);
    color: var(--success-color);
    border: 1px solid rgba(16, 185, 129, 0.2);
}

.admin-login-footer {
    padding: var(--space-lg) var(--space-xl);
    background: var(--gray-lighter);
    border-top: 1px solid var(--gray-light);
    text-align: center;
}

.admin-login-footer a {
    color: var(--primary-color);
    text-decoration: none;
    font-size: 0.9rem;
}

.admin-login-footer a:hover {
    text-decoration: underline;
}

/* ===== PANEL ===== */
.admin-panel { flex: 1; padding: var(--space-xl) 0; }
.admin-container { max-width: 1200px; margin: 0 auto; padding: 0 var(--space-lg); }

.admin-dashboard-header { text-align: center; margin-bottom: var(--space-2xl); color: var(--white); }
.admin-dashboard-header h2 { font-size: 2.5rem; font-weight: 700; background: var(--accent-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

/* ===== STATS GRID ===== */
.admin-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-lg); margin-bottom: var(--space-2xl); }

.admin-stat-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    display: flex;
    align-items: center;
    gap: var(--space-md);
    box-shadow: var(--shadow-lg);
    transition: transform var(--transition-normal);
}
.admin-stat-card:hover { transform: translateY(-2px); }

.admin-stat-card .stat-icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--primary-gradient);
    color: var(--white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    font-weight: 600;
    transition: all var(--transition-normal);
    border: 3px solid var(--gray-light);
}
.admin-stat-card .stat-icon.pending { background: var(--warning-color); }
.admin-stat-card .stat-icon.approved { background: var(--success-color); }
.admin-stat-card .stat-icon.total { background: var(--primary-color); }

.admin-stat-card .stat-content h3 { font-size: 2rem; font-weight: 700; margin: 0; color: var(--dark); }
.admin-stat-card .stat-content p { margin: 0; color: var(--gray); font-size: 0.875rem; }

/* ===== SECTIONS ===== */
.admin-section { background: var(--white); border-radius: var(--radius-lg); margin-bottom: var(--space-xl); box-shadow: var(--shadow-lg); overflow: hidden; }

.admin-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-lg);
    border-bottom: 1px solid var(--gray-light);
    background: linear-gradient(135deg, #eef2ff 0%, #fff 100%);
}
.admin-section-header h3 { margin: 0; font-size: 1.25rem; font-weight: 600; color: var(--dark); }

/* Plans Editor */
.plans-grid { padding: var(--space-lg); display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
.plan-card { border: 1px solid var(--gray-light); border-radius: var(--radius-md); overflow: hidden; background: var(--white); box-shadow: var(--shadow-sm); }
.plan-card-header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-md) var(--space-lg); background: linear-gradient(135deg, #eef2ff 0%, #fff 100%); border-bottom: 1px solid var(--gray-light); }
.plan-card-header h4 { margin: 0; font-weight: 600; }
.plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--space-md); padding: var(--space-lg); }

/* Admin Table */
.admin-table { padding: var(--space-lg); }
.table { width: 100%; border-collapse: collapse; background: var(--white); border: 1px solid var(--gray-light); border-radius: var(--radius-md); overflow: hidden; }
.table thead th { text-align: left; background: #f8fafc; color: var(--dark); font-weight: 600; padding: 10px 12px; border-bottom: 1px solid var(--gray-light); }
.table tbody td { padding: 10px 12px; border-bottom: 1px solid #eef2f7; font-size: 0.95rem; }
.table.compact thead th, .table.compact tbody td { padding: 8px 10px; }

/* Filters */
.admin-filters { padding: var(--space-lg); border-bottom: 1px solid var(--gray-light); }
.filter-group { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.filter-btn { padding: var(--space-xs) var(--space-md); border: 1px solid var(--gray-light); border-radius: var(--radius-md); background: var(--white); color: var(--gray); font-size: 0.875rem; cursor: pointer; transition: all var(--transition-normal); display: flex; align-items: center; gap: var(--space-xs); }
.filter-btn:hover, .filter-btn.active { background: var(--primary-color); color: var(--white); border-color: var(--primary-color); }

/* Users Grid */
.users-grid { padding: var(--space-lg); }
.user-card { display: flex; align-items: center; justify-content: space-between; padding: var(--space-md); border: 1px solid var(--gray-light); border-radius: var(--radius-md); margin-bottom: var(--space-md); transition: all var(--transition-normal); }
.user-card:hover { border-color: var(--primary-color); box-shadow: var(--shadow-sm); }
.user-info { display: flex; align-items: center; gap: var(--space-md); flex: 1; }
.user-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--primary-gradient); color: var(--white); display: flex; align-items: center; justify-content: center; font-size: 0.85rem; font-weight: 700; }
.user-details h4 { margin: 0 0 var(--space-xs); font-size: 1rem; font-weight: 500; color: var(--dark); }
.user-details p { margin: 0; font-size: 0.875rem; color: var(--gray); }
.user-status { padding: 0.25rem 0.5rem; border-radius: var(--radius-sm); font-size: 0.75rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.5px; }
.user-status.pending { background: #fef3c7; color: #92400e; }
.user-status.approved { background: #d1fae5; color: #065f46; }
.user-status.rejected { background: #fee2e2; color: #991b1b; }
.user-actions { display: flex; gap: var(--space-xs); }

/* Search */
.admin-search { padding: var(--space-lg); border-bottom: 1px solid var(--gray-light); }
.search-group { display: flex; gap: var(--space-md); max-width: 400px; }
.search-group input { flex: 1; padding: 0.75rem; border: 1px solid var(--gray-light); border-radius: var(--radius-md); font-size: 0.875rem; }
.search-group input:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1); }

/* Log Viewer */
.admin-results { padding: var(--space-lg); }
.log-viewer { max-height: 400px; overflow: auto; background: var(--dark); color: #00ff00; padding: var(--space-md); border-radius: var(--radius-md); font-family: var(--font-mono); font-size: 0.875rem; line-height: 1.4; border: none; margin: 0; }
.log-viewer:empty::before { content: "No logs found. Try searching for something..."; color: var(--gray); font-style: italic; }

/* Pricing Grid */
.pricing-grid { padding: var(--space-lg); display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-lg); }

/* App Edit Cards */
.app-edit-card { display: flex; flex-direction: column; gap: var(--space-sm); background: var(--white); padding: var(--space-md); border-radius: var(--radius-md); border: 1px solid var(--gray-light); box-shadow: var(--shadow-sm); margin-bottom: var(--space-md); }
.app-edit-row { display: flex; justify-content: space-between; align-items: center; gap: var(--space-md); }
.app-edit-left { display: flex; flex-direction: column; gap: 4px; }
.app-edit-right { display: flex; gap: var(--space-sm); align-items: center; }
.app-edit-card .app-name { font-weight: 600; font-size: 1rem; color: var(--dark); }
.app-edit-card .app-id, .app-edit-card .muted { font-size: 0.85rem; color: var(--gray); }
.app-edit-card input[type="number"], .app-edit-card input[type="text"], .app-edit-card select { padding: var(--space-sm) var(--space-md); border: 2px solid var(--gray-light); border-radius: var(--radius-md); font-size: 0.9rem; transition: var(--transition-normal); }
.app-edit-card input:focus, .app-edit-card select:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1); }
.input-rfactor, .input-complexity { width: 80px; }
.input-owner { width: 150px; }
.select-move-wave { min-width: 120px; }
.app-edit-card label { display: block; font-size: 0.75rem; font-weight: 600; color: var(--gray); text-transform: uppercase; margin-bottom: 4px; }
.save-app-btn { white-space: nowrap; }
