/* ==========================================================================
   melissamreid.ca — site.css
   Design tokens, base typography, layout primitives. No page-specific styles.
   Mobile-first; tablet/desktop expansions at 768px.
   ========================================================================== */

:root {
    /* Brand colors — sampled from /assets/images/melissa-reid-card.jpg */
    --color-primary: #063A7C;       /* Deep navy: headlines, borders, primary buttons */
    --color-secondary: #063A7C;     /* Same as primary; card uses one ink. Hierarchy from weight/size/style, not hue. Do not diverge. */
    --color-primary-deep: #042556;  /* ~30% darker navy; same hue family. Hover/active for primary buttons. */
    /* Single-ink interactive-state rule: hover/active/current must NOT shift hue.
       Carry state via underline, weight, or a darker shade of the same hue family.
         Nav + footer links: underline appears on :hover / :focus-visible.
         Active page link:   weight 600 + always-on underline.
         Primary button:     background shifts to --color-primary-deep on :hover/:focus/:active; text stays #FFFFFF.
       Future tokens that name a "secondary" or "accent" hue should be reviewed against this rule. */
    --color-text: #2A2A2A;
    --color-text-muted: #666666;
    --color-bg: #FFFFFF;
    --color-bg-alt: #F8F9FB;
    --color-divider: #D0D5DC;

    /* Typography */
    --font-sans: 'Outfit', system-ui, sans-serif;
    --font-serif: 'DM Serif Display', Georgia, serif;
    --fs-xs: 0.875rem;
    --fs-sm: 1rem;
    --fs-base: 1.0625rem;           /* 17px body */
    --fs-lg: 1.25rem;
    --fs-xl: clamp(1.5rem, 4vw, 2rem);     /* H3 */
    --fs-2xl: clamp(2rem, 5vw, 2.75rem);   /* H2 */
    --fs-3xl: clamp(2.5rem, 7vw, 4rem);    /* H1 */

    /* Spacing scale */
    --space-1: 0.5rem;
    --space-2: 1rem;
    --space-3: 1.5rem;
    --space-4: 2rem;
    --space-6: 3rem;
    --space-8: 4rem;
    --space-12: 6rem;

    /* Layout */
    --content-max: 68ch;
    --container-max: 1200px;
    --radius-sm: 4px;
    --radius-md: 8px;
}

/* --- Reset / base --------------------------------------------------------- */

*, *::before, *::after { box-sizing: border-box; }

html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--fs-base);
    line-height: 1.65;
    color: var(--color-text);
    background: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img, svg { max-width: 100%; height: auto; display: block; }

a {
    color: var(--color-secondary);
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
}
a:hover, a:focus-visible {
    color: var(--color-primary);
}

:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

hr {
    border: 0;
    border-top: 1px solid var(--color-divider);
    margin: var(--space-6) 0;
}

/* --- Typography ----------------------------------------------------------- */

h1, h2, h3, h4 {
    font-family: var(--font-sans);
    color: var(--color-primary);
    line-height: 1.15;
    margin: 0 0 var(--space-3);
}

h1 {
    font-weight: 700;
    font-size: var(--fs-3xl);
    letter-spacing: -0.01em;
}

h2 {
    font-weight: 600;
    font-size: var(--fs-2xl);
    margin-top: var(--space-8);
}

h3 {
    font-weight: 600;
    font-size: var(--fs-xl);
    color: var(--color-secondary);
    margin-top: var(--space-6);
}

p { margin: 0 0 var(--space-3); }

strong { font-weight: 600; color: var(--color-primary); }
em { font-style: italic; }

/* Subtitle / tagline — DM Serif Display italic, navy (single-ink), mid-size. */
.subtitle,
.tagline {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--color-secondary);
    font-size: clamp(1.25rem, 2.5vw, 1.6rem);
    line-height: 1.35;
    margin: 0 0 var(--space-4);
}

/* H2 immediately after H1 acts as a serif-italic page subtitle (markdown
   convention: `# Title` followed by `## Subtitle`). Same treatment as
   .subtitle / .tagline, but applied automatically so prose authors can write
   plain markdown without classes. Subsequent H2s keep the default section-
   header treatment. */
h1 + h2,
.prose h1 + h2 {
    font-family: var(--font-serif);
    font-style: italic;
    font-weight: 400;
    color: var(--color-primary);
    font-size: clamp(1.25rem, 2.5vw, 1.6rem);
    line-height: 1.35;
    margin-top: 0;
    margin-bottom: var(--space-4);
}

