@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
    --bg: #08080d;
    --bg-alt: #0c0c14;
    --card-bg: #111119;
    --card-bg-hover: #16161f;
    --surface: #1a1a25;
    --primary: #7c5cfc;
    --primary-hover: #6a4ae8;
    --primary-glow: rgba(124, 92, 252, 0.12);
    --accent: #00d4aa;
    --accent-glow: rgba(0, 212, 170, 0.12);
    --text: #e8e8f0;
    --text-muted: #8888a0;
    --text-dim: #555568;
    --border: #1c1c2a;
    --border-light: #282840;
    --success: #00d4aa;
    --error: #ff4757;
    --warning: #ffa502;
    --discord: #5865F2;
    --radius: 12px;
    --radius-lg: 16px;
    --radius-sm: 8px;
    --shadow-card: 0 2px 16px rgba(0,0,0,0.3);
    --shadow-glow: 0 0 40px var(--primary-glow);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: var(--bg);
    color: var(--text);
    line-height: 1.6;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
}

/* ══════════════════════════════════════════════════════
   LAYOUT
   ══════════════════════════════════════════════════════ */

.container { max-width: 1200px; margin: 0 auto; padding: 0 2rem; }
.container-narrow { max-width: 900px; margin: 0 auto; padding: 0 2rem; }

/* ══════════════════════════════════════════════════════
   NAVBAR
   ══════════════════════════════════════════════════════ */

.navbar {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(8, 8, 13, 0.85);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border);
    padding: 0 2rem;
}

.navbar-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 64px;
}

.logo {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
}

.logo-icon {
    width: 34px;
    height: 34px;
    background: linear-gradient(135deg, var(--primary), #9b7dff);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    font-size: 1rem;
    color: white;
}

.logo-text {
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--text);
    letter-spacing: -0.02em;
}

.nav-links {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.nav-user {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding-right: 0.5rem;
}

.nav-avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid var(--border-light);
}

.nav-username {
    color: var(--text-muted);
    font-size: 0.85rem;
    font-weight: 500;
}

/* ══════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════ */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.6rem 1.2rem;
    border-radius: var(--radius-sm);
    text-decoration: none;
    font-weight: 600;
    cursor: pointer;
    border: none;
    font-size: 0.85rem;
    transition: all 0.2s ease;
    line-height: 1;
    white-space: nowrap;
}

.btn-primary {
    background: var(--primary);
    color: white;
    box-shadow: 0 2px 12px rgba(124, 92, 252, 0.25);
}
.btn-primary:hover {
    background: var(--primary-hover);
    box-shadow: 0 4px 20px rgba(124, 92, 252, 0.35);
    transform: translateY(-1px);
}

.btn-accent {
    background: var(--accent);
    color: #0a0a0f;
    font-weight: 700;
}
.btn-accent:hover {
    box-shadow: 0 4px 20px rgba(0, 212, 170, 0.35);
    transform: translateY(-1px);
}

.btn-secondary {
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border-light);
}
.btn-secondary:hover {
    border-color: var(--primary);
    background: var(--card-bg-hover);
}

.btn-discord {
    background: var(--discord);
    color: white;
}
.btn-discord:hover {
    background: #4752c4;
    transform: translateY(-1px);
}

.btn-danger {
    background: rgba(255, 71, 87, 0.1);
    color: var(--error);
    border: 1px solid rgba(255, 71, 87, 0.2);
}
.btn-danger:hover { background: rgba(255, 71, 87, 0.2); }

.btn-ghost {
    background: transparent;
    color: var(--text-muted);
    border: 1px solid var(--border);
}
.btn-ghost:hover { color: var(--text); border-color: var(--border-light); }

.btn-lg { padding: 0.85rem 2rem; font-size: 0.95rem; border-radius: var(--radius); }
.btn-sm { padding: 0.35rem 0.7rem; font-size: 0.78rem; border-radius: 6px; }
.btn-xs { padding: 0.25rem 0.5rem; font-size: 0.72rem; border-radius: 5px; }
.btn-block { width: 100%; }
.btn-icon { padding: 0.5rem; width: 34px; height: 34px; }

