/* ======================================================
   Feedback Guru — Custom Styles
   Matched to production https://feedback.guru
   Brand: #FF29CC (hot pink), Dark UI, Montserrat + Manrope
   ====================================================== */

/* Fonts served locally — eliminates Google Fonts network request and layout shift */
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/montserrat.woff2') format('woff2');
    font-weight: 300 900;
    font-style: normal;
    font-display: optional;
}
@font-face {
    font-family: 'Manrope';
    src: url('../fonts/manrope.woff2') format('woff2');
    font-weight: 300 800;
    font-style: normal;
    font-display: optional;
}

:root {
    --fg-pink: #FF29CC;
    --fg-pink-hover: #E620B5;
    --fg-pink-glow: rgba(255, 41, 204, 0.25);
    --fg-pink-light: rgba(255, 41, 204, 0.08);
    --fg-dark: #111111;
    --fg-dark-card: #1A1A1A;
    --fg-dark-border: #2A2A2A;
    --fg-body-bg: #0D0D0D;
    --fg-cream: #FFF8EF;
    /* Slightly lighter default text colors for better contrast */
    --fg-text: #E3E3E3;
    --fg-text-muted: #C0C0C0;
    --fg-white: #FFFFFF;
    --fg-navbar-height: 64px;
    --fg-sidebar-width: 280px;
}


/* ── Global ── */

body {
    font-family: 'Manrope', 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--fg-text);
    background-color: var(--fg-body-bg);
    line-height: 1.7;
    font-size: 16px;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Montserrat', 'Manrope', sans-serif;
    color: var(--fg-white);
    font-weight: 700;
}

.btn-primary {
    background-color: var(--fg-pink);
    border-color: var(--fg-pink);
    color: var(--fg-white);
    font-weight: 600;
}
.btn-primary:hover, .btn-primary:focus {
    background-color: var(--fg-pink-hover);
    border-color: var(--fg-pink-hover);
    box-shadow: 0 0 20px var(--fg-pink-glow);
}
.btn-outline-primary {
    color: var(--fg-pink);
    border-color: var(--fg-pink);
}
.btn-outline-primary:hover {
    background-color: var(--fg-pink);
    border-color: var(--fg-pink);
    color: var(--fg-white);
    box-shadow: 0 0 20px var(--fg-pink-glow);
}
.btn-outline-dark {
    color: var(--fg-text);
    border-color: var(--fg-dark-border);
}
.btn-outline-dark:hover {
    background-color: var(--fg-dark-card);
    border-color: var(--fg-text-muted);
    color: var(--fg-white);
}
.text-primary {
    color: var(--fg-pink) !important;
}
.bg-primary {
    background-color: var(--fg-pink) !important;
}
.border-primary {
    border-color: var(--fg-pink) !important;
}

a {
    color: var(--fg-pink);
}
a:hover {
    color: var(--fg-pink-hover);
}

.tracking-wide {
    letter-spacing: 0.08em;
}

::selection {
    background-color: rgba(63, 73, 81, 0.5);
    color: var(--fg-cream);
}


/* ── Navbar ── */

header.sticky-top {
    background-color: var(--fg-body-bg);
}

.navbar {
    padding: 0.5rem 0;
    background-color: var(--fg-body-bg) !important;
    border-bottom: none !important;
}
.navbar .nav-link {
    color: #E8E8E8;
    font-size: 1.125rem;
    padding: 0.5rem 0.75rem;
    transition: color 0.2s;
}
.navbar .nav-link:hover {
    color: var(--fg-white);
}
.navbar .nav-link.active {
    color: var(--fg-pink);
}
.navbar-brand img {
    filter: none;
}
.navbar-toggler {
    border-color: var(--fg-dark-border);
}
.navbar-toggler-icon {
    filter: invert(1);
}
/* Navbar CTA: inline row on desktop */
@media (min-width: 992px) {
    .fg-nav-cta {
        flex-direction: row;
        align-items: center;
        width: auto;
    }
    .fg-nav-cta .btn {
        width: auto;
    }
}


/* ══════════════════════════════════════════════
   HOMEPAGE SECTIONS
   ══════════════════════════════════════════════ */

/* ── Hero ── */

.fg-hero {
    background: radial-gradient(ellipse at 30% 50%, rgba(255, 41, 204, 0.06) 0%, transparent 60%),
                var(--fg-body-bg);
    overflow: hidden;
}
.fg-built-for-badge {
    display: inline-flex;
    align-items: center;
    background: rgba(149, 191, 70, 0.12);
    border: 1px solid rgba(149, 191, 70, 0.3);
    color: #95BF46;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.35rem 0.9rem;
    border-radius: 50px;
}
.fg-hero-headline {
    font-size: 2.75rem;
    line-height: 1.15;
    color: var(--fg-white);
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
}
.fg-hero-sub {
    font-size: 1.1rem;
    line-height: 1.7;
    color: var(--fg-text);
}
.fg-hero .text-secondary {
    color: var(--fg-text-muted) !important;
}
.fg-hero .fw-bold {
    color: var(--fg-white);
}
.fg-hero-trust-list {
    color: var(--fg-text);
    font-size: 0.95rem;
}
.fg-hero-trust-list li {
    padding-left: 1.4em;
    position: relative;
    margin-bottom: 0.4rem;
}
.fg-hero-trust-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #95BF46;
    font-weight: 700;
}
.fg-hero-img {
    max-width: 100%;
    height: auto;
    filter: drop-shadow(0 0 40px var(--fg-pink-glow));
}