/* Pull quote — story-page centerpiece. Oversized serif italic, teal-blue, indented. */
.prose blockquote,
blockquote.pullquote {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--color-secondary);
    font-size: clamp(1.5rem, 3.5vw, 2.25rem);
    line-height: 1.3;
    margin: var(--space-6) 0;
    padding: 0 0 0 var(--space-4);
    border-left: 3px solid var(--color-secondary);
}
.prose blockquote p { margin: 0 0 var(--space-2); }
.prose blockquote p:last-child { margin-bottom: 0; }

/* Long-form prose container */
.prose {
    max-width: var(--content-max);
    margin-left: auto;
    margin-right: auto;
}
.prose ul, .prose ol { padding-left: 1.25em; margin: 0 0 var(--space-3); }
.prose li { margin-bottom: var(--space-1); }
.prose li::marker { color: var(--color-secondary); }
.prose a { color: var(--color-secondary); }

/* --- Layout primitives ---------------------------------------------------- */

.container {
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--space-3);
}

.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--color-primary);
    color: #fff;
    padding: var(--space-1) var(--space-2);
    z-index: 1000;
}
.skip-link:focus {
    left: var(--space-2);
    top: var(--space-2);
}

/* --- Site header / nav ---------------------------------------------------- */

.site-header {
    border-bottom: 1px solid var(--color-divider);
    background: var(--color-bg);
    position: relative;
}

.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding-top: var(--space-3);
    padding-bottom: var(--space-3);
}

.site-header__brand {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--color-primary);
    line-height: 1.1;
}
.site-header__brand-name {
    font-weight: 700;
    font-size: 1.25rem;
    letter-spacing: -0.005em;
}
.site-header__brand-sub {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--color-secondary);
    font-size: 0.95rem;
    margin-top: 0.15rem;
}

.nav-toggle {
    display: inline-flex;
    flex-direction: column;
    justify-content: space-between;
    width: 2.25rem;
    height: 1.6rem;
    padding: 0;
    background: transparent;
    border: 0;
    cursor: pointer;
}
.nav-toggle__bar {
    display: block;
    height: 2px;
    width: 100%;
    background: var(--color-primary);
    border-radius: 1px;
}

.primary-nav {
    display: none;
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-divider);
    box-shadow: 0 8px 16px -12px rgba(26, 58, 126, 0.25);
    padding: var(--space-2) var(--space-3) var(--space-3);
    z-index: 50;
}
.primary-nav.is-open { display: block; }

.primary-nav__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.primary-nav__item {
    border-bottom: 1px solid var(--color-divider);
}
.primary-nav__item:last-child { border-bottom: 0; }

.primary-nav__link {
    display: block;
    padding: var(--space-2) 0;
    font-weight: 500;
    color: var(--color-primary);
    text-decoration: none;
}
.primary-nav__link.is-current {
    font-weight: 600;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}
.primary-nav__link:hover,
.primary-nav__link:focus-visible {
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

/* --- Main / footer -------------------------------------------------------- */

.site-main {
    padding: var(--space-6) 0 var(--space-8);
}

.site-footer {
    border-top: 1px solid var(--color-divider);
    background: var(--color-bg-alt);
    padding: var(--space-6) 0;
    margin-top: var(--space-8);
    color: var(--color-text-muted);
    font-size: var(--fs-xs);
}
.site-footer__inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}
.site-footer__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-3);
}
.site-footer__list a { color: var(--color-primary); text-decoration: none; }
.site-footer a:hover,
.site-footer a:focus-visible {
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}
.site-footer__contact { margin: 0 0 var(--space-1); }
.site-footer__copy { margin: 0; max-width: 70ch; }

/* --- Buttons -------------------------------------------------------------- */

.btn {
    display: inline-block;
    font-family: var(--font-sans);
    font-weight: 500;
    font-size: var(--fs-base);
    line-height: 1.2;
    padding: 0.85em 1.4em;
    border-radius: var(--radius-sm);
    border: 1px solid transparent;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 120ms ease, color 120ms ease, border-color 120ms ease;
}
.btn--primary,
.btn--primary:link,
.btn--primary:visited {
    background: var(--color-primary);
    color: #FFFFFF;
    border-color: var(--color-primary);
}
.btn--primary:hover,
.btn--primary:focus-visible,
.btn--primary:active {
    background: var(--color-primary-deep);
    border-color: var(--color-primary-deep);
    color: #FFFFFF;
}
.btn--secondary,
.btn--secondary:link,
.btn--secondary:visited {
    background: transparent;
    color: var(--color-primary);
    border-color: var(--color-primary);
}
.btn--secondary:hover,
.btn--secondary:focus-visible,
.btn--secondary:active {
    background: var(--color-primary);
    color: #FFFFFF;
}