.btn-download {
    background: linear-gradient(135deg, var(--primary), #9b7dff);
    color: white;
    padding: 0.9rem 2.2rem;
    font-size: 0.95rem;
    border-radius: var(--radius);
    box-shadow: 0 4px 24px rgba(124, 92, 252, 0.3);
}
.btn-download:hover {
    box-shadow: 0 6px 32px rgba(124, 92, 252, 0.45);
    transform: translateY(-2px);
}

/* ══════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════ */

.hero {
    text-align: center;
    padding: 6rem 0 4rem;
    position: relative;
}

.hero::before {
    content: '';
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
    width: 700px;
    height: 500px;
    background: radial-gradient(circle, var(--primary-glow) 0%, transparent 70%);
    pointer-events: none;
}

.hero > * { position: relative; z-index: 1; }

.hero-badge {
    display: inline-block;
    padding: 0.35rem 0.9rem;
    background: var(--card-bg);
    border: 1px solid var(--border-light);
    border-radius: 20px;
    font-size: 0.75rem;
    color: var(--accent);
    font-weight: 600;
    margin-bottom: 1.5rem;
    letter-spacing: 0.04em;
}

.hero h2 {
    font-size: 3.2rem;
    font-weight: 900;
    margin-bottom: 1rem;
    letter-spacing: -0.03em;
    line-height: 1.1;
}

.hero h2 .highlight {
    background: linear-gradient(135deg, var(--primary), #b39dff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hero p {
    color: var(--text-muted);
    font-size: 1.1rem;
    margin-bottom: 2.5rem;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

.cta-buttons {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

.hero-note {
    margin-top: 1.2rem;
    font-size: 0.78rem;
    color: var(--text-dim);
}

/* ══════════════════════════════════════════════════════
   PLUGIN STORE GRID
   ══════════════════════════════════════════════════════ */

.section-title {
    font-size: 1.6rem;
    font-weight: 800;
    margin-bottom: 0.4rem;
    letter-spacing: -0.02em;
}

.section-subtitle {
    color: var(--text-muted);
    font-size: 0.95rem;
    margin-bottom: 2rem;
}

.store-section {
    padding: 3rem 0;
}

.plugin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 300px));
    justify-content: center;
    gap: 1.5rem;
}

/* ── Plugin Card ────────────────────────── */

.plugin-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s;
    position: relative;
}

.plugin-card:hover {
    transform: translateY(-4px);
    border-color: var(--primary);
    box-shadow: var(--shadow-glow);
}

.plugin-card.featured {
    border-color: rgba(124, 92, 252, 0.4);
}

.plugin-card-featured-tag {
    position: absolute;
    top: 12px;
    right: 12px;
    background: var(--primary);
    color: white;
    font-size: 0.68rem;
    font-weight: 700;
    padding: 0.2rem 0.6rem;
    border-radius: 6px;
    letter-spacing: 0.04em;
    z-index: 2;
    text-transform: uppercase;
}

/* Showcase area — image/GIF with hover swap */
.plugin-showcase {
    position: relative;
    width: 100%;
    aspect-ratio: 509 / 754;
    background: var(--bg-alt);
    overflow: hidden;
}

.plugin-showcase img,
.plugin-showcase video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center center;
    transition: opacity 0.3s;
    background: #06060d;
}

.plugin-showcase .showcase-static {
    z-index: 1;
}

.plugin-showcase .showcase-gif {
    z-index: 2;
    opacity: 0;
}

.plugin-showcase .showcase-media-only {
    z-index: 1;
    opacity: 1;
}

.plugin-card:hover .showcase-gif:not(.showcase-media-only) {
    opacity: 1;
}

.plugin-card:hover .showcase-static:not(.showcase-media-only) {
    opacity: 0;
}

/* No media placeholder */
.plugin-showcase-empty {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-dim);
    font-size: 2.5rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    background: linear-gradient(135deg, var(--bg-alt), #12121c);
}

.plugin-card-body {
    padding: 1.4rem;
}

.plugin-card-name {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 0.3rem;
}

.plugin-card-desc {
    color: var(--text-muted);
    font-size: 0.85rem;
    margin-bottom: 1rem;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.plugin-card-features {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-bottom: 1rem;
}

.feature-tag {
    padding: 0.2rem 0.55rem;
    background: var(--primary-glow);
    border: 1px solid rgba(124, 92, 252, 0.18);
    border-radius: 6px;
    font-size: 0.72rem;
    color: #bbaeff;
    font-weight: 500;
}

.plugin-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 0.8rem;
    border-top: 1px solid var(--border);
}

.plugin-card-version {
    font-size: 0.75rem;
    color: var(--text-dim);
    font-weight: 500;
}

.plugin-card-plans {
    display: flex;
    gap: 0.35rem;
}