@media (max-width: 991.98px) {
    .fg-hero-headline { font-size: 2rem; }
}
@media (max-width: 575.98px) {
    .fg-hero-headline { font-size: 1.65rem; }
}


/* ── Platform logos bar ── */

.fg-platforms {
    background-color: var(--fg-body-bg);
    border: none;
}
.fg-platforms .text-secondary {
    color: var(--fg-text) !important;
}
.fg-platform-icon {
    width: 48px;
    height: 48px;
    object-fit: contain;
    opacity: 0.9;
    transition: opacity 0.2s;
}
.fg-platform-icon:hover {
    opacity: 1;
}


/* ── Results by the numbers ── */

.fg-stats {
    background-color: var(--fg-dark);
}
.fg-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.fg-stat-number {
    font-family: 'Montserrat', sans-serif;
    font-size: 3.25rem;
    font-weight: 800;
    color: var(--fg-white);
    line-height: 1.1;
}
.fg-stat-accent {
    color: var(--fg-pink);
}
.fg-stat-label {
    font-size: 0.95rem;
    color: var(--fg-text-muted);
    margin-top: 0.25rem;
    font-weight: 500;
}
@media (max-width: 767.98px) {
    .fg-stat-number {
        font-size: 2.5rem;
    }
}


/* ── How it works (tabbed steps) ── */

.fg-how-it-works {
    background-color: var(--fg-body-bg);
}

/* Tab toggle */
.fg-tab-toggle {
    display: inline-flex;
    background: var(--fg-dark-card);
    border-radius: 50px;
    border: 1px solid var(--fg-dark-border);
    padding: 4px;
}
.fg-tab-btn {
    background: transparent;
    border: none;
    color: var(--fg-text-muted);
    font-size: 0.9rem;
    font-weight: 600;
    padding: 0.5rem 1.25rem;
    border-radius: 50px;
    cursor: pointer;
    transition: all 0.2s;
}
.fg-tab-btn.active {
    background: var(--fg-pink);
    color: #fff;
}
.fg-tab-btn:hover:not(.active) {
    color: var(--fg-white);
}

/* Step circles and connectors */
.fg-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(255, 41, 204, 0.1);
    border: 2px solid var(--fg-pink);
    color: var(--fg-pink);
    font-family: 'Montserrat', sans-serif;
    font-size: 1.5rem;
    font-weight: 800;
    position: relative;
    z-index: 1;
}
.fg-step {
    position: relative;
}
.fg-step-connector {
    position: absolute;
    top: 28px;
    left: calc(50% + 36px);
    width: calc(100% - 72px);
    height: 2px;
    background: var(--fg-dark-border);
    z-index: 0;
}
.col-md-4:last-child .fg-step-connector {
    display: none !important;
}
.fg-how-it-works h2 {
    color: var(--fg-white);
}
.fg-how-it-works h5 {
    color: var(--fg-white);
}
.fg-how-it-works .text-secondary {
    color: var(--fg-text-muted) !important;
}


/* ── Showcase (dashboard + phone) ── */

.fg-showcase {
    background-color: var(--fg-dark) !important;
}
.fg-showcase h3 {
    color: var(--fg-white);
}
.fg-showcase .text-secondary {
    color: var(--fg-text-muted) !important;
}
.fg-showcase .rounded-3 {
    border: 1px solid var(--fg-dark-border);
}
.fg-phone-screenshot {
    max-height: 420px;
    width: auto;
    filter: drop-shadow(0 8px 24px rgba(0,0,0,0.3));
}


/* ── Why More Reviews ── */

.fg-why-reviews {
    background-color: var(--fg-body-bg);
}
.fg-why-reviews h2 {
    color: var(--fg-white);
}
.fg-reason-card {
    background: var(--fg-dark-card);
    border-radius: 12px;
    border: 1px solid var(--fg-dark-border);
    height: 100%;
}
.fg-reason-card h5 {
    color: var(--fg-white);
}
.fg-reason-icon {
    width: 64px;
    height: 64px;
    filter: none;
}
/* Center the bottom row of 2 cards under the top row of 3 */
.fg-why-reviews .row {
    justify-content: center;
}


/* ── Tier colors ── */

:root {
    --tier-pioneer: #F9A8D4;      /* light pink */
    --tier-starter: #94A3B8;      /* light blue-gray */
    --tier-premium: #FF29CC;      /* magenta / site accent */
    --tier-professional: #FACC15; /* gold */
}

/* ── Competitor comparison table ── */

.fg-comparison {
    background-color: var(--fg-body-bg);
}
.fg-comparison h2 {
    color: var(--fg-white);
}
.fg-comparison-table {
    background: var(--fg-dark-card);
    border-radius: 12px;
    overflow: hidden;
    color: var(--fg-text);
    border: 1px solid var(--fg-dark-border);
    --bs-table-bg: transparent;
    --bs-table-color: var(--fg-text);
}
.fg-comparison-table thead th {
    background: rgba(255, 255, 255, 0.04);
    font-weight: 700;
    font-size: 1.05rem;
    padding: 1.1rem 1rem;
    border-bottom: 2px solid var(--fg-dark-border);
    border-color: var(--fg-dark-border);
    color: var(--fg-text-muted);
}
.fg-comparison-table thead th.fg-col-highlight {
    color: var(--fg-pink);
    border-bottom-color: var(--fg-pink);
}
.fg-comparison-table tbody tr {
    border-color: var(--fg-dark-border);
}
.fg-comparison-table tbody td {
    padding: 0.85rem 1rem;
    vertical-align: middle;
    border-color: var(--fg-dark-border);
    background: transparent;
}
.fg-comparison-table tbody td.fg-col-highlight {
    background: rgba(255, 41, 204, 0.04);
}
.fg-comparison-table tbody tr:hover {
    background: rgba(255, 255, 255, 0.02);
}
.fg-check-yes {
    color: var(--fg-pink);
    font-weight: 700;
    font-size: 1.1rem;
}
.fg-check-no {
    color: #555;
    font-weight: 600;
    font-size: 1.1rem;
}
.fg-check-muted {
    color: var(--fg-text-muted);
    font-size: 0.9rem;
}


