/* ============================================================
   SRG Software Single Hero block CSS v2026
   - Edge-to-Edge layout with Container content-alignment.
   - Refactored dynamic elements for stacked ratings & category.
   ============================================================ */

.srg-single-hero-block {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    padding: var(--srg-space-10, 48px) 0;
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.02) 0%, rgba(37, 99, 235, 0.07) 100%);
    border-bottom: 1px solid rgba(37, 99, 235, 0.1);
    transition: background 200ms, border-color 200ms;
}

.srg-single-hero-inner {
    display: flex;
    flex-direction: column;
    gap: var(--srg-space-8, 32px);
}

.srg-hero-with-media .srg-single-hero-inner {
    display: grid;
    grid-template-columns: 42% 1fr;
    gap: var(--srg-space-8, 32px);
    align-items: start;
}

.srg-hero-media-col {
    position: relative;
    border-radius: var(--srg-radius-xl, 14px);
    overflow: hidden;
    background: rgba(37, 99, 235, 0.04);
}

/* ── Video Player ── */
.srg-media-video { aspect-ratio: 16 / 10; overflow: hidden; }
.srg-video-wrapper { position: relative; width: 100%; height: 100%; }
.srg-video-wrapper iframe { width: 100%; height: 100%; border: none; display: block; }
.srg-video-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(9, 14, 26, 0.2);
    cursor: pointer;
    transition: opacity 150ms, visibility 150ms;
    z-index: 10;
}
.srg-video-overlay.hidden { opacity: 0; visibility: hidden; pointer-events: none; }
.srg-video-play-btn { background: none; border: none; padding: 0; cursor: pointer; transition: transform 150ms; }
.srg-video-play-btn:hover { transform: scale(1.08); }
.srg-video-play-btn circle { transition: fill 150ms; }
.srg-video-play-btn:hover circle { fill: rgba(9, 14, 26, 0.85); }