.plan-badge {
    padding: 0.18rem 0.5rem;
    background: var(--accent-glow);
    border: 1px solid rgba(0, 212, 170, 0.2);
    border-radius: 5px;
    font-size: 0.68rem;
    color: var(--accent);
    font-weight: 600;
}

/* ══════════════════════════════════════════════════════
   HOW IT WORKS / STEPS
   ══════════════════════════════════════════════════════ */

.steps-section { padding: 3rem 0; }

.steps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
}

.step {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.8rem;
    transition: border-color 0.2s;
}

.step:hover { border-color: var(--border-light); }

.step-number {
    width: 36px;
    height: 36px;
    background: var(--primary-glow);
    border: 1px solid rgba(124, 92, 252, 0.3);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.85rem;
    color: var(--primary);
    margin-bottom: 1rem;
}

.step h3 { font-size: 1rem; margin-bottom: 0.4rem; font-weight: 600; }
.step p { color: var(--text-muted); font-size: 0.85rem; }

/* ══════════════════════════════════════════════════════
   PLANS / PRICING
   ══════════════════════════════════════════════════════ */

.plans-section { padding: 3rem 0; }

.plans-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}

.plan-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 2.2rem;
    text-align: center;
    position: relative;
    transition: all 0.25s;
}

.plan-card:hover {
    border-color: var(--primary);
    transform: translateY(-2px);
}

.plan-card.featured {
    border-color: var(--primary);
    box-shadow: var(--shadow-glow);
}

.plan-card.featured::before {
    content: 'POPULAR';
    position: absolute;
    top: -1px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--primary);
    color: white;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.2rem 0.8rem;
    border-radius: 0 0 6px 6px;
    letter-spacing: 0.06em;
}

.plan-card h3 { font-size: 1.15rem; margin-bottom: 0.3rem; }

.plan-price {
    font-size: 2.4rem;
    font-weight: 800;
    margin: 0.8rem 0;
    letter-spacing: -0.02em;
}

.plan-price .currency { font-size: 1.1rem; color: var(--text-muted); }
.plan-price .period { font-size: 0.8rem; color: var(--text-dim); font-weight: 400; }

.plan-card ul {
    list-style: none;
    margin: 1.2rem 0;
    text-align: left;
}

.plan-card li {
    padding: 0.35rem 0;
    color: var(--text-muted);
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.plan-card li::before {
    content: '\2713';
    color: var(--accent);
    font-weight: 700;
    font-size: 0.8rem;
}

/* ══════════════════════════════════════════════════════
   DOWNLOAD SECTION
   ══════════════════════════════════════════════════════ */

.download-section { padding: 3rem 0; text-align: center; }

.download-card {
    background: var(--card-bg);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-lg);
    padding: 2.5rem;
    max-width: 600px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
}

.download-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--primary), var(--accent));
}

.download-card h3 { font-size: 1.4rem; margin-bottom: 0.4rem; }
.download-card p { color: var(--text-muted); margin-bottom: 1.5rem; }

.download-meta {
    display: flex;
    gap: 2rem;
    justify-content: center;
    margin-top: 1.5rem;
    flex-wrap: wrap;
}

.download-meta .meta-item { font-size: 0.78rem; color: var(--text-dim); }
.download-meta .meta-item strong { color: var(--text-muted); }

.platform-tags {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    margin-bottom: 1.5rem;
}

.platform-tag {
    padding: 0.25rem 0.65rem;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 6px;
    font-size: 0.72rem;
    color: var(--text-muted);
}

/* ══════════════════════════════════════════════════════
   DASHBOARD
   ══════════════════════════════════════════════════════ */

.page-section { padding: 2rem 0; }

.page-header {
    margin-bottom: 2rem;
}

.page-header h2 {
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.page-header p { color: var(--text-muted); font-size: 0.9rem; }

.dashboard-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.dashboard-grid-full {
    grid-column: 1 / -1;
}

/* ── Cards ────────────────────────────────── */

.card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.8rem;
}

.card-title {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-dim);
    font-weight: 600;
    margin-bottom: 1rem;
}