/* ── Pricing cards ── */

.fg-pricing {
    background-color: var(--fg-body-bg);
}
.fg-pricing-card {
    background: var(--fg-dark-card);
    border-radius: 16px;
    border: 1px solid var(--fg-dark-border);
    transition: transform 0.2s, box-shadow 0.2s;
}
.fg-pricing-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(255, 41, 204, 0.1);
}
/* Plan titles use the standard heading color for a more consistent look */
.fg-pricing-card h4 {
    color: var(--fg-white);
}
.fg-pricing-card h4.tier-pioneer,
.fg-pricing-card h4.tier-starter,
.fg-pricing-card h4.tier-premium,
.fg-pricing-card h4.tier-professional {
    color: var(--fg-white);
}
.fg-pricing-card .text-secondary {
    color: var(--fg-text-muted) !important;
}
.fg-pricing-highlighted {
    border-color: var(--tier-professional);
    background:
        radial-gradient(circle at 0% 100%, rgba(250, 204, 21, 0.10) 0%, transparent 55%),
        var(--fg-dark-card);
    box-shadow: 0 0 30px rgba(250, 204, 21, 0.30);
}
.fg-pricing-highlighted:hover {
    box-shadow: 0 0 40px rgba(250, 204, 21, 0.45);
    transform: translateY(-6px);
}

/* Pioneer urgency */
.fg-pricing-pioneer {
    border-color: var(--tier-pioneer);
    box-shadow: 0 0 20px rgba(249, 168, 212, 0.15);
    animation: pioneer-glow 3s ease-in-out infinite;
}
@keyframes pioneer-glow {
    0%, 100% { box-shadow: 0 0 20px rgba(249, 168, 212, 0.15); }
    50%      { box-shadow: 0 0 32px rgba(249, 168, 212, 0.3); }
}
.fg-pricing-pioneer:hover {
    box-shadow: 0 0 36px rgba(249, 168, 212, 0.35);
}
.fg-pricing-highlighted .btn-primary {
    background-image: linear-gradient(135deg, #FACC15, #F97316);
    border: none;
    color: #1A1A1A;
    box-shadow: 0 0 18px rgba(250, 204, 21, 0.45);
}
.fg-pricing-highlighted .btn-primary:hover,
.fg-pricing-highlighted .btn-primary:focus {
    background-image: linear-gradient(135deg, #FDE047, #FB923C);
    box-shadow: 0 0 26px rgba(250, 204, 21, 0.65);
    color: #1A1A1A;
}
.fg-badge-urgent {
    background: var(--tier-pioneer);
    color: #1A1A1A;
    animation: badge-pulse 2s ease-in-out infinite;
}
@keyframes badge-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.7; }
}
.fg-lock-in-text {
    color: var(--tier-pioneer);
    letter-spacing: 0.02em;
}
.fg-price-amount {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--fg-white);
    line-height: 1;
}
.fg-pricing-card .badge {
    font-weight: 600;
}
.fg-pricing-features {
    text-align: center;
}
.fg-pricing-features li {
    text-align: center;
}
.fg-shopify-badge-link {
    color: var(--fg-white) !important;
    opacity: 1;
    transition: opacity 0.2s;
    font-size: 0.78rem;
}
.fg-shopify-badge-link:hover {
    opacity: 1;
    color: var(--fg-pink) !important;
}

/* ── Mid-page CTA strip ── */

.fg-mid-cta {
    background-color: var(--fg-dark);
    border: none;
}
.fg-mid-cta .fs-5 {
    color: var(--fg-white);
}


/* ── Testimonials ── */

.fg-testimonial {
    background-color: var(--fg-dark);
}
.fg-testimonial h3 {
    color: var(--fg-white);
}
.fg-testimonial .text-secondary,
.fg-testimonial .fw-bold.text-secondary {
    color: var(--fg-text-muted) !important;
}
.fg-testimonial-card {
    background: var(--fg-dark-card);
    border-radius: 12px;
    border: 1px solid var(--fg-dark-border);
    transition: box-shadow 0.2s, border-color 0.2s;
}
.fg-testimonial-card:hover {
    box-shadow: 0 0 20px var(--fg-pink-glow);
    border-color: rgba(255, 41, 204, 0.25);
}
.fg-testimonial-card .text-secondary {
    color: var(--fg-text) !important;
}
.fg-testimonial-card .fw-bold {
    color: var(--fg-white);
}
.fg-testimonial-card .small.text-secondary {
    color: var(--fg-text-muted) !important;
}
.fg-stars {
    color: #FACC15;
    font-size: 1.1rem;
    letter-spacing: 2px;
}


/* ── FAQ ── */