/* ── Image Gallery Slideshow ── */
.srg-media-gallery { position: relative; aspect-ratio: 16 / 10; overflow: hidden; }
.srg-gallery-slides { position: relative; width: 100%; height: 100%; }
.srg-gallery-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1); z-index: 1; }
.srg-gallery-slide.active { opacity: 1; z-index: 2; }
.srg-gallery-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.srg-gallery-nav {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--srg-space-3, 12px) var(--srg-space-4, 16px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(to top, rgba(9, 14, 26, 0.6), transparent);
    z-index: 10;
}
.srg-gallery-prev, .srg-gallery-next { background: transparent; border: none; color: rgba(255, 255, 255, 0.7); cursor: pointer; transition: all 150ms; padding: 0; display: inline-flex; align-items: center; justify-content: center; }
.srg-gallery-prev:hover, .srg-gallery-next:hover { color: #ffffff; transform: scale(1.15); }
.srg-gallery-dots { display: flex; gap: var(--srg-space-1-5, 6px); align-items: center; }
.srg-gallery-dot { width: 8px; height: 8px; border-radius: var(--srg-radius-full, 9999px); border: none; background: rgba(255, 255, 255, 0.4); cursor: pointer; transition: all 150ms; padding: 0; }
.srg-gallery-dot.active { background: #ffffff; width: 20px; border-radius: 4px; }

/* ── Content Header Details ── */
.srg-hero-content-col {
    display: flex;
    flex-direction: column;
    gap: var(--srg-space-5, 20px);
}

.srg-hero-head {
    display: flex;
    align-items: normal;
    gap: var(--srg-space-4, 16px);
}

.srg-hero-logo-wrap {
    flex: 0 0 72px;
    width: 72px;
    height: 72px;
    background: transparent !important;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.srg-hero-logo-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: var(--srg-radius-md, 8px);
}

.srg-hero-title-wrap {
    flex: 1;
    min-width: 0;
}

.srg-hero-title {
    font-size: var(--srg-text-xl, 1.25rem) !important;
    font-weight: var(--srg-weight-bold, 800) !important;
    color: var(--srg-text-primary, #0F172A);
    /* Proportional rhythm: title sits closest to logo, needs tightest gap */
    margin-top: 0 !important;
    margin-bottom: 8px !important;
    line-height: var(--srg-leading-tight, 1.25);
    letter-spacing: -0.5px;
}

/* Align metadata vertically to place categories below stars */
.srg-hero-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--srg-space-2, 8px);
}

.srg-hero-rating {
    display: flex;
    align-items: center;
    gap: var(--srg-space-1-5, 6px);
    line-height: 1;
    /* Proportional rhythm: rating flows directly below title */
    margin-top: 0 !important;
    margin-bottom: 12px !important;
}

.srg-hero-stars-empty {
    color: rgba(37, 99, 235, 0.2);
    letter-spacing: 1px;
}

.srg-hero-rev {
    font-size: var(--srg-text-sm, 14px);
    font-weight: var(--srg-weight-semibold, 700);
    color: var(--srg-text-secondary, #475569);
}

.srg-hero-cat-row {
    display: flex;
    width: 100%;
    /* Proportional rhythm: category badges bridge rating and description */
    margin-top: 0 !important;
    margin-bottom: 16px !important;
}

.srg-hero-cat {
    display: inline-flex;
    align-items: center;
    gap: var(--srg-space-1, 4px);
    font-size: var(--srg-text-xs, 12.5px);
    font-weight: var(--srg-weight-bold, 700);
    color: var(--srg-context-accent, #2563EB);
    text-decoration: none;
    background: rgba(37, 99, 235, 0.06);
    padding: var(--srg-space-1, 4px) var(--srg-space-3, 12px);
    border-radius: var(--srg-radius-md, 8px);
    transition: all 150ms;
}

.srg-hero-cat:hover {
    background: var(--srg-context-accent, #2563EB);
    color: #ffffff !important;
    transform: translateY(-1px);
}

.srg-hero-desc {
    /* Comfortable reading: slightly larger size with generous line-height */
    font-size: 1.05rem !important;
    line-height: 1.65 !important;
    color: var(--srg-text-secondary, #475569);
    /* Proportional rhythm: widest gap before price badges section */
    margin-top: 0 !important;
    margin-bottom: 24px !important;
}

/* ── Unified Price Badges ── */
.srg-price-badges-wrap {
    display: flex;
    flex-wrap: wrap;
    /* Soft gap between individual badge pills */
    gap: 8px !important;
    /* Proportional rhythm: zero top margin (desc handles its own bottom) */
    margin-top: 0 !important;
    margin-bottom: 24px !important;
}

.srg-price-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 11px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.02em;
    border: 1.5px solid transparent;
    white-space: nowrap;
    font-family: var(--srg-font-body, sans-serif);
    line-height: 1;
    transition: all 150ms;
}

.srg-badge-free {
    color: #10B981;
    border-color: #D1FAE5;
    background: #ECFDF5;
}

.srg-badge-paid,
.srg-badge-pro {
    color: var(--srg-context-accent, #2563EB);
    border-color: rgba(37, 99, 235, 0.15);
    background: rgba(37, 99, 235, 0.05);
}

/* ── Interactive buttons and contextual color control ── */
.srg-hero-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--srg-space-3, 12px);
    flex-wrap: wrap;
    border-top: 1px solid rgba(37, 99, 235, 0.1);
    padding-top: var(--srg-space-5, 20px);
    margin-top: auto;
}

.srg-hero-btns {
    display: flex;
    gap: var(--srg-space-2-5, 10px);
    flex-wrap: wrap;
}

.srg-hero-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--srg-space-2, 8px);
    font-size: var(--srg-text-sm, 14px);
    font-weight: var(--srg-weight-bold, 700);
    padding: var(--srg-space-2-5, 10px) var(--srg-space-5, 20px);
    border-radius: var(--srg-radius-lg, 10px);
    text-decoration: none !important;
    transition: all 150ms;
    white-space: nowrap;
    cursor: pointer;
    border: 2px solid transparent;
}

.srg-hero-btn-primary {
    background: var(--srg-context-accent, #2563EB);
    color: #ffffff !important;
    border-color: var(--srg-context-accent, #2563EB);
    box-shadow: 0 4px 14px rgba(37, 99, 235, 0.2);
}

.srg-hero-btn-primary:hover {
    filter: brightness(0.9);
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(37, 99, 235, 0.3);
}

.srg-hero-btn-secondary {
    background: transparent;
    color: var(--srg-context-accent, #2563EB) !important;
    border-color: rgba(37, 99, 235, 0.15);
}

.srg-hero-btn-secondary:hover {
    background: rgba(37, 99, 235, 0.05);
    border-color: var(--srg-context-accent, #2563EB);
    transform: translateY(-2px);
}

/* ── Unified modern share bar ── */
.srg-hero-share { display: flex; align-items: center; gap: var(--srg-space-1-5, 6px); }
.srg-share-divider { display: block; width: 1px; height: 20px; background: rgba(37, 99, 235, 0.1); margin-right: var(--srg-space-2, 8px); }
.srg-share-label { font-size: var(--srg-text-xs, 12px); font-weight: var(--srg-weight-bold, 700); color: var(--srg-text-tertiary, #94a3b8); text-transform: uppercase; letter-spacing: 0.8px; margin-right: var(--srg-space-1, 4px); }
.srg-share-icon { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: var(--srg-radius-md, 8px); border: none; background: rgba(37, 99, 235, 0.03); color: var(--srg-context-accent, #2563EB); cursor: pointer; transition: all 150ms; text-decoration: none !important; padding: 0; }
.srg-share-icon:hover { transform: translateY(-2px); color: #ffffff; }
.srg-share-x:hover { background: #090e1a; }
.srg-share-fb:hover { background: #1877F2; }
.srg-share-li:hover { background: #0A66C2; }
.srg-share-copy:hover { background: var(--srg-context-accent, #2563EB); color: #ffffff !important; }
.srg-share-copy.copied { background: var(--srg-accent-50, #ecfdf5); color: var(--srg-accent-600, #059669) !important; }

/* ============================================================
   DARK MODE ADJUSTMENTS
   ============================================================ */
html.srg-dark .srg-single-hero-block { background: linear-gradient(135deg, #090e1a 0%, #0f172a 100%); border-bottom-color: rgba(37, 99, 235, 0.15); }
html.srg-dark .srg-hero-title { color: var(--srg-neutral-50, #f8fafc); }
html.srg-dark .srg-hero-desc { color: var(--srg-neutral-300, #cbd5e1); }
html.srg-dark .srg-hero-rev { color: var(--srg-neutral-400, #94a3b8); }
html.srg-dark .srg-hero-actions { border-top-color: rgba(37, 99, 235, 0.15); }
html.srg-dark .srg-share-divider { background: rgba(37, 99, 235, 0.15); }
html.srg-dark .srg-share-icon { background: rgba(37, 99, 235, 0.12); color: rgba(255, 255, 255, 0.85); }
html.srg-dark .srg-share-x:hover { background: #ffffff; color: #090e1a; }
html.srg-dark .srg-share-fb:hover { background: #1877F2; color: #ffffff; }
html.srg-dark .srg-share-li:hover { background: #0A66C2; color: #ffffff; }
html.srg-dark .srg-share-copy:hover { background: var(--srg-context-accent, #2563EB); color: #ffffff !important; }
html.srg-dark .srg-share-copy.copied { background: rgba(16, 185, 129, 0.2); color: var(--srg-accent-500, #10b981) !important; }

/* Handle price badge colors in dark mode */
html.srg-dark .srg-badge-free { color: #34D399; border-color: rgba(16, 185, 129, 0.2); background: rgba(16, 185, 129, 0.1); }
html.srg-dark .srg-badge-paid, html.srg-dark .srg-badge-pro { color: var(--srg-context-accent, #2563EB); border-color: rgba(37, 99, 235, 0.2); background: rgba(37, 99, 235, 0.1); }

/* ============================================================
   RESPONSIVE ADAPTERS (Updated for Side-by-Side Mobile Head)
   ============================================================ */
@media (max-width: 1024px) {
    .srg-hero-with-media .srg-single-hero-inner { 
        grid-template-columns: 1fr; 
        gap: var(--srg-space-6, 24px); 
    }
}

@media (max-width: 640px) {
    .srg-single-hero-block { 
        padding: var(--srg-space-8, 32px) 0; 
    }
    
    /* Maintain horizontal layout on mobile matching desktop */
    .srg-hero-head { 
        display: flex;
        flex-direction: row !important; /* Horizontal alignment beside logo */
        align-items: normal; 
        gap: var(--srg-space-3-5, 14px); 
        width: 100%;
    }
    
    /* Scale logo responsively on mobile to maintain dimensions */
    .srg-hero-logo-wrap { 
        flex: 0 0 60px !important; 
        width: 60px !important; 
        height: 60px !important; 
    }
    
    .srg-hero-title { 
        font-size: clamp(1.2rem, 4vw, 1.4rem) !important; /* Flexible mobile-friendly font size */
        /* Keep proportional 8px bottom gap consistent with desktop rhythm */
        margin-top: 0 !important;
        margin-bottom: 8px !important;
    }
    
    .srg-hero-meta {
        gap: var(--srg-space-1, 4px); /* Safe gap below title */
    }
    
    .srg-hero-actions { 
        flex-direction: column; 
        align-items: stretch; 
        gap: var(--srg-space-4, 16px); 
    }
    
    .srg-hero-btns { 
        flex-direction: column; 
        width: 100%; 
    }
    
    .srg-hero-btn { 
        width: 100%; 
    }
    
    .srg-hero-share { 
        justify-content: center; 
        border-top: 1px solid rgba(37, 99, 235, 0.1); 
        padding-top: var(--srg-space-4, 16px); 
        width: 100%; 
    }
    
    html.srg-dark .srg-hero-share { 
        border-top-color: rgba(37, 99, 235, 0.15); 
    }
    
    .srg-share-divider { 
        display: none; 
    }
}


/* Elegant responsive last updated bar */
.srg-meta-update-strip {
    display: inline-flex;
    align-items: center;
    background: var(--srg-bg-secondary);
    border: 1px solid var(--srg-border-secondary);
    padding: 8px 16px;
    border-radius: 30px;
    margin-bottom: 24px;
    font-size: 13px;
    font-weight: 500;
    color: var(--srg-text-secondary);
    transition: background 0.3s ease, border-color 0.3s ease;
}

.srg-meta-update-item {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Dynamically color icon with the active section identity */
.srg-meta-clock-icon {
    color: var(--srg-context-accent);
    flex-shrink: 0;
}

/* Resolve margins between alternatives, guides, and FAQ sections */
.srg-spacing-calibrated {
    margin-top: 0px;
    margin-bottom: 50px;
}

@media (max-width: 768px) {
    .srg-spacing-calibrated {
        margin-top: 0px;
        margin-bottom: 50px;
    }
}