/* ════════════════════════════════════════════════════════════════════════
   FASE 7 — Premium Marketing Front Door (2026-05-08)
   ────────────────────────────────────────────────────────────────────────
   Marketing surfaces (Features, Pricing, Trust, Privacy) need a
   premium first impression — no admin chrome, no sidebar, clean nav,
   strong type hierarchy, generous whitespace.

   Scoped to body[data-area="marketing"]. _MarketingLayout.cshtml does
   NOT load admin-chrome.css or admin-themed.css; this file inherits
   only platforma-tokens + platforma-type + platforma-design-system.
   ──────────────────────────────────────────────────────────────────────── */

/* ─── Reset essentials (marketing layout is otherwise un-styled) ────── */
body[data-area="marketing"] {
    margin: 0;
    background: var(--platforma-white, #fff);
    color: var(--platforma-ink-strong, #111827);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
                 "Helvetica Neue", Arial, sans-serif;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body[data-area="marketing"] *,
body[data-area="marketing"] *::before,
body[data-area="marketing"] *::after {
    box-sizing: border-box;
}

body[data-area="marketing"] a {
    color: var(--platforma-brand, #D4213D);
    text-decoration: none;
}

body[data-area="marketing"] a:hover {
    text-decoration: underline;
    text-underline-offset: 3px;
}

body[data-area="marketing"] a:focus-visible {
    outline: 2px solid var(--platforma-brand, #D4213D);
    outline-offset: 2px;
    border-radius: 4px;
}

/* Skip-link visibility — only on keyboard focus, same as admin */
body[data-area="marketing"] .platforma-skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--platforma-ink-strong, #111827);
    color: #fff;
    padding: 0.5rem 1rem;
    z-index: 1000;
}

body[data-area="marketing"] .platforma-skip-link:focus {
    left: 8px;
    top: 8px;
}

/* ════════════════════════════════════════════════════════════════════
   Top navigation
   ════════════════════════════════════════════════════════════════════ */
.platforma-marketing-nav {
    position: sticky;
    top: 0;
    z-index: var(--platforma-z-sticky, 100);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: saturate(180%) blur(12px);
    -webkit-backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.08));
}

.platforma-marketing-nav__inner {
    max-width: var(--platforma-frame-default, 1180px);
    margin: 0 auto;
    padding: 0.875rem clamp(1rem, 3vw, 2rem);
    display: flex;
    align-items: center;
    gap: clamp(1rem, 3vw, 2.5rem);
}

.platforma-marketing-nav__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    color: var(--platforma-ink-strong, #111827) !important;
    font-weight: 700;
    font-size: 1.0625rem;
    letter-spacing: -0.01em;
    text-decoration: none !important;
}

.platforma-marketing-nav__brand-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--platforma-page-banner-platform);
    color: #fff;
    font-weight: 800;
    letter-spacing: -0.04em;
    font-size: 1rem;
}

.platforma-marketing-nav__brand-name {
    line-height: 1;
}

.platforma-marketing-nav__links {
    display: flex;
    gap: clamp(1rem, 2.5vw, 2rem);
    margin-left: auto;
}