/* --- Placeholder slot (interim platform copy) ----------------------------- */

/* Whole-paragraph bracketed copy is post-processed in markdown.php to receive
   .placeholder-slot. Reads as visibly quieter than real prose so a reader does
   not mistake an interim slot for a hedged position. */
.placeholder-slot,
.prose p.placeholder-slot {
    color: var(--color-text-muted);
    font-style: italic;
    border-left: 2px solid var(--color-divider);
    padding-left: var(--space-3);
    margin-left: 0;
}

/* --- Platform page -------------------------------------------------------- */

.platform-stack {
    padding-top: var(--space-3);
    padding-bottom: var(--space-3);
}

@media (max-width: 768px) {
    /* Platform copy is denser; give it a touch more side breathing room on phones. */
    .page-platform .platform-stack {
        padding-left: var(--space-4);
        padding-right: var(--space-4);
    }
}
.platform-pillar { scroll-margin-top: var(--space-3); }
.platform-pillar + .platform-pillar {
    margin-top: var(--space-8);
    padding-top: var(--space-8);
    border-top: 1px solid var(--color-divider);
}

/* --- Homepage sections ---------------------------------------------------- */

/* Reset .site-main vertical padding for the homepage; sections own their rhythm. */
.page-home .site-main { padding: 0; }

/* Hero band ------------------------------------------------------------- */
.hero {
    padding: var(--space-6) 0 var(--space-8);
    border-bottom: 1px solid var(--color-divider);
}
.hero__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
    align-items: center;
}
.hero__media img {
    width: 100%;
    max-width: 520px;
    height: auto;
    margin: 0 auto;
    border-radius: var(--radius-md);
}
.hero__badge {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: var(--fs-xs);
    font-weight: 600;
    color: var(--color-primary);
    margin: 0 0 var(--space-2);
}
.hero__content h1 { margin-bottom: var(--space-2); }
.hero__intro {
    font-size: var(--fs-lg);
    line-height: 1.55;
    max-width: 60ch;
    margin: var(--space-3) 0 var(--space-4);
}
.hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

/* Pillars band ---------------------------------------------------------- */
.pillars {
    padding: var(--space-8) 0;
    background: var(--color-bg);
}
.pillars__intro {
    text-align: center;
    color: var(--color-primary);
    max-width: 60ch;
    margin: 0 auto var(--space-6);
    font-size: var(--fs-base);
}
.pillars__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-3);
}
.pillars__item { display: flex; }
.pillar {
    display: block;
    width: 100%;
    background: var(--color-bg);
    border: 1px solid var(--color-divider);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    text-decoration: none;
    color: inherit;
    transition: background-color 120ms ease, border-color 120ms ease;
}
.pillar:hover,
.pillar:focus-visible {
    background: var(--color-bg-alt);
    border-color: var(--color-primary);
}
.pillar__bullet {
    display: inline-block;
    width: 0.4rem;
    height: 0.4rem;
    background: var(--color-primary);
    border-radius: 50%;
    margin-right: var(--space-1);
    vertical-align: 0.3em;
}
.pillar__title {
    display: inline;
    font-family: var(--font-sans);
    font-weight: 600;
    color: var(--color-primary);
    font-size: var(--fs-xl);
    margin: 0;
    line-height: 1.25;
}
.pillar__summary {
    margin: var(--space-2) 0 0;
    color: var(--color-text);
    font-size: var(--fs-base);
    line-height: 1.55;
}