.fg-faq {
    background-color: var(--fg-body-bg);
}
.fg-faq h2 {
    color: var(--fg-white);
}
.fg-faq .accordion-item {
    background: transparent;
    border-color: var(--fg-dark-border) !important;
}
.fg-faq .accordion-button {
    background: transparent;
    box-shadow: none;
    padding: 1.25rem 0;
    font-size: 1rem;
    color: var(--fg-white);
}
.fg-faq .accordion-button::after {
    filter: invert(1);
}
.fg-faq .accordion-button:not(.collapsed) {
    color: var(--fg-pink);
    background: transparent;
}
.fg-faq .accordion-body {
    padding: 0 0 1.25rem 0;
    color: var(--fg-text-muted);
}


/* ── Bottom CTA ── */

.fg-bottom-cta {
    background: linear-gradient(135deg, #1A0A14 0%, #2D0A23 50%, #1A0A14 100%) !important;
    border-top: 1px solid rgba(255, 41, 204, 0.2);
    border-bottom: 1px solid rgba(255, 41, 204, 0.2);
}
.fg-bottom-cta h2 {
    color: var(--fg-white);
}
.fg-bottom-cta .btn-light {
    background: var(--fg-pink);
    border-color: var(--fg-pink);
    color: var(--fg-white) !important;
    font-weight: 700;
}
.fg-bottom-cta .btn-light:hover {
    background: var(--fg-pink-hover);
    box-shadow: 0 0 24px var(--fg-pink-glow);
}

/* ── Try it out promo + pages ── */

.fg-try-eyebrow {
    letter-spacing: 0.08em;
    color: #f9a8d4;
}

.fg-try-promo {
    background-color: var(--fg-body-bg);
}

.fg-try-promo-card {
    background: linear-gradient(135deg, rgba(255, 41, 204, 0.09) 0%, rgba(26, 26, 26, 1) 42%, rgba(17, 17, 17, 1) 100%);
    border: 1px solid rgba(255, 41, 204, 0.25);
    border-radius: 14px;
}

.fg-try-hero,
.fg-results-hero {
    background: radial-gradient(ellipse at 30% 40%, rgba(255, 41, 204, 0.08) 0%, transparent 58%), var(--fg-body-bg);
}

.fg-results-hero {
    background: var(--fg-body-bg);
}

.page-review-test-results .fg-results-hero .fg-hero-sub {
    color: #e6e6e6 !important;
}

.fg-try-form-card,
.fg-results-message-card {
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 14px;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.25);
}

.fg-try-form .form-label {
    color: var(--fg-white);
    font-weight: 600;
}

.fg-try-form .form-control {
    background-color: var(--fg-dark);
    border: 1px solid var(--fg-dark-border);
    border-radius: 8px;
    color: var(--fg-text);
    padding: 0.75rem 1rem;
}

.fg-try-form .form-control:focus {
    border-color: var(--fg-pink);
    box-shadow: 0 0 0 3px var(--fg-pink-glow);
    background-color: var(--fg-dark);
    color: var(--fg-white);
}

.fg-try-form .form-control::placeholder {
    color: var(--fg-text-muted);
    opacity: 0.6;
}

.fg-try-form .g-recaptcha {
    min-height: 78px;
    display: table;
    margin: 0 auto;
}

.fg-try-message {
    border-radius: 10px;
    border-width: 1px;
}

.fg-try-conversion,
.fg-results-cta {
    background-color: var(--fg-dark);
}

.fg-try-choice-card {
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 14px;
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.fg-try-choice-card:hover {
    border-color: rgba(255, 41, 204, 0.35);
    box-shadow: 0 8px 26px rgba(255, 41, 204, 0.12);
    transform: translateY(-3px);
}

.fg-try-choice-card-primary {
    border-color: rgba(255, 41, 204, 0.55);
    box-shadow: 0 0 26px rgba(255, 41, 204, 0.16);
}

.page-review-test-results .fg-try-choice-card-primary {
    background:
        radial-gradient(circle at 15% 12%, rgba(255, 41, 204, 0.2) 0%, transparent 55%),
        var(--fg-dark-card);
    border-color: rgba(255, 41, 204, 0.85);
    box-shadow: 0 0 36px rgba(255, 41, 204, 0.26);
    transform: translateY(-4px) scale(1.01);
}

.page-review-test-results .fg-try-choice-card-primary:hover {
    box-shadow: 0 0 44px rgba(255, 41, 204, 0.35);
    transform: translateY(-5px) scale(1.015);
}

.page-review-test-results .fg-try-choice-card-primary .btn {
    width: 100%;
}

.fg-results-decision {
    background: linear-gradient(135deg, rgba(255, 41, 204, 0.09) 0%, rgba(26, 26, 26, 1) 42%, rgba(17, 17, 17, 1) 100%);
    border: 1px solid rgba(255, 41, 204, 0.25);
    border-radius: 14px;
    box-shadow: none;
}

.fg-results-decision-badge {
    letter-spacing: 0.08em;
    color: #f9a8d4;
}

.fg-results-decision-list li {
    color: var(--fg-text);
    font-size: 0.95rem;
    margin-bottom: 0.35rem;
    padding-left: 1.35rem;
    position: relative;
}

.fg-results-decision-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #95BF46;
    font-weight: 700;
}

.fg-results-cta-note {
    display: block;
    text-align: center;
}

.fg-results-cta-stack {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
}

.fg-results-message {
    background-color: var(--fg-body-bg);
}

.fg-results-stars {
    display: inline-flex;
    gap: 0.25rem;
    font-size: 2.1rem;
    line-height: 1;
}