.platforma-marketing-nav__link {
    color: var(--platforma-ink-muted, #4b5563) !important;
    font-weight: 500;
    font-size: 0.9375rem;
    padding: 0.375rem 0;
    text-decoration: none !important;
    border-bottom: 2px solid transparent;
    transition: color 120ms ease, border-color 120ms ease;
}

.platforma-marketing-nav__link:hover,
.platforma-marketing-nav__link.is-active {
    color: var(--platforma-ink-strong, #111827) !important;
    border-bottom-color: var(--platforma-brand, #D4213D);
}

.platforma-marketing-nav__cta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* ─── FASE 9.A — Hamburger toggle (visible on <768px only) ────────── */
.platforma-marketing-nav__hamburger {
    display: none;  /* shown only on <768px via @media below */
    flex-direction: column;
    justify-content: center;
    gap: 4px;
    width: 40px;
    height: 40px;
    padding: 0;
    margin-left: auto;
    background: transparent;
    border: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.12));
    border-radius: 8px;
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease;
}

.platforma-marketing-nav__hamburger:hover,
.platforma-marketing-nav__hamburger:focus-visible {
    background: var(--platforma-gray-50, #f9fafb);
    outline: none;
}

.platforma-marketing-nav__hamburger:focus-visible {
    border-color: var(--platforma-brand, #D4213D);
    box-shadow: 0 0 0 3px rgba(212, 33, 61, 0.18);
}

.platforma-marketing-nav__hamburger-bar {
    display: block;
    width: 18px;
    height: 2px;
    background: var(--platforma-ink-strong, #111827);
    margin: 0 auto;
    border-radius: 2px;
    transition: transform 180ms ease, opacity 120ms ease;
}

/* Animate to "X" when expanded */
.platforma-marketing-nav__hamburger[aria-expanded="true"] .platforma-marketing-nav__hamburger-bar:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}
.platforma-marketing-nav__hamburger[aria-expanded="true"] .platforma-marketing-nav__hamburger-bar:nth-child(2) {
    opacity: 0;
}
.platforma-marketing-nav__hamburger[aria-expanded="true"] .platforma-marketing-nav__hamburger-bar:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

/* ─── FASE 9.A — Mobile drawer (slide-down panel under nav) ───────── */
.platforma-marketing-nav__drawer {
    display: none;  /* hidden by default + on desktop */
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: saturate(180%) blur(12px);
    -webkit-backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.08));
    box-shadow: 0 12px 32px -16px rgba(0, 0, 0, 0.18);
    padding: 1rem clamp(1rem, 3vw, 2rem) 1.5rem;
    max-height: calc(100vh - 64px);
    overflow-y: auto;
}

/* FASE 18.A — Backdrop scrim behind mobile drawer */
.platforma-marketing-nav__scrim {
    display: none;  /* shown only on <768px when drawer open */
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.42);
    z-index: var(--platforma-z-modal, 200);
    opacity: 0;
    transition: opacity 200ms ease;
    cursor: pointer;
}

.platforma-marketing-nav__scrim[data-open="true"] {
    opacity: 1;
}

.platforma-marketing-nav__drawer-nav {
    display: flex;
    flex-direction: column;
}