.card-highlight {
    border-color: var(--primary);
    box-shadow: var(--shadow-glow);
    background: linear-gradient(135deg, var(--card-bg), #151528);
}

/* ── Loader download card ─────────────────── */

.loader-card {
    text-align: center;
    padding: 2.5rem;
}

.loader-card h3 { font-size: 1.3rem; margin-bottom: 0.4rem; }
.loader-card p { color: var(--text-muted); margin-bottom: 1.2rem; font-size: 0.9rem; }
.loader-card .version-label { font-size: 0.78rem; color: var(--text-dim); margin-top: 0.8rem; }

/* ── Subscription info ────────────────────── */

.status-badge {
    display: inline-block;
    padding: 0.25rem 0.7rem;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
}

.status-badge.active {
    background: rgba(0, 212, 170, 0.1);
    color: var(--accent);
    border: 1px solid rgba(0, 212, 170, 0.2);
}

.status-badge.inactive {
    background: rgba(255, 71, 87, 0.1);
    color: var(--error);
    border: 1px solid rgba(255, 71, 87, 0.2);
}

.sub-info { margin-top: 1rem; }

.sub-row {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
    font-size: 0.88rem;
}

.sub-row label { color: var(--text-muted); }
.sub-row span { font-weight: 500; }

/* ── Plugin list ──────────────────────────── */

.plugin-list-item {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--border);
}

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

.plugin-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent);
    flex-shrink: 0;
}

.plugin-list-name { font-size: 0.88rem; }

/* ── Plan card (subscribe) ────────────────── */

.plan-card-sm {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 1rem 1.2rem;
    margin-bottom: 0.6rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    transition: border-color 0.2s;
}

.plan-card-sm:hover { border-color: var(--border-light); }
.plan-card-sm h4 { font-size: 0.92rem; font-weight: 600; }
.plan-card-sm .plan-meta { color: var(--text-dim); font-size: 0.8rem; }

.plan-actions { display: flex; gap: 0.4rem; }

/* ══════════════════════════════════════════════════════
   ADMIN PANEL
   ══════════════════════════════════════════════════════ */

.admin-layout { display: grid; gap: 1.5rem; }

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    text-align: center;
}

.stat {
    background: var(--surface);
    border-radius: var(--radius-sm);
    padding: 1.2rem;
}

.stat span {
    display: block;
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--primary);
    letter-spacing: -0.02em;
}

.stat label {
    color: var(--text-dim);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ── Forms ─────────────────────────────────── */

.form-group { margin-bottom: 1rem; }

.form-group label {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--text-muted);
    font-size: 0.82rem;
    font-weight: 500;
}

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 0.6rem 0.85rem;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
    font-size: 0.88rem;
    font-family: inherit;
    transition: border-color 0.2s;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-glow);
}

.form-group textarea { resize: vertical; min-height: 60px; }
.form-group input[type="file"] { padding: 0.45rem; }

.form-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.form-row-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.helper-text {
    color: var(--text-dim);
    font-size: 0.75rem;
    margin-top: 0.25rem;
}

.plugin-edit-hint {
    margin-bottom: 1rem;
    padding: 0.85rem 1rem;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(0, 212, 170, 0.25);
    background: rgba(0, 212, 170, 0.07);
    color: var(--text-muted);
    font-size: 0.84rem;
}

.form-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
}

.form-check input { width: auto; accent-color: var(--primary); }
.form-check span { font-size: 0.85rem; color: var(--text-muted); }

/* ── Choice grid (plan checkboxes) ────────── */

.choice-grid { display: grid; gap: 0.6rem; }

.choice-item {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.75rem;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
}

.choice-item:hover { border-color: var(--border-light); background: var(--card-bg-hover); }
.choice-item input { width: auto; margin-top: 0.15rem; accent-color: var(--primary); }
.choice-item strong { font-size: 0.88rem; color: var(--text); }
.choice-item small { display: block; color: var(--text-dim); font-size: 0.75rem; }

.file-update {
    border: 1px dashed var(--border-light);
    border-radius: var(--radius-sm);
    padding: 0.85rem;
    background: rgba(255, 255, 255, 0.02);
}

.media-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

/* ── Catalog (plugin list in admin) ───────── */

.catalog-list { display: grid; gap: 0.8rem; }

.catalog-item {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem;
}

.catalog-item-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 0.6rem;
}

.catalog-item h3 { font-size: 0.95rem; margin-bottom: 0.15rem; }

.catalog-meta {
    color: var(--text-muted);
    font-size: 0.82rem;
    margin-bottom: 0.6rem;
}

.inline-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }

/* ── Pills ────────────────────────────────── */

.pill-row { display: flex; flex-wrap: wrap; gap: 0.4rem; }

.pill {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 600;
    border: 1px solid transparent;
}