.fg-results-rating-summary {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.1) 0%, transparent 60%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(17, 17, 17, 0.7));
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 14px;
    padding: 1rem 1.35rem;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        0 2px 6px rgba(0, 0, 0, 0.2),
        0 18px 20px -16px rgba(0, 0, 0, 0.55);
    min-width: 240px;
}

.fg-results-guidance {
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 14px;
}

.fg-results-star.is-filled {
    color: #facc15;
}

.fg-results-star.is-empty {
    color: #555;
}

.fg-results-rating-summary #review-results-rating-label {
    color: var(--fg-white);
    font-weight: 700;
    letter-spacing: 0.01em;
}


/* ── Footer ── */

.fg-footer {
    background-color: var(--fg-dark);
    border-top: 1px solid var(--fg-dark-border);
}
.fg-footer .text-secondary {
    color: var(--fg-text-muted) !important;
}
.fg-footer a {
    color: var(--fg-text-muted);
}
.fg-footer a:hover {
    color: var(--fg-pink);
}
.fg-footer-heading {
    color: var(--fg-white);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}


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

.page-docs .docs-layout {
    min-height: calc(100vh - var(--fg-navbar-height));
}

.docs-sidebar-col {
    position: sticky;
    top: var(--fg-navbar-height);
    height: calc(100vh - var(--fg-navbar-height));
    overflow-y: auto;
    scrollbar-width: thin;
    z-index: 10;
    background-color: var(--fg-dark) !important;
    border-color: var(--fg-dark-border) !important;
}

.docs-sidebar-heading {
    color: var(--fg-text-muted);
    letter-spacing: 0.06em;
    font-size: 0.7rem;
}
.docs-nav .nav-link {
    color: var(--fg-text-muted);
    padding: 0.4rem 0.75rem;
    border-radius: 0.375rem;
    border-left: 3px solid transparent;
    font-size: 0.875rem;
    transition: all 0.15s ease;
}
.docs-nav .nav-link:hover {
    color: var(--fg-pink);
    background-color: var(--fg-pink-light);
}
.docs-nav .nav-link.active {
    color: var(--fg-pink);
    background-color: var(--fg-pink-light);
    border-left-color: var(--fg-pink);
}
.docs-nav > .nav-item + .nav-item {
    margin-top: 0.15rem;
}

.docs-section-toggle .bi-chevron-down {
    transition: transform 0.2s ease;
    font-size: 0.7rem;
}
.docs-section-toggle[aria-expanded="true"] .bi-chevron-down {
    transform: rotate(180deg);
}

.docs-content-col {
    max-width: 800px;
    min-height: calc(100vh - var(--fg-navbar-height));
    background-color: var(--fg-body-bg);
}

/* Docs landing page - card-style link list */
.docs-landing ol,
.docs-landing ul {
    list-style: none;
    padding-left: 0;
}
.docs-landing ol li,
.docs-landing ul li {
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 10px;
    padding: 0.85rem 1.15rem;
    margin-bottom: 0.6rem;
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
}
.docs-landing ol li:hover,
.docs-landing ul li:hover {
    border-color: rgba(255, 41, 204, 0.3);
    box-shadow: 0 2px 12px rgba(255, 41, 204, 0.08);
    transform: translateX(4px);
}
.docs-landing ol li a,
.docs-landing ul li a {
    color: var(--fg-pink);
    font-weight: 600;
}

.docs-article .lead.text-secondary {
    /* Slightly darker than standard body text for subtle emphasis */
    color: #d0d0d0 !important;
}

/* ── Docs Typography ── */

.docs-body h2 {
    margin-top: 2rem;
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--fg-dark-border);
    font-weight: 700;
    color: var(--fg-white);
}
.docs-body h3 {
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
    font-weight: 600;
    color: var(--fg-white);
}
.docs-body h4 {
    margin-top: 1.25rem;
    font-weight: 600;
    color: var(--fg-white);
}

.docs-body code {
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 0.25rem;
    padding: 0.125rem 0.375rem;
    font-size: 0.85em;
    color: var(--fg-pink);
}
.docs-body pre {
    background: #0A0A0A;
    color: #e2e8f0;
    border-radius: 0.5rem;
    padding: 1.25rem;
    margin: 1rem 0;
    overflow-x: auto;
    font-size: 0.875rem;
    line-height: 1.6;
    border: 1px solid var(--fg-dark-border);
}
.docs-body pre code {
    background: none;
    border: none;
    padding: 0;
    color: inherit;
    font-size: inherit;
}
.docs-body blockquote {
    border-left: 4px solid var(--fg-pink);
    padding: 0.75rem 1rem;
    background: var(--fg-dark-card);
    border-radius: 0 0.375rem 0.375rem 0;
    margin: 1rem 0;
    color: var(--fg-text);
}
.docs-body table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
}
.docs-body table th,
.docs-body table td {
    padding: 0.625rem 0.75rem;
    border: 1px solid var(--fg-dark-border);
    text-align: left;
}
.docs-body table th {
    background: var(--fg-dark-card);
    font-weight: 600;
    color: var(--fg-white);
}
.docs-body img {
    max-width: 100%;
    border-radius: 0.5rem;
    margin: 1rem 0;
    border: 1px solid var(--fg-dark-border);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
}