.platforma-marketing-nav__drawer-link {
    display: block;
    padding: 0.875rem 0.25rem;
    color: var(--platforma-ink-strong, #111827) !important;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none !important;
    border-bottom: 1px solid var(--platforma-gray-100, #f3f4f6);
}

.platforma-marketing-nav__drawer-link:last-child {
    border-bottom: none;
}

.platforma-marketing-nav__drawer-link.is-active {
    color: var(--platforma-brand, #D4213D) !important;
}

.platforma-marketing-nav__drawer-link:focus-visible {
    outline: 2px solid var(--platforma-brand, #D4213D);
    outline-offset: 2px;
    border-radius: 4px;
}

.platforma-marketing-nav__drawer-cta {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.08));
}

/* ─── Responsive nav: <768px collapses links + reveals hamburger ──── */
@media (max-width: 768px) {
    .platforma-marketing-nav__links {
        display: none;
    }
    .platforma-marketing-nav__cta {
        display: none;
    }
    .platforma-marketing-nav__hamburger {
        display: flex;
    }
    .platforma-marketing-nav__drawer[data-open="true"] {
        display: block;
    }
    /* FASE 18.A — scrim only relevant on mobile breakpoint */
    .platforma-marketing-nav__scrim[data-open="true"] {
        display: block;
    }
}

/* ════════════════════════════════════════════════════════════════════
   Buttons (marketing-only — admin uses platforma-buttons.css)
   ════════════════════════════════════════════════════════════════════ */
body[data-area="marketing"] .platforma-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.625rem 1.125rem;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.9375rem;
    line-height: 1.2;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease,
                border-color 120ms ease, box-shadow 120ms ease;
    white-space: nowrap;
    text-decoration: none !important;
}

body[data-area="marketing"] .platforma-btn-primary {
    background: var(--platforma-brand, #D4213D);
    color: #fff !important;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.15) inset,
                0 6px 18px -8px rgba(212, 33, 61, 0.45);
}

body[data-area="marketing"] .platforma-btn-primary:hover {
    background: var(--platforma-brand-pressed, #B81830);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset,
                0 8px 22px -8px rgba(212, 33, 61, 0.55);
}

body[data-area="marketing"] .platforma-btn-ghost {
    background: transparent;
    color: var(--platforma-ink-strong, #111827) !important;
    border-color: var(--platforma-surface-line, rgba(0, 0, 0, 0.12));
}

body[data-area="marketing"] .platforma-btn-ghost:hover {
    background: var(--platforma-gray-50, #f9fafb);
}

body[data-area="marketing"] .platforma-btn-lg {
    padding: 0.875rem 1.5rem;
    font-size: 1rem;
    border-radius: 10px;
}

/* ════════════════════════════════════════════════════════════════════
   Hero — premium marketing landing block
   ════════════════════════════════════════════════════════════════════ */
.platforma-marketing-hero {
    position: relative;
    background: var(--platforma-page-banner-platform);
    color: #fff;
    overflow: hidden;
    isolation: isolate;
}

/* FASE 19.A — Variant overrides for CMS-rendered hero. The .platforma-marketing-hero
   default is the platform variant; variant classes swap the gradient
   so the same partial works for tenant/trust/warn/neutral surfaces. */
.platforma-marketing-hero--platform { background: var(--platforma-page-banner-platform); }
.platforma-marketing-hero--tenant   { background: var(--platforma-page-banner-tenant); }
.platforma-marketing-hero--trust    { background: var(--platforma-page-banner-trust); }
.platforma-marketing-hero--warn     { background: var(--platforma-page-banner-warn); }
.platforma-marketing-hero--neutral  { background: var(--platforma-page-banner-neutral); color: var(--platforma-ink-strong, #111827); }

/* CMS-rendered hero (FASE 19.A) works outside body[data-area="marketing"]
   too — when rendered inside a tenant-website page. Same selectors don't
   require the body-scope. The class --cms tags it for any future
   CMS-only treatments. */
.platforma-marketing-hero--cms {
    /* Same as base; placeholder class for future CMS-only tweaks. */
}

.platforma-marketing-hero::after {
    /* Subtle radial accent — premium feel without overwhelming the type. */
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(60% 80% at 80% 20%, rgba(255, 255, 255, 0.12), transparent 60%),
        radial-gradient(40% 60% at 10% 100%, rgba(0, 0, 0, 0.18), transparent 60%);
    pointer-events: none;
    z-index: -1;
}

.platforma-marketing-hero__inner {
    max-width: var(--platforma-frame-default, 1180px);
    margin: 0 auto;
    padding: clamp(3rem, 7vw, 5.5rem) clamp(1rem, 3vw, 2rem);
    display: grid;
    gap: clamp(1.25rem, 2.5vw, 2rem);
}

.platforma-marketing-hero__overline {
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    opacity: 0.85;
    margin: 0;
}

.platforma-marketing-hero__title {
    font-size: var(--platforma-text-display-1, clamp(2.25rem, 1.5rem + 3vw, 3.5rem));
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 0;
    max-width: 18ch;
}

.platforma-marketing-hero__subtitle {
    font-size: var(--platforma-text-body-lg, 1.125rem);
    line-height: 1.5;
    opacity: 0.92;
    margin: 0;
    max-width: 56ch;
}

.platforma-marketing-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.5rem;
}

.platforma-marketing-hero__actions .platforma-btn-primary {
    background: rgba(255, 255, 255, 0.95);
    color: var(--platforma-brand, #D4213D) !important;
    box-shadow: 0 6px 18px -8px rgba(0, 0, 0, 0.35);
}

.platforma-marketing-hero__actions .platforma-btn-primary:hover {
    background: #fff;
}

.platforma-marketing-hero__actions .platforma-btn-ghost {
    background: rgba(255, 255, 255, 0.12);
    color: #fff !important;
    border-color: rgba(255, 255, 255, 0.32);
}

.platforma-marketing-hero__actions .platforma-btn-ghost:hover {
    background: rgba(255, 255, 255, 0.22);
}

.platforma-marketing-hero__stats {
    display: flex;
    flex-wrap: wrap;
    gap: clamp(1.25rem, 4vw, 3rem);
    padding-top: clamp(1rem, 2vw, 1.5rem);
    border-top: 1px solid rgba(255, 255, 255, 0.18);
    margin-top: clamp(0.5rem, 2vw, 1rem);
}

.platforma-marketing-hero__stat-value {
    display: block;
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.platforma-marketing-hero__stat-label {
    display: block;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    opacity: 0.78;
    margin-top: 0.25rem;
}

/* ════════════════════════════════════════════════════════════════════
   Section / frame helpers (used inside marketing pages)
   ════════════════════════════════════════════════════════════════════ */
body[data-area="marketing"] .platforma-marketing-section {
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 3vw, 2rem);
}

body[data-area="marketing"] .platforma-marketing-frame {
    max-width: var(--platforma-frame-default, 1180px);
    margin: 0 auto;
}

body[data-area="marketing"] .platforma-marketing-frame--narrow {
    max-width: var(--platforma-frame-narrow, 720px);
}

/* ════════════════════════════════════════════════════════════════════
   Card grid (Features page, Pricing tiers)
   ════════════════════════════════════════════════════════════════════ */
body[data-area="marketing"] .platforma-marketing-grid {
    display: grid;
    gap: clamp(1rem, 2vw, 1.5rem);
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    margin-top: clamp(1.5rem, 3vw, 2.5rem);
}

body[data-area="marketing"] .platforma-card {
    background: var(--platforma-white, #fff);
    border: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.08));
    border-radius: 12px;
    padding: clamp(1.25rem, 2vw, 1.75rem);
    transition: transform 160ms ease, box-shadow 160ms ease;
}

body[data-area="marketing"] .platforma-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 40px -24px rgba(0, 0, 0, 0.18);
}

body[data-area="marketing"] .platforma-card h2,
body[data-area="marketing"] .platforma-card h3 {
    margin: 0 0 0.5rem;
    font-size: 1.0625rem;
    font-weight: 600;
    color: var(--platforma-ink-strong, #111827);
}

body[data-area="marketing"] .platforma-card ul {
    list-style: none;
    margin: 0.75rem 0 0;
    padding: 0;
    color: var(--platforma-ink-muted, #4b5563);
    font-size: 0.9375rem;
}

body[data-area="marketing"] .platforma-card li {
    padding: 0.375rem 0 0.375rem 1.25rem;
    position: relative;
}

body[data-area="marketing"] .platforma-card li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.6875rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--platforma-brand, #D4213D);
    opacity: 0.85;
}

/* ════════════════════════════════════════════════════════════════════
   CTA strip (mid-page conversion block)
   ════════════════════════════════════════════════════════════════════ */
body[data-area="marketing"] .platforma-marketing-cta {
    background: var(--platforma-gray-50, #f9fafb);
    border-top: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.06));
    border-bottom: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.06));
}

body[data-area="marketing"] .platforma-marketing-cta__inner {
    max-width: var(--platforma-frame-default, 1180px);
    margin: 0 auto;
    padding: clamp(2.5rem, 5vw, 4rem) clamp(1rem, 3vw, 2rem);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 1.5rem;
}

body[data-area="marketing"] .platforma-marketing-cta__title {
    font-size: var(--platforma-text-headline, clamp(1.5rem, 1rem + 1.5vw, 2rem));
    font-weight: 700;
    color: var(--platforma-ink-strong, #111827);
    margin: 0;
    max-width: 30ch;
}

/* ════════════════════════════════════════════════════════════════════
   Footer
   ════════════════════════════════════════════════════════════════════ */
.platforma-marketing-footer {
    background: var(--platforma-ink-strong, #111827);
    color: rgba(255, 255, 255, 0.78);
    margin-top: clamp(2rem, 4vw, 4rem);
}

.platforma-marketing-footer__cols {
    max-width: var(--platforma-frame-default, 1180px);
    margin: 0 auto;
    padding: clamp(2.5rem, 5vw, 4rem) clamp(1rem, 3vw, 2rem) 1.5rem;
    display: grid;
    gap: clamp(1.5rem, 3vw, 2.5rem);
    grid-template-columns: 1.4fr repeat(3, 1fr);
}

@media (max-width: 768px) {
    .platforma-marketing-footer__cols {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 480px) {
    .platforma-marketing-footer__cols {
        grid-template-columns: 1fr;
    }
}

.platforma-marketing-footer__title {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #fff;
    margin: 0 0 0.875rem;
}

.platforma-marketing-footer__lead,
.platforma-marketing-footer__meta {
    font-size: 0.875rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.68);
    margin: 0;
    max-width: 32ch;
}

/* FASE 18.B — Newsletter signup in footer */
.platforma-marketing-footer__newsletter {
    margin-top: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.platforma-marketing-footer__newsletter-label {
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.85);
}

.platforma-marketing-footer__newsletter-row {
    display: flex;
    gap: 0.375rem;
    flex-wrap: wrap;
}

.platforma-marketing-footer__newsletter-input {
    flex: 1 1 12rem;
    min-width: 0;
    padding: 0.5rem 0.75rem;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 6px;
    color: #fff;
    font-size: 0.875rem;
}

.platforma-marketing-footer__newsletter-input::placeholder {
    color: rgba(255, 255, 255, 0.45);
}

.platforma-marketing-footer__newsletter-input:focus {
    outline: 2px solid var(--platforma-brand, #D4213D);
    outline-offset: 1px;
    background: rgba(255, 255, 255, 0.12);
}

.platforma-marketing-footer__newsletter-btn {
    padding: 0.5rem 0.875rem;
    background: var(--platforma-brand, #D4213D);
    color: #fff;
    font-weight: 600;
    font-size: 0.875rem;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    white-space: nowrap;
    transition: background 120ms ease;
}

.platforma-marketing-footer__newsletter-btn:hover {
    background: var(--platforma-brand-pressed, #B81830);
}

.platforma-marketing-footer__newsletter-feedback {
    margin: 0.25rem 0 0;
    font-size: 0.8125rem;
    color: rgba(255, 255, 255, 0.85);
}

.platforma-marketing-footer__newsletter-feedback--ok {
    color: #86efac;
}

.platforma-marketing-footer__newsletter-feedback--err {
    color: #fca5a5;
}

.platforma-marketing-footer__links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.platforma-marketing-footer__links li {
    margin-bottom: 0.4rem;
}

.platforma-marketing-footer__links a {
    color: rgba(255, 255, 255, 0.78) !important;
    font-size: 0.875rem;
    text-decoration: none !important;
}

.platforma-marketing-footer__links a:hover {
    color: #fff !important;
    text-decoration: underline !important;
    text-underline-offset: 3px;
}

.platforma-marketing-footer__bar {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1rem clamp(1rem, 3vw, 2rem);
    max-width: var(--platforma-frame-default, 1180px);
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.75rem;
    color: rgba(255, 255, 255, 0.55);
    font-size: 0.8125rem;
}

.platforma-marketing-footer__bar a {
    color: rgba(255, 255, 255, 0.7) !important;
}

/* ════════════════════════════════════════════════════════════════════
   Pricing grid (specialised tier cards)
   ════════════════════════════════════════════════════════════════════ */
body[data-area="marketing"] .platforma-pricing-grid {
    display: grid;
    gap: clamp(1rem, 2vw, 1.5rem);
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    margin-top: clamp(1.5rem, 3vw, 2.5rem);
}

body[data-area="marketing"] .platforma-pricing-card {
    background: var(--platforma-white, #fff);
    border: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.08));
    border-radius: 14px;
    padding: clamp(1.5rem, 2.5vw, 2rem);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

body[data-area="marketing"] .platforma-pricing-card--featured {
    border-color: var(--platforma-brand, #D4213D);
    box-shadow: 0 16px 48px -24px rgba(212, 33, 61, 0.32);
    transform: translateY(-4px);
}

body[data-area="marketing"] .platforma-pricing-card__tier {
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--platforma-brand, #D4213D);
}

body[data-area="marketing"] .platforma-pricing-card__name {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--platforma-ink-strong, #111827);
    margin: 0;
}

body[data-area="marketing"] .platforma-pricing-card__price {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    color: var(--platforma-ink-strong, #111827);
    font-variant-numeric: tabular-nums;
}

body[data-area="marketing"] .platforma-pricing-card__price-period {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--platforma-ink-muted, #6b7280);
}

body[data-area="marketing"] .platforma-pricing-card__cta {
    margin-top: auto;
    padding-top: 0.75rem;
}

/* ════════════════════════════════════════════════════════════════════
   FASE 18.X — Premium trust badges (replaces emoji-based version)
   Pattern: rounded 48×48 brand-tinted icon tile + title + caption.
   Same convention as Stripe / Linear / Vercel / Anthropic.
   ════════════════════════════════════════════════════════════════════ */
.platforma-trust-badges {
    margin-top: clamp(2rem, 4vw, 3rem);
    padding: clamp(1.5rem, 3vw, 2.5rem) clamp(1rem, 2vw, 1.5rem);
    background: var(--platforma-gray-50, #f9fafb);
    border-radius: 12px;
}

.platforma-trust-badges__heading {
    text-align: center;
    margin: 0 0 clamp(1.25rem, 2.5vw, 2rem);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--platforma-ink-muted, #6b7280);
}

.platforma-trust-badges__grid {
    display: grid;
    gap: clamp(0.75rem, 1.5vw, 1.25rem);
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    max-width: var(--platforma-frame-default, 1180px);
    margin: 0 auto;
}

.platforma-trust-badge {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 1rem 1rem 1.125rem;
    background: var(--platforma-white, #fff);
    border: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.06));
    border-radius: 10px;
    text-decoration: none !important;
    color: var(--platforma-ink-strong, #111827);
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.platforma-trust-badge:not(.platforma-trust-badge--static):hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 24px -16px rgba(0, 0, 0, 0.18);
    border-color: var(--platforma-brand, #D4213D);
}

.platforma-trust-badge--static {
    cursor: default;
}

.platforma-trust-badge--pending {
    opacity: 0.72;
}

.platforma-trust-badge__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    flex-shrink: 0;
    /* SVGs inherit currentColor; we set color per variant below. */
}

.platforma-trust-badge__icon--brand {
    background: var(--platforma-brand-soft, #FBE7EA);
    color: var(--platforma-brand, #D4213D);
}

.platforma-trust-badge__icon--accent {
    background: rgba(46, 92, 138, 0.08);
    color: var(--platforma-accent, #2E5C8A);
}

.platforma-trust-badge__icon--success {
    background: rgba(5, 150, 105, 0.08);
    color: var(--platforma-success, #059669);
}

.platforma-trust-badge__icon--neutral {
    background: var(--platforma-gray-100, #f3f4f6);
    color: var(--platforma-gray-600, #4b5563);
}

.platforma-trust-badge__title {
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.3;
    color: var(--platforma-ink-strong, #111827);
}

.platforma-trust-badge__caption {
    font-size: 0.75rem;
    line-height: 1.4;
    color: var(--platforma-ink-muted, #6b7280);
}

.platforma-trust-badge__caption em {
    font-style: italic;
}

/* ════════════════════════════════════════════════════════════════════
   FASE 19.B — Value Pillars (3 cards med icon + title + body)
   ════════════════════════════════════════════════════════════════════ */
.platforma-value-pillars__card {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.platforma-value-pillars__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--platforma-brand-soft, #FBE7EA);
    color: var(--platforma-brand, #D4213D);
    margin-bottom: 0.25rem;
}

/* ════════════════════════════════════════════════════════════════════
   FASE 19.C — How It Works (3-step numbered cards)
   ════════════════════════════════════════════════════════════════════ */
.platforma-how-it-works__step {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.platforma-how-it-works__number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: var(--platforma-page-banner-platform);
    color: #fff;
    font-weight: 700;
    margin-bottom: 0.25rem;
    font-size: 0.9375rem;
}

/* ════════════════════════════════════════════════════════════════════
   FASE 19.I — FAQ Accordion (native <details> styling)
   ════════════════════════════════════════════════════════════════════ */
.platforma-faq-accordion__item {
    background: var(--platforma-white, #fff);
    border: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.08));
    border-radius: 10px;
    transition: border-color 160ms ease;
}
.platforma-faq-accordion__item[open] {
    border-color: var(--platforma-brand, #D4213D);
}
.platforma-faq-accordion__question {
    cursor: pointer;
    padding: 1rem 1.25rem;
    font-weight: 600;
    font-size: 1rem;
    color: var(--platforma-ink-strong, #111827);
    list-style: none;
    position: relative;
    padding-right: 2.5rem;
}
.platforma-faq-accordion__question::-webkit-details-marker { display: none; }
.platforma-faq-accordion__question::after {
    content: "+";
    position: absolute;
    right: 1.25rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.5rem;
    line-height: 1;
    color: var(--platforma-brand, #D4213D);
    transition: transform 160ms ease;
}
.platforma-faq-accordion__item[open] .platforma-faq-accordion__question::after {
    content: "−";
}
.platforma-faq-accordion__answer {
    padding: 0 1.25rem 1.125rem;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--platforma-ink-muted, #4b5563);
}
.platforma-faq-accordion__question:focus-visible {
    outline: 2px solid var(--platforma-brand, #D4213D);
    outline-offset: 2px;
    border-radius: 8px;
}

/* ════════════════════════════════════════════════════════════════════
   FASE 19.J — Image Gallery (lightbox-trigger tiles)
   ════════════════════════════════════════════════════════════════════ */
.platforma-image-gallery__tile {
    transition: transform 160ms ease, box-shadow 160ms ease;
}
.platforma-image-gallery__tile:hover {
    transform: scale(1.02);
    box-shadow: 0 12px 24px -16px rgba(0, 0, 0, 0.18);
}
.platforma-image-gallery__tile:focus-visible {
    outline: 3px solid var(--platforma-brand, #D4213D);
    outline-offset: 2px;
}
.platforma-image-gallery__lightbox::backdrop {
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(8px);
}

/* ════════════════════════════════════════════════════════════════════
   FASE 19.N — Bento-grid (Apple-style asymmetric tile grid)
   ════════════════════════════════════════════════════════════════════ */
.platforma-bento-grid__layout {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: minmax(180px, auto);
    gap: 0.75rem;
}
.platforma-bento-grid__tile--small  { grid-column: span 1; }
.platforma-bento-grid__tile--medium { grid-column: span 2; }
.platforma-bento-grid__tile--large  { grid-column: span 2; grid-row: span 2; }
@media (max-width: 768px) {
    .platforma-bento-grid__layout { grid-template-columns: 1fr; }
    .platforma-bento-grid__tile--small,
    .platforma-bento-grid__tile--medium,
    .platforma-bento-grid__tile--large { grid-column: span 1; grid-row: span 1; }
}

/* ════════════════════════════════════════════════════════════════════
   FASE 19.P — Tabs (active state + role=tablist styling)
   ════════════════════════════════════════════════════════════════════ */
.platforma-tabs__list {
    display: flex;
    gap: 0.25rem;
    border-bottom: 1px solid var(--platforma-surface-line, rgba(0,0,0,0.08));
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}
.platforma-tabs__tab {
    background: transparent;
    border: none;
    padding: 0.75rem 1.25rem;
    font-weight: 600;
    color: var(--platforma-ink-muted, #6b7280);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color 120ms ease, border-color 120ms ease;
}
.platforma-tabs__tab:hover { color: var(--platforma-ink-strong, #111827); }
.platforma-tabs__tab.is-active {
    color: var(--platforma-brand, #D4213D);
    border-bottom-color: var(--platforma-brand, #D4213D);
}

/* ════════════════════════════════════════════════════════════════════
   FASE 19.AA — Parallax: disable på mobile + reduced-motion (a11y + perf)
   ════════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .platforma-parallax-image { background-attachment: scroll !important; }
}
@media (prefers-reduced-motion: reduce) {
    .platforma-parallax-image { background-attachment: scroll !important; }
}

/* Visually-hidden helper (used by newsletter section) */
.platforma-visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ════════════════════════════════════════════════════════════════════
   FASE 18.D — Case study card meta strip
   ════════════════════════════════════════════════════════════════════ */
body[data-area="marketing"] .platforma-case-study-card {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

body[data-area="marketing"] .platforma-case-study-card__meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* ════════════════════════════════════════════════════════════════════
   FASE 18.C — Testimonial cards (3-column grid, neutral background)
   ════════════════════════════════════════════════════════════════════ */
body[data-area="marketing"] .platforma-testimonial-grid {
    display: grid;
    gap: clamp(1rem, 2vw, 1.5rem);
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    margin-top: clamp(1.5rem, 3vw, 2.5rem);
}

body[data-area="marketing"] .platforma-testimonial {
    margin: 0;
    background: var(--platforma-white, #fff);
    border: 1px solid var(--platforma-surface-line, rgba(0, 0, 0, 0.08));
    border-radius: 12px;
    padding: clamp(1.25rem, 2vw, 1.75rem);
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: relative;
}

body[data-area="marketing"] .platforma-testimonial::before {
    /* Subtle " before the quote — typographic flourish, decoration only. */
    content: "“";
    position: absolute;
    top: 0.25rem;
    left: 0.875rem;
    font-size: 3rem;
    line-height: 1;
    color: var(--platforma-brand, #D4213D);
    opacity: 0.18;
    font-family: Georgia, serif;
    pointer-events: none;
}

body[data-area="marketing"] .platforma-testimonial__quote {
    margin: 0;
    font-size: 1rem;
    line-height: 1.6;
    color: var(--platforma-ink-strong, #111827);
    font-style: normal;
    quotes: none;
}

body[data-area="marketing"] .platforma-testimonial__cite {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
    font-style: normal;
    margin-top: auto;
    padding-top: 0.5rem;
    border-top: 1px solid var(--platforma-gray-100, #f3f4f6);
}

body[data-area="marketing"] .platforma-testimonial__name {
    font-weight: 700;
    color: var(--platforma-ink-strong, #111827);
    font-size: 0.9375rem;
}

body[data-area="marketing"] .platforma-testimonial__role {
    font-size: 0.8125rem;
    color: var(--platforma-ink-muted, #6b7280);
}

/* ════════════════════════════════════════════════════════════════════
   FASE 17.C — Customer logos / social proof strip
   ════════════════════════════════════════════════════════════════════ */
body[data-area="marketing"] .platforma-customer-logos {
    display: flex;
    flex-wrap: wrap;
    gap: clamp(1rem, 3vw, 2.5rem);
    justify-content: center;
    align-items: center;
    margin-top: clamp(1rem, 2vw, 1.5rem);
}

body[data-area="marketing"] .platforma-customer-logo {
    display: inline-flex;
    align-items: center;
    height: 32px;
    padding: 0 1rem;
    color: var(--platforma-gray-500, #6b7280);
    font-weight: 600;
    font-size: 0.9375rem;
    letter-spacing: -0.005em;
    opacity: 0.78;
    transition: opacity 160ms ease, color 160ms ease;
    border-left: 1px solid var(--platforma-gray-200, #e5e7eb);
}

body[data-area="marketing"] .platforma-customer-logo:first-child {
    border-left: none;
    padding-left: 0;
}

body[data-area="marketing"] .platforma-customer-logo:hover {
    color: var(--platforma-ink-strong, #111827);
    opacity: 1;
}

@media (max-width: 768px) {
    body[data-area="marketing"] .platforma-customer-logo {
        border-left: none;
        padding: 0 0.5rem;
    }
}

/* ====================================================================
   FASE 18/19 component baseline shells — 2026-05-12
   ====================================================================
   These rules satisfy FormClassConsistencyTests by declaring the
   wrapper/section/element classes that the corresponding Razor
   sections render. Most components inherit their visual treatment
   from the parent `.platforma-marketing-section` and `.platforma-marketing-frame`
   classes; these rules add semantic markers so the design-system
   drift-guard ratchet stays tight. A future slice can replace these
   shells with full visual styling per component.

   Group key:
   - Sections (`.platforma-X-section` / `.platforma-X`):           outer wrappers
   - BEM elements (`.platforma-X__Y`):                            inner parts
   - Status/utility tokens:                                       row-level helpers
   ==================================================================== */

/* Section wrappers — outer <section> markers on marketing CMS blocks */
.platforma-animated-svg,
.platforma-before-after-slider,
.platforma-bento-grid,
.platforma-card-grid-cta,
.platforma-case-study-card-grid,
.platforma-chat-widget-embed,
.platforma-comparison-table,
.platforma-contact-channel-card,
.platforma-contact-channels-section,
.platforma-countdown-timer,
.platforma-cta-strip,
.platforma-customer-logos-section,
.platforma-download-vault,
.platforma-embedded-form,
.platforma-faq-accordion,
.platforma-feature-comparison,
.platforma-forum-feed,
.platforma-how-it-works,
.platforma-image-carousel,
.platforma-image-gallery-section,
.platforma-instagram-grid,
.platforma-interactive-map,
.platforma-live-stream-embed,
.platforma-marketplace-tiles,
.platforma-newsletter-section-form,
.platforma-newsletter-signup-section,
.platforma-pricing-calculator,
.platforma-pricing-tiers-section,
.platforma-quote-single,
.platforma-roadmap-timeline,
.platforma-roi-calculator,
.platforma-seed-options,
.platforma-signup-progress,
.platforma-social-feed-embed,
.platforma-stats-counter,
.platforma-team-card,
.platforma-team-grid-marketing,
.platforma-testimonial-grid-section,
.platforma-trust-badges-section,
.platforma-value-pillars,
.platforma-video-hero,
.platforma-webinar-signup {
    display: block;
    position: relative;
}

/* BEM elements — inner pieces (grids, tracks, dots, cards, etc.) */
.platforma-animated-svg__svg,
.platforma-before-after-slider__before,
.platforma-before-after-slider__compare,
.platforma-before-after-slider__handle,
.platforma-bento-grid__tile,
.platforma-case-study-card-grid__card,
.platforma-comparison-table__grid,
.platforma-embedded-form__form,
.platforma-faq-accordion__list,
.platforma-feature-comparison__scroll,
.platforma-feature-comparison__table,
.platforma-how-it-works__grid,
.platforma-image-carousel__dots,
.platforma-image-carousel__slide,
.platforma-image-carousel__track,
.platforma-image-carousel__viewport,
.platforma-image-gallery__grid,
.platforma-marketing-footer__col,
.platforma-roadmap-timeline__item,
.platforma-roadmap-timeline__list,
.platforma-signup-progress__content,
.platforma-signup-progress__stepper,
.platforma-stats-counter__grid,
.platforma-stats-counter__value,
.platforma-tabs__container,
.platforma-tabs__panel,
.platforma-value-pillars__grid,
.platforma-video-hero__bg {
    display: block;
}

/* Utility / state tokens used across marketing + admin chrome */
.platforma-page          { display: block; }
.platforma-error         { color: var(--platforma-danger, #991b1b); }
.platforma-text-danger   { color: var(--platforma-danger, #991b1b); }
.platforma-row-warning   { background: var(--platforma-warning-soft, #fef3c7); }
.platforma-help-body     { color: var(--platforma-muted, #6b7280); }
.platforma-help-list     { padding-left: 1.25rem; }
.platforma-btn-small     { padding: 0.25rem 0.5rem; font-size: 0.875rem; }
.platforma-btn-warning   { background: var(--platforma-warning, #92400e); color: #fff; }