/* Preview bands (story / lineage) -------------------------------------- */
.preview-band {
    padding: var(--space-8) 0;
    border-top: 1px solid var(--color-divider);
}
.preview-band--alt {
    background: var(--color-bg-alt);
    border-top-color: transparent;
}
.preview-band__inner {
    max-width: 80ch;
    text-align: left;
    margin-left: auto;
    margin-right: auto;
}
.preview-band__label {
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: var(--fs-xs);
    font-weight: 600;
    color: var(--color-primary);
    margin: 0 0 var(--space-2);
}
.preview-band__pull {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--color-primary);
    font-size: clamp(1.4rem, 3vw, 1.9rem);
    line-height: 1.35;
    margin: 0 0 var(--space-3);
}
.preview-band__cta { margin: 0; }
.preview-band__cta a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 500;
}
.preview-band__cta a:hover,
.preview-band__cta a:focus-visible {
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

/* Closing CTA band ----------------------------------------------------- */
.closing-cta {
    padding: var(--space-8) 0 var(--space-12);
    text-align: center;
    border-top: 1px solid var(--color-divider);
}
.closing-cta__inner {
    max-width: 60ch;
}
.closing-cta__headline {
    font-family: var(--font-sans);
    font-weight: 700;
    color: var(--color-primary);
    font-size: clamp(2.25rem, 5.5vw, 3.25rem);
    line-height: 1.1;
    margin: 0 0 var(--space-3);
}
.closing-cta__body {
    font-family: var(--font-serif);
    font-style: italic;
    color: var(--color-primary);
    font-size: clamp(1.25rem, 2.5vw, 1.6rem);
    line-height: 1.4;
    margin: 0 0 var(--space-4);
}
.closing-cta__action { margin: 0; }

/* --- Tablet/desktop ------------------------------------------------------- */

@media (min-width: 768px) {
    .site-header__inner {
        padding-top: var(--space-4);
        padding-bottom: var(--space-4);
    }
    .site-header__brand-name { font-size: 1.4rem; }

    .nav-toggle { display: none; }

    .primary-nav {
        display: block;
        position: static;
        background: transparent;
        border-bottom: 0;
        box-shadow: none;
        padding: 0;
    }
    .primary-nav__list {
        flex-direction: row;
        gap: var(--space-4);
    }
    .primary-nav__item { border-bottom: 0; }
    .primary-nav__link { padding: 0; }

    .site-main { padding: var(--space-8) 0 var(--space-12); }

    .site-footer__inner {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-start;
        gap: var(--space-6);
    }
    .site-footer__meta { text-align: right; }
    .site-footer__list { justify-content: flex-start; }

    /* Hero: photo dominant on left, text on right (card proportions) */
    .hero { padding: var(--space-12) 0; }
    .hero__inner {
        grid-template-columns: 5fr 7fr;
        gap: var(--space-8);
    }
    .hero__media img { max-width: 100%; }

    /* Pillars: three-column grid */
    .pillars { padding: var(--space-12) 0; }
    .pillars__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-4);
    }

    /* Preview / closing bands */
    .preview-band { padding: var(--space-12) 0; }
    .preview-band__inner { margin-left: auto; margin-right: auto; }
    .closing-cta { padding: var(--space-12) 0; }
    .closing-cta__inner { margin: 0 auto; }
}

/* Contact form (single ink, card-faithful) */
.contact-form {
    max-width: 32rem;
    margin: 0;
}
.contact-form .form-field {
    margin-bottom: var(--space-3);
}
.contact-form label {
    display: block;
    font-weight: 600;
    color: var(--color-primary);
    margin-bottom: var(--space-1);
    font-size: var(--fs-sm);
}
.form-field__hint {
    font-weight: 400;
    color: var(--color-text-muted);
    font-style: italic;
    font-size: var(--fs-xs);
}
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form select,
.contact-form textarea {
    width: 100%;
    padding: 0.6rem 0.8rem;
    border: 1px solid var(--color-divider);
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: var(--fs-base);
    color: var(--color-text);
    background: var(--color-bg);
    box-sizing: border-box;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: 1px;
    border-color: var(--color-primary);
}
.contact-form textarea {
    resize: vertical;
    min-height: 8rem;
}
.contact-form button[type="submit"] {
    margin-top: var(--space-2);
}
.form-error {
    background: #FFF7E0;
    color: #7A5A00;
    border-left: 3px solid #C9A227;
    padding: var(--space-3);
    margin-bottom: var(--space-3);
    border-radius: var(--radius-sm);
}
.form-success {
    background: var(--color-bg-alt);
    border-left: 3px solid var(--color-primary);
    padding: var(--space-4);
    margin: var(--space-8) 0;
    border-radius: var(--radius-sm);
}
.form-success h2 {
    margin-top: 0;
    color: var(--color-primary);
}

.contact-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 2.5rem;
    align-items: start;
    margin-top: 2rem;
}