/* Docs FAQ accordions */
.docs-body details {
    margin-bottom: 0.75rem;
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 10px;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
    padding: 0 1.25rem;
}
.docs-body details:hover {
    border-color: rgba(255, 41, 204, 0.25);
}
.docs-body details[open] {
    border-color: rgba(255, 41, 204, 0.3);
    box-shadow: 0 2px 12px rgba(255, 41, 204, 0.08);
    padding-bottom: 1rem;
}
.docs-body details summary {
    padding: 1rem 0;
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-weight: 600;
    color: var(--fg-white);
    transition: color 0.15s;
}
.docs-body details summary::-webkit-details-marker {
    display: none;
}
.docs-body details summary::after {
    content: '+';
    font-size: 1.2rem;
    font-weight: 300;
    color: var(--fg-text-muted);
    transition: transform 0.2s, color 0.2s;
    flex-shrink: 0;
    margin-left: 1rem;
}
.docs-body details[open] summary::after {
    content: '-';
    color: var(--fg-pink);
}
.docs-body details summary:hover {
    color: var(--fg-pink);
}
.docs-body details > *:not(summary) {
    padding-top: 0.25rem;
    padding-bottom: 1.25rem;
}

.docs-body h3 + details {
    margin-top: 0.75rem;
}

/* Docs breadcrumb */
.breadcrumb-item a {
    color: var(--fg-text-muted);
}
.breadcrumb-item a:hover {
    color: var(--fg-pink);
}
.breadcrumb-item.active {
    color: var(--fg-text);
}
.breadcrumb-item + .breadcrumb-item::before {
    color: var(--fg-text-muted);
}

/* Docs prev/next */
.docs-prevnext {
    border-color: var(--fg-dark-border) !important;
}
.docs-pn-card {
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 10px;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.docs-pn-card:hover {
    border-color: rgba(255, 41, 204, 0.35);
    box-shadow: 0 4px 16px rgba(255, 41, 204, 0.08);
}
.docs-pn-label {
    color: var(--fg-text-muted);
}
.docs-pn-title {
    color: var(--fg-white);
    font-size: 0.95rem;
    transition: color 0.15s;
}
.docs-pn-card:hover .docs-pn-title {
    color: var(--fg-pink);
}
.docs-pn-next {
    text-align: right;
}


/* ── Table of Contents (Right Sidebar) ── */

.toc-sidebar {
    position: sticky;
    top: calc(var(--fg-navbar-height) + 1.5rem);
}
.toc-sidebar h6 {
    color: var(--fg-text-muted);
}
.toc-nav .nav-link {
    color: var(--fg-text-muted);
    font-size: 0.8rem;
    padding: 0.2rem 0;
    border-left: 2px solid transparent;
    padding-left: 0.75rem;
    transition: all 0.15s ease;
}
.toc-nav .nav-link:hover,
.toc-nav .nav-link.active {
    color: var(--fg-pink);
    border-left-color: var(--fg-pink);
}
.toc-nav .nav-link.toc-h3 {
    padding-left: 1.5rem;
    font-size: 0.75rem;
}


/* ══════════════════════════════════════════════
   BLOG
   ══════════════════════════════════════════════ */

.page-blog .container,
.page-blog-post .container {
    color: var(--fg-text);
}
.page-blog h1, .page-blog-post h1 {
    color: var(--fg-white);
}
.page-blog .text-dark {
    color: var(--fg-white) !important;
}

/* Blog hero */
.fg-blog-hero {
    background: radial-gradient(ellipse at 50% 80%, rgba(255, 41, 204, 0.06) 0%, transparent 60%),
                var(--fg-body-bg);
    border-bottom: 1px solid var(--fg-dark-border);
}

/* Blog listing */
.fg-blog-listing {
    background-color: var(--fg-body-bg);
}
.fg-blog-card {
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 12px;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.fg-blog-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(255, 41, 204, 0.1);
    border-color: rgba(255, 41, 204, 0.3);
}
.fg-blog-card-title {
    color: var(--fg-white);
    transition: color 0.2s;
}
.fg-blog-card:hover .fg-blog-card-title {
    color: var(--fg-pink);
}
.fg-blog-badge {
    background: var(--fg-pink-light);
    color: var(--fg-pink);
    font-weight: 600;
    font-size: 0.75rem;
}
.fg-blog-arrow {
    font-size: 1.5rem;
    color: var(--fg-text-muted);
    transition: color 0.2s, transform 0.2s;
}
.fg-blog-card:hover .fg-blog-arrow {
    color: var(--fg-pink);
    transform: translateX(4px);
}

/* Blog category filters */
.fg-blog-filters {
    border-bottom: 1px solid var(--fg-dark-border);
    padding-bottom: 0.75rem;
    margin-bottom: 1.25rem;
}
.fg-filter-btn {
    display: inline-block;
    padding: 0.4rem 1.1rem;
    border-radius: 50px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--fg-text-muted);
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    text-decoration: none;
    transition: all 0.2s;
}
.fg-filter-btn:hover {
    color: var(--fg-white);
    border-color: var(--fg-text-muted);
}
.fg-filter-btn.active {
    background: var(--fg-pink);
    border-color: var(--fg-pink);
    color: var(--fg-white);
}