.pill-muted { background: rgba(124, 92, 252, 0.1); color: #bbaeff; border-color: rgba(124, 92, 252, 0.2); }
.pill-accent { background: rgba(0, 212, 170, 0.1); color: var(--accent); border-color: rgba(0, 212, 170, 0.2); }
.pill-error { background: rgba(255, 71, 87, 0.1); color: var(--error); border-color: rgba(255, 71, 87, 0.2); }
.pill-warning { background: rgba(255, 165, 2, 0.1); color: var(--warning); border-color: rgba(255, 165, 2, 0.2); }

/* ── Tables ───────────────────────────────── */

table { width: 100%; border-collapse: collapse; }
th, td { padding: 0.65rem 0.8rem; text-align: left; border-bottom: 1px solid var(--border); }
th { color: var(--text-dim); font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
td { font-size: 0.88rem; }

/* ── Media preview ────────────────────────── */

.media-preview {
    display: flex;
    gap: 1rem;
    margin-top: 0.5rem;
}

.media-preview img {
    max-height: 80px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
}

/* ══════════════════════════════════════════════════════
   MISC
   ══════════════════════════════════════════════════════ */

.success { color: var(--success); margin-top: 0.5rem; font-size: 0.88rem; }
.error { color: var(--error); margin-top: 0.5rem; font-size: 0.88rem; }
.loading { color: var(--text-muted); }
.empty-state { color: var(--text-muted); font-size: 0.88rem; padding: 0.8rem 0; }
.text-muted { color: var(--text-muted); }
.text-dim { color: var(--text-dim); }
.mt-1 { margin-top: 0.5rem; }
.mt-2 { margin-top: 1rem; }
.mb-1 { margin-bottom: 0.5rem; }
.mb-2 { margin-bottom: 1rem; }
.hidden { display: none !important; }

/* ══════════════════════════════════════════════════════
   STORE + DETAIL UPGRADES
   ══════════════════════════════════════════════════════ */

.hero-store {
    padding-bottom: 2.5rem;
}

.hero-metrics,
.dashboard-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 2rem;
}

.dashboard-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 1.5rem;
}

.metric-card,
.summary-card {
    background: rgba(17, 17, 25, 0.8);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem 1.1rem;
    text-align: left;
}

.metric-card strong,
.summary-card strong {
    display: block;
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.metric-card span,
.summary-card label {
    color: var(--text-dim);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.section-heading-row {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 1rem;
    margin-bottom: 1rem;
}

.results-note {
    color: var(--text-dim);
    font-size: 0.82rem;
}

.catalog-toolbar {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr auto;
    gap: 1rem;
    margin-bottom: 1.5rem;
    align-items: end;
}

.toolbar-field label {
    display: block;
    color: var(--text-muted);
    font-size: 0.8rem;
    margin-bottom: 0.35rem;
}

.toolbar-field input,
.toolbar-field select {
    width: 100%;
    padding: 0.7rem 0.85rem;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text);
}

.catalog-toggle.is-active {
    border-color: var(--primary);
    background: var(--primary-glow);
}

.plugin-grid-wide {
    grid-template-columns: repeat(auto-fit, minmax(260px, 300px));
}

.plugin-card-topline {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.category-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.22rem 0.6rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    color: var(--text-muted);
    border: 1px solid var(--border);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.mini-badge-row {
    display: flex;
    gap: 0.35rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.mini-badge {
    padding: 0.18rem 0.45rem;
    border-radius: 999px;
    background: rgba(124, 92, 252, 0.12);
    border: 1px solid rgba(124, 92, 252, 0.18);
    color: #c8bcff;
    font-size: 0.66rem;
    font-weight: 700;
    text-transform: uppercase;
}

.plugin-card-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 1rem;
}

.updates-section {
    padding: 2rem 0 3rem;
}

.updates-list,
.feature-stack,
.version-timeline,
.checklist,
.action-stack {
    display: grid;
    gap: 0.8rem;
}

.update-item,
.dashboard-plugin-card {
    display: block;
    text-decoration: none;
    color: var(--text);
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem 1.1rem;
    transition: border-color 0.2s, transform 0.2s;
}

.update-item:hover,
.dashboard-plugin-card:hover {
    border-color: var(--primary);
    transform: translateY(-2px);
}

.update-item strong,
.dashboard-plugin-card strong {
    font-size: 0.95rem;
}

.update-item p,
.dashboard-plugin-card span {
    color: var(--text-muted);
    font-size: 0.82rem;
    margin-top: 0.3rem;
}

.update-version,
.update-date {
    display: inline-block;
    color: var(--text-dim);
    font-size: 0.75rem;
    margin-top: 0.35rem;
}

.update-item.compact {
    padding: 0.85rem 1rem;
}

.why-grid,
.faq-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.value-card,
.faq-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.4rem;
}

.value-card h3,
.faq-card h3 {
    font-size: 1rem;
    margin-bottom: 0.45rem;
}

.value-card p,
.faq-card p {
    color: var(--text-muted);
    font-size: 0.85rem;
}

.support-section {
    padding: 1rem 0 3rem;
}

.support-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1.5rem;
    background: linear-gradient(135deg, rgba(124, 92, 252, 0.12), rgba(0, 212, 170, 0.08));
    border: 1px solid var(--border-light);
    border-radius: var(--radius-lg);
    padding: 1.6rem 1.8rem;
    margin-bottom: 1rem;
}