.contact-layout__photo img {
    display: block;
    width: 100%;
    max-width: 220px;
    height: auto;
    border-radius: 8px;
}

@media (max-width: 768px) {
    .contact-layout {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }
    .contact-layout__photo img {
        max-width: 180px;
    }
}

/* Story inline thumbnail — sized like contact portrait, text wraps */
.prose .story-photo.story-photo--right {
    float: right;
    display: block;
    width: 220px;
    max-width: 220px;
    height: auto;
    margin: 0.15rem 0 0.75rem 1.25rem;
    border-radius: 8px;
}

@media (max-width: 768px) {
    .prose .story-photo.story-photo--right {
        width: 180px;
        max-width: 180px;
        margin: 0.15rem 0 0.5rem 1rem;
    }
}

/* Story closing portrait — centered, no float, sits below the survivor paragraph. */
.prose .story-photo.story-photo--closing {
    float: none;
    display: block;
    width: 100%;
    height: auto;
    max-width: min(320px, 80%);
    margin: var(--space-6) auto 0;
    border-radius: 8px;
}

/* --- Journey -------------------------------------------------------------- */

.journey-back {
    font-size: var(--fs-sm);
    margin-bottom: var(--space-4);
}
.journey-back a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 500;
}
.journey-back a:hover,
.journey-back a:focus-visible {
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* Media figures break out of the prose measure slightly for visual breathing room. */
.journey-media {
    margin: var(--space-6) auto;
    max-width: min(100%, calc(var(--content-max) + var(--space-6)));
    text-align: center;
}
.journey-media figcaption {
    font-size: var(--fs-xs);
    color: var(--color-text-muted);
    font-style: italic;
    margin-top: var(--space-1);
}

/* Self-hosted video: portrait 576x1024. Cap height so it doesn't dominate the
   viewport, let width track aspect ratio, center it. */
.journey-media--video video {
    display: block;
    max-height: 70vh;
    max-width: 100%;
    width: auto;
    margin-inline: auto;
    border-radius: var(--radius-md);
}

/* Facebook Reels-style embeds: portrait wrapper, ~420px max, 9:16 ratio. */
.journey-media__fb-wrap {
    max-width: 420px;
    margin: 0 auto;
    aspect-ratio: 4 / 5;
    background: var(--color-bg-alt);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.journey-media__fb-wrap iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

/* Inline article preview cards on the journey page. */
.prose .journey-article-card {
    border: 1px solid var(--color-divider);
    border-radius: var(--radius-md);
    padding: var(--space-3);
    margin: var(--space-6) auto;
    max-width: var(--content-max);
}
.prose .journey-article-card__date {
    font-size: var(--fs-xs);
    color: var(--color-text-muted);
    margin: 0 0 var(--space-1);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.prose .journey-article-card__title {
    font-size: var(--fs-lg);
    margin: 0 0 var(--space-2);
}
.prose .journey-article-card__title a {
    color: var(--color-primary);
    text-decoration: none;
}
.prose .journey-article-card__title a:hover,
.prose .journey-article-card__title a:focus-visible {
    text-decoration: underline;
    text-underline-offset: 3px;
}
.prose .journey-article-card__pull {
    margin: 0 0 var(--space-2);
}
.prose .journey-article-card__more {
    margin: 0;
    font-size: var(--fs-sm);
}
.prose .journey-article-card__more a {
    color: var(--color-secondary);
    font-weight: 600;
    text-decoration: none;
}
.prose .journey-article-card__more a:hover,
.prose .journey-article-card__more a:focus-visible {
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* Inline portraits — text wraps around floated thumbnails. */
.journey-photo { max-width: 280px; margin: var(--space-1) 0 var(--space-2); }
.journey-photo--left  { float: left;  margin-right: var(--space-4); }
.journey-photo--right { float: right; margin-left: var(--space-4); }
.journey-photo img { width: 100%; height: auto; border-radius: var(--radius-md); display: block; }
.journey-media { clear: both; }   /* videos/cards never collide with a floated photo */
@media (max-width: 768px) {
    .journey-photo, .journey-photo--left, .journey-photo--right {
        float: none; margin: var(--space-4) auto; max-width: 320px;
    }
    .journey-media { width: 100%; max-width: 100%; }
    .journey-media--video video { width: 100%; height: auto; max-height: none; }
    .journey-media__fb-wrap { width: 100%; max-width: 100%; }
    .journey-media__fb-wrap iframe { width: 100%; height: 100%; }
}