.blog-body h2 {
    margin-top: 2rem;
    margin-bottom: 0.75rem;
    font-weight: 700;
    color: var(--fg-white);
}
.blog-body h3 {
    margin-top: 1.5rem;
    font-weight: 600;
    color: var(--fg-white);
}
.blog-body img {
    max-width: 100%;
    border-radius: 0.5rem;
    margin: 1rem 0;
}
.blog-body pre {
    background: #0A0A0A;
    color: #e2e8f0;
    border-radius: 0.5rem;
    padding: 1.25rem;
    overflow-x: auto;
    border: 1px solid var(--fg-dark-border);
}
.blog-body code {
    background: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 0.25rem;
    padding: 0.125rem 0.375rem;
    font-size: 0.85em;
    color: var(--fg-pink);
}
.blog-body pre code {
    background: none;
    border: none;
    padding: 0;
    color: inherit;
}
.blog-body blockquote {
    border-left: 4px solid var(--fg-pink);
    padding: 0.75rem 1rem;
    background: var(--fg-dark-card);
    border-radius: 0 0.375rem 0.375rem 0;
    color: var(--fg-text);
}

/* Blog badges */
.badge.bg-primary.bg-opacity-10 {
    background-color: var(--fg-pink-light) !important;
    color: var(--fg-pink) !important;
}
.badge.bg-light {
    background-color: var(--fg-dark-card) !important;
    color: var(--fg-text) !important;
    border-color: var(--fg-dark-border) !important;
}

/* Blog post back link */
.page-blog-post .border-top {
    border-color: var(--fg-dark-border) !important;
}


/* ── About page ── */

.fg-about-hero {
    background: radial-gradient(ellipse at 50% 80%, rgba(255, 41, 204, 0.08) 0%, transparent 60%),
                var(--fg-body-bg);
    border-bottom: 1px solid var(--fg-dark-border);
}
.fg-about-hero .fg-hero-headline {
    font-size: 2.5rem;
}
.fg-about-hero .text-secondary {
    color: var(--fg-text) !important;
}

.fg-about-section {
    background-color: var(--fg-body-bg);
}
.fg-about-section-alt {
    background-color: var(--fg-dark);
}
.fg-about-section h2 {
    color: var(--fg-white);
}
.fg-about-section p {
    color: var(--fg-text);
    font-size: 1.05rem;
    line-height: 1.8;
}

.fg-about-quote {
    border-left: 4px solid var(--fg-pink);
    background: var(--fg-dark-card);
    border-radius: 0 12px 12px 0;
    padding: 1.25rem 1.5rem;
    margin: 1.75rem 0;
    font-size: 1.15rem;
    font-style: italic;
    color: var(--fg-white);
    line-height: 1.7;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}

.fg-about-value-card {
    background: var(--fg-dark-card);
    border-radius: 12px;
    border: 1px solid var(--fg-dark-border);
    transition: transform 0.2s, box-shadow 0.2s;
}
.fg-about-value-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(255, 41, 204, 0.1);
}
.fg-about-value-card h5 {
    color: var(--fg-white);
}
.fg-about-value-card .text-secondary {
    color: var(--fg-text-muted) !important;
}
.fg-about-value-icon img {
    opacity: 0.85;
}

.fg-about-cta {
    background: linear-gradient(135deg, #1A0A14 0%, #2D0A23 50%, #1A0A14 100%);
    border-top: 1px solid rgba(255, 41, 204, 0.2);
}
.fg-about-cta h2 {
    color: var(--fg-white);
}
.fg-about-cta .text-secondary {
    color: var(--fg-text) !important;
}

@media (max-width: 575.98px) {
    .fg-about-hero .fg-hero-headline {
        font-size: 1.75rem;
    }
    .fg-about-quote {
        font-size: 1rem;
        padding: 1rem 1.15rem;
    }
    .fg-about-cta .btn-lg {
        width: 100%;
    }
}


/* ── Generic page (about, contact) ── */

.page-content {
    color: var(--fg-text);
}
.page-content h2, .page-content h3, .page-content h4 {
    color: var(--fg-white);
}
.page-content a {
    color: var(--fg-pink);
}
.page-content strong {
    color: var(--fg-pink);
}


/* ── Contact Form (Grav Form Plugin) ── */

.form-wrapper {
    margin-top: 1rem;
}

/* Each field row */
.form-field {
    margin-bottom: 1.5rem;
}

/* Label wrapper */
.form-field .form-label {
    margin-bottom: 0.5rem;
}
.form-field .form-label label {
    color: var(--fg-white);
    font-weight: 600;
    font-size: 0.9rem;
    display: block;
}
.form-field .form-label .required {
    color: var(--fg-pink);
    margin-left: 2px;
}

/* Input and textarea styling */
.form-field input[type="text"],
.form-field input[type="email"],
.form-field textarea {
    background-color: var(--fg-dark-card);
    border: 1px solid var(--fg-dark-border);
    border-radius: 8px;
    color: var(--fg-text);
    padding: 0.7rem 1rem;
    width: 100%;
    font-size: 0.95rem;
    font-family: inherit;
    transition: border-color 0.2s, box-shadow 0.2s;
    display: block;
    box-sizing: border-box;
}
.form-field input[type="text"]::placeholder,
.form-field input[type="email"]::placeholder,
.form-field textarea::placeholder {
    color: var(--fg-text-muted);
    opacity: 0.5;
}
.form-field input[type="text"]:focus,
.form-field input[type="email"]:focus,
.form-field textarea:focus {
    outline: none;
    border-color: var(--fg-pink);
    box-shadow: 0 0 0 3px var(--fg-pink-glow);
    background-color: var(--fg-dark-card);
    color: var(--fg-white);
}
.form-field textarea {
    resize: vertical;
    min-height: 140px;
}

/* Button wrapper */
.form-wrapper .buttons {
    margin-top: 0.5rem;
}

/* Validation errors */
.form-field .form-errors,
.form-field .has-errors input,
.form-field .has-errors textarea {
    border-color: #ef4444;
}
.form-errors .form-message {
    color: #ef4444;
    font-size: 0.85rem;
    margin-top: 0.35rem;
}

/* Contact form success / error messages (theme override) */
.fg-form-message.alert {
    border-radius: 12px;
    border: 1px solid;
    font-size: 0.95rem;
    font-weight: 500;
    padding: 1rem 1.25rem;
}
.fg-form-message.alert-success {
    background: var(--fg-pink-light);
    border-color: rgba(255, 41, 204, 0.35);
    color: var(--fg-text);
}
.fg-form-message.alert-success .bi-check-circle-fill {
    color: var(--fg-pink);
}
.fg-form-message.alert-danger {
    background: rgba(239, 68, 68, 0.08);
    border-color: rgba(239, 68, 68, 0.35);
    color: #fca5a5;
}
.fg-form-message.alert-danger .bi-exclamation-circle-fill {
    color: #ef4444;
}
.fg-form-message.alert-warning {
    background: rgba(234, 179, 8, 0.08);
    border-color: rgba(234, 179, 8, 0.35);
    color: #fde047;
}
.fg-form-message.alert-warning .bi-exclamation-triangle-fill {
    color: #eab308;
}

/* Legacy notices (fallback if plugin uses old markup) */
.notices {
    margin-bottom: 1.5rem;
}
.notices.success p,
.notices.green p {
    background: var(--fg-pink-light);
    border: 1px solid rgba(255, 41, 204, 0.35);
    color: var(--fg-text);
    border-radius: 12px;
    padding: 1rem 1.25rem;
    font-weight: 500;
    font-size: 0.95rem;
}
.notices.error p,
.notices.red p {
    background: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.35);
    color: #fca5a5;
    border-radius: 12px;
    padding: 1rem 1.25rem;
    font-weight: 500;
    font-size: 0.95rem;
}


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