.support-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.plan-description {
    color: var(--text-muted);
    font-size: 0.84rem;
    min-height: 3em;
}

.dashboard-plugin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.9rem;
}

.check-item {
    display: flex;
    gap: 0.8rem;
    align-items: flex-start;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.9rem 1rem;
}

.check-item.done {
    border-color: rgba(0, 212, 170, 0.25);
}

.check-mark {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: var(--bg);
    border: 1px solid var(--border-light);
    color: var(--accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    flex-shrink: 0;
}

.check-item p {
    color: var(--text-muted);
    font-size: 0.8rem;
    margin-top: 0.2rem;
}

.action-stack {
    gap: 0.55rem;
}

.plugin-hero {
    display: grid;
    grid-template-columns: minmax(280px, 380px) 1fr;
    gap: 2rem;
    padding: 3rem 0 2rem;
    align-items: start;
}

.plugin-hero-media {
    position: sticky;
    top: 88px;
}

.plugin-showcase-hero {
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-light);
    overflow: hidden;
}

.plugin-hero-content h1 {
    font-size: 2.6rem;
    line-height: 1.05;
    margin: 0.75rem 0;
    letter-spacing: -0.03em;
}

.plugin-hero-content p {
    color: var(--text-muted);
    font-size: 1rem;
    max-width: 58ch;
}

.plugin-meta-row,
.plugin-plan-row,
.plugin-cta-row {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.feature-line {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 0.8rem 1rem;
    font-size: 0.86rem;
}

.version-item {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem 1.1rem;
}

.version-item.latest {
    border-color: var(--primary);
    background: rgba(124, 92, 252, 0.06);
}

.version-item-head,
.version-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.version-item p {
    color: var(--text-muted);
    font-size: 0.84rem;
    margin: 0.35rem 0;
}

.admin-workbench {
    align-items: start;
}

.release-note-snippet {
    margin-top: 0.7rem;
    padding: 0.8rem 0.9rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    font-size: 0.82rem;
}

.version-panel {
    margin-top: 0.9rem;
    display: grid;
    gap: 0.65rem;
}

.showcase-preview img,
.showcase-preview video {
    max-height: 80px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    background: var(--bg-alt);
}

/* ── Footer ───────────────────────────────── */

.footer {
    text-align: center;
    padding: 3rem 0 2rem;
    color: var(--text-dim);
    font-size: 0.78rem;
    border-top: 1px solid var(--border);
    margin-top: 4rem;
}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════ */

@media (max-width: 768px) {
    .container { padding: 0 1rem; }
    .hero h2 { font-size: 2rem; }
    .hero { padding: 3rem 0 2rem; }
    .plugin-grid { grid-template-columns: 1fr; }
    .steps-grid { grid-template-columns: 1fr; }
    .plans-grid { grid-template-columns: 1fr; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
    .dashboard-grid { grid-template-columns: 1fr; }
    .form-row, .form-row-3, .media-row { grid-template-columns: 1fr; }
    .plan-card-sm { flex-direction: column; text-align: center; }
    .catalog-item-header { flex-direction: column; }
    .inline-actions { flex-direction: column; }
    .navbar-inner { padding: 0; }
    .download-meta { flex-direction: column; gap: 0.5rem; }
    .catalog-toolbar { grid-template-columns: 1fr; }
    .hero-metrics,
    .dashboard-summary-grid,
    .why-grid,
    .faq-grid { grid-template-columns: 1fr; }
    .plugin-card-actions,
    .support-actions,
    .plugin-cta-row,
    .plugin-meta-row { flex-direction: column; align-items: stretch; }
    .support-card,
    .plugin-hero { grid-template-columns: 1fr; display: grid; }
    .plugin-hero-media { position: static; }
}