/* ── Large (≤ 991px — tablet portrait) ── */

@media (max-width: 991.98px) {

    /* Docs sidebar becomes static on tablet/mobile */
    .docs-sidebar-col {
        position: static;
        height: auto;
        border-end: none !important;
        padding-top: 1rem !important;
        padding-bottom: 0 !important;
    }
    .docs-content-col {
        max-width: 100%;
    }

    /* Navbar CTA buttons stack vertically in mobile menu */
    .fg-nav-cta {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
    }
    .fg-nav-cta .btn {
        width: 100%;
        text-align: center;
    }

    /* Showcase phone screenshot smaller on tablet */
    .fg-phone-screenshot {
        max-height: 340px;
    }
}


/* ── Medium (≤ 767px — mobile landscape) ── */

@media (max-width: 767.98px) {

    /* Platform icons shrink on mobile */
    .fg-platform-icon {
        width: 36px;
        height: 36px;
    }

    /* Comparison table: smaller text for mobile scrolling */
    .fg-comparison-table {
        font-size: 0.85rem;
    }
    .fg-comparison-table thead th {
        font-size: 0.9rem;
        padding: 0.75rem 0.6rem;
    }
    .fg-comparison-table tbody td {
        padding: 0.6rem 0.5rem;
    }

    /* Pricing: slightly smaller price on narrower cards */
    .fg-price-amount {
        font-size: 2rem;
    }

    /* Showcase phone screenshot smaller */
    .fg-phone-screenshot {
        max-height: 280px;
    }

    /* Reason cards: reduce icon size on mobile */
    .fg-reason-icon {
        width: 48px;
        height: 48px;
    }

    /* Footer: make CTA button full width on mobile */
    .fg-footer .btn {
        width: 100%;
        text-align: center;
    }
}


/* ── Small (≤ 575px — mobile portrait) ── */

@media (max-width: 575.98px) {

    /* Tab toggle: stack vertically on very small screens */
    .fg-tab-toggle {
        flex-direction: column;
        border-radius: 12px;
        width: 100%;
    }
    .fg-tab-btn {
        width: 100%;
        text-align: center;
        border-radius: 8px;
    }

    /* Step numbers slightly smaller */
    .fg-step-number {
        width: 48px;
        height: 48px;
        font-size: 1.25rem;
    }

    /* Platform icons even smaller on phones */
    .fg-platform-icon {
        width: 30px;
        height: 30px;
    }

    /* Platform section text: don't break to two lines, shrink */
    .fg-platforms .text-secondary.small {
        font-size: 0.75rem;
    }

    /* Stats section: tighter on phones */
    .fg-stat-number {
        font-size: 2rem;
    }
    .fg-stat-label {
        font-size: 0.8rem;
    }

    /* Hero CTA: full width button on mobile */
    .fg-hero .btn-lg {
        width: 100%;
        text-align: center;
    }

    /* Pricing: stack better */
    .fg-price-amount {
        font-size: 1.75rem;
    }

    /* Bottom CTA: full width button */
    .fg-bottom-cta .btn-lg {
        width: 100%;
    }

    .fg-try-promo-card .btn-lg {
        width: 100%;
    }

    /* Comparison table: even smaller */
    .fg-comparison-table {
        font-size: 0.78rem;
    }
    .fg-comparison-table thead th {
        font-size: 0.8rem;
        padding: 0.6rem 0.4rem;
    }

    /* Footer columns: full-width logo column on phones */
    .fg-footer .col-lg-4 {
        text-align: center;
    }
    .fg-footer .col-lg-4 .btn {
        display: inline-block;
        width: auto;
    }

    .fg-results-stars {
        font-size: 1.8rem;
    }
}
