.ap-skyscraper-cta-wrap {
    width: min(300px, 100%);
    max-width: 100%;
    margin: 1.5rem auto;
}

.ap-skyscraper-cta-wrap--wide-skyscraper {
    width: min(160px, 100%);
}

@media (min-width: 960px) and (min-height: 860px) {
    .ap-skyscraper-cta-wrap--sticky {
        position: sticky;
        top: 96px;
        align-self: flex-start;
        z-index: 4;
    }
}

.ap-skyscraper-cta {
    --ap-sky-blue: #1491ff;
    --ap-sky-blue-2: #0052ff;
    --ap-sky-cyan: #29e4ff;
    --ap-sky-navy: #062066;
    position: relative;
    isolation: isolate;
    overflow: hidden;
    box-sizing: border-box;
    width: 100%;
    min-height: 760px;
    padding: 32px 22px 24px;
    border-radius: 0;
    background:
        radial-gradient(circle at 82% 8%, rgba(41, 228, 255, 0.26), transparent 26%),
        radial-gradient(circle at 16% 62%, rgba(24, 115, 255, 0.34), transparent 34%),
        linear-gradient(145deg, #04216e 0%, #053b9d 48%, #03216f 100%);
    box-shadow:
        0 26px 70px rgba(5, 19, 65, 0.32),
        inset 0 1px 0 rgba(255, 255, 255, 0.2);
    color: #ffffff;
    font-family: inherit;
}

.ap-skyscraper-cta--wide-skyscraper {
    min-height: 600px;
    padding: 22px 12px 18px;
}

.ap-skyscraper-cta::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
        linear-gradient(120deg, transparent 0 30%, rgba(255, 255, 255, 0.13) 42%, transparent 56%),
        repeating-linear-gradient(135deg, rgba(255,255,255,0.055) 0 2px, transparent 2px 16px);
    transform: translateX(-75%);
    animation: apSkySweep 5.6s ease-in-out infinite;
}

.ap-skyscraper-cta::after {
    content: "";
    position: absolute;
    left: -65px;
    right: -65px;
    bottom: -90px;
    height: 260px;
    z-index: -1;
    background:
        radial-gradient(circle at 50% 0%, rgba(41, 228, 255, 0.2), transparent 46%),
        linear-gradient(135deg, rgba(255,255,255,0.06), transparent);
    transform: rotate(-10deg);
}

.ap-skyscraper-cta__shine {
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(circle at 88% 22%, rgba(42, 218, 255, 0.22), transparent 20%),
        radial-gradient(circle at 10% 88%, rgba(255, 213, 62, 0.12), transparent 22%);
    animation: apSkyGlow 3.4s ease-in-out infinite;
}

.ap-skyscraper-cta__orb {
    position: absolute;
    border: 2px dashed rgba(119, 211, 255, 0.25);
    border-radius: 999px;
    pointer-events: none;
}

.ap-skyscraper-cta__orb--one {
    top: -32px;
    right: -38px;
    width: 108px;
    height: 108px;
    animation: apSkySpin 18s linear infinite;
}

.ap-skyscraper-cta__orb--two {
    top: 132px;
    right: -42px;
    width: 90px;
    height: 90px;
    animation: apSkySpin 14s linear infinite reverse;
}

.ap-skyscraper-cta__grid {
    position: absolute;
    top: 22px;
    right: 60px;
    width: 48px;
    height: 48px;
    opacity: 0.36;
    background-image: radial-gradient(circle, rgba(129, 212, 255, 0.7) 1.5px, transparent 2px);
    background-size: 10px 10px;
    animation: apSkyGrid 2.8s ease-in-out infinite;
}

.ap-skyscraper-cta__brand {
    position: relative;
    z-index: 2;
    margin-bottom: 22px;
}

.ap-skyscraper-cta__logo {
    display: block;
    width: auto;
    height: 30px;
    max-width: 172px;
    object-fit: contain;
    filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.22));
}

.ap-skyscraper-cta__kicker {
    position: relative;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-bottom: 12px;
    padding: 6px 11px;
    border: 1px solid rgba(167, 213, 255, 0.56);
    border-radius: 999px;
    background: rgba(0, 16, 58, 0.35);
    color: #d8efff;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1;
    text-transform: uppercase;
}

.ap-skyscraper-cta__kicker-dot {
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: var(--ap-sky-cyan);
    box-shadow: 0 0 0 5px rgba(41, 228, 255, 0.13), 0 0 16px rgba(41, 228, 255, 0.9);
    animation: apSkyDot 1.4s ease-in-out infinite;
}

.ap-skyscraper-cta__heading {
    position: relative;
    z-index: 2;
    max-width: 260px;
    margin: 0;
    color: #ffffff;
    font-size: 42px;
    line-height: 0.94;
    letter-spacing: -0.065em;
    font-weight: 950;
}

.ap-skyscraper-cta__heading::first-line {
    color: #ffffff;
}

.ap-skyscraper-cta__body {
    position: relative;
    z-index: 2;
    max-width: 245px;
    margin: 14px 0 0;
    color: rgba(225, 241, 255, 0.88);
    font-size: 13px;
    line-height: 1.45;
}

.ap-skyscraper-cta__visual {
    position: relative;
    z-index: 2;
    height: 260px;
    margin-top: 22px;
}

.ap-skyscraper-cta__doc-stack {
    position: absolute;
    left: 8px;
    top: 34px;
    width: 116px;
    height: 142px;
    animation: apSkyFloatA 4.7s ease-in-out infinite;
}

.ap-skyscraper-cta__doc-stack > span {
    position: absolute;
    inset: 16px 18px 0 0;
    border-radius: 16px;
    background: rgba(202, 229, 255, 0.5);
    box-shadow: 0 16px 32px rgba(0, 13, 60, 0.22);
    transform: rotate(-6deg);
}

.ap-skyscraper-cta__doc-stack > span:nth-child(2) {
    inset: 9px 9px 8px 8px;
    background: rgba(223, 241, 255, 0.68);
    transform: rotate(-2deg);
}

.ap-skyscraper-cta__doc {
    position: absolute;
    inset: 0 0 14px 24px;
    padding: 18px 14px;
    border: 1px solid rgba(255,255,255,0.7);
    border-radius: 18px;
    background: rgba(255,255,255,0.94);
    box-shadow: 0 20px 38px rgba(0, 21, 77, 0.28);
}

.ap-skyscraper-cta__doc b {
    display: grid;
    place-items: center;
    width: 38px;
    height: 30px;
    border-radius: 7px;
    background: #ff426d;
    color: #fff;
    font-size: 10px;
    letter-spacing: 0.06em;
}

.ap-skyscraper-cta__doc i {
    display: block;
    height: 8px;
    margin-top: 12px;
    border-radius: 999px;
    background: #c9d8ee;
}

.ap-skyscraper-cta__doc i:nth-of-type(2) {
    width: 78%;
}

.ap-skyscraper-cta__doc i:nth-of-type(3) {
    width: 62%;
}

.ap-skyscraper-cta__audio-tile {
    position: absolute;
    right: 7px;
    top: 64px;
    display: grid;
    place-items: center;
    width: 86px;
    height: 86px;
    border: 2px solid rgba(139, 229, 255, 0.8);
    border-radius: 20px;
    background: linear-gradient(145deg, #1594ff, #20c8e9);
    box-shadow: 0 18px 36px rgba(0, 27, 86, 0.26), 0 0 24px rgba(41, 228, 255, 0.18);
    animation: apSkyFloatB 3.8s ease-in-out infinite;
}

.ap-skyscraper-cta__audio-tile span {
    width: 34px;
    height: 42px;
    border: 4px solid #ffffff;
    border-bottom: none;
    border-radius: 22px 22px 0 0;
    position: relative;
}

.ap-skyscraper-cta__audio-tile span::before,
.ap-skyscraper-cta__audio-tile span::after {
    content: "";
    position: absolute;
    bottom: -13px;
    width: 10px;
    height: 22px;
    border-radius: 999px;
    background: #ffffff;
}

.ap-skyscraper-cta__audio-tile span::before {
    left: -6px;
}

.ap-skyscraper-cta__audio-tile span::after {
    right: -6px;
}

.ap-skyscraper-cta__waves {
    position: absolute;
    left: 92px;
    top: 164px;
    display: flex;
    align-items: end;
    gap: 4px;
    height: 42px;
}

.ap-skyscraper-cta__waves i {
    display: block;
    width: 5px;
    height: 14px;
    border-radius: 999px;
    background: linear-gradient(180deg, #ffffff, var(--ap-sky-cyan));
    box-shadow: 0 0 12px rgba(41, 228, 255, 0.45);
    animation: apSkyWave 0.9s ease-in-out infinite;
}

.ap-skyscraper-cta__waves i:nth-child(2) { height: 24px; animation-delay: 0.07s; }
.ap-skyscraper-cta__waves i:nth-child(3) { height: 36px; animation-delay: 0.14s; }
.ap-skyscraper-cta__waves i:nth-child(4) { height: 27px; animation-delay: 0.21s; }
.ap-skyscraper-cta__waves i:nth-child(5) { height: 40px; animation-delay: 0.28s; }
.ap-skyscraper-cta__waves i:nth-child(6) { height: 26px; animation-delay: 0.35s; }
.ap-skyscraper-cta__waves i:nth-child(7) { height: 34px; animation-delay: 0.42s; }
.ap-skyscraper-cta__waves i:nth-child(8) { height: 18px; animation-delay: 0.49s; }

.ap-skyscraper-cta__player {
    position: absolute;
    left: 32px;
    right: 10px;
    bottom: 4px;
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 54px;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,0.94);
    color: #08276d;
    box-shadow: 0 18px 38px rgba(0, 13, 60, 0.28);
    animation: apSkyFloatC 4.2s ease-in-out infinite;
}

.ap-skyscraper-cta__play {
    display: grid;
    place-items: center;
    width: 35px;
    height: 35px;
    border-radius: 999px;
    background: linear-gradient(135deg, #1677ff, #004dff);
    color: #fff;
    font-size: 12px;
    box-shadow: 0 10px 18px rgba(22, 119, 255, 0.34);
}

.ap-skyscraper-cta__mini-wave {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
}

.ap-skyscraper-cta__mini-wave i {
    width: 4px;
    height: 12px;
    border-radius: 999px;
    background: linear-gradient(180deg, #1677ff, #25d8f6);
    animation: apSkyMiniWave 0.85s ease-in-out infinite;
}

.ap-skyscraper-cta__mini-wave i:nth-child(2) { height: 18px; animation-delay: 0.08s; }
.ap-skyscraper-cta__mini-wave i:nth-child(3) { height: 14px; animation-delay: 0.16s; }
.ap-skyscraper-cta__mini-wave i:nth-child(4) { height: 22px; animation-delay: 0.24s; }
.ap-skyscraper-cta__mini-wave i:nth-child(5) { height: 15px; animation-delay: 0.32s; }

.ap-skyscraper-cta__time {
    font-size: 11px;
    font-weight: 900;
    color: #435678;
}

.ap-skyscraper-cta__features {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 7px;
    margin-top: 18px;
    padding: 10px;
    border: 1px solid rgba(151, 198, 255, 0.24);
    border-radius: 14px;
    background: rgba(0, 15, 67, 0.36);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}

.ap-skyscraper-cta__features span {
    display: block;
    color: rgba(236, 247, 255, 0.9);
    font-size: 9.5px;
    font-weight: 850;
    line-height: 1.15;
    text-align: center;
}

.ap-skyscraper-cta__features span::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    margin: 0 auto 5px;
    border-radius: 999px;
    background:
        radial-gradient(circle at 50% 50%, #29e4ff 0 32%, transparent 34%),
        rgba(255,255,255,0.11);
    box-shadow: 0 0 18px rgba(41, 228, 255, 0.18);
}

.ap-skyscraper-cta__button {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 50px;
    margin-top: 18px;
    padding: 12px 16px;
    border-radius: 999px;
    background: linear-gradient(135deg, #ffdf57 0%, #ffbe2e 100%);
    color: #08276d;
    font-size: 18px;
    font-weight: 950;
    letter-spacing: -0.025em;
    text-align: center;
    text-decoration: none;
    box-shadow:
        0 16px 32px rgba(0, 0, 0, 0.25),
        0 0 0 0 rgba(255, 222, 87, 0.34),
        inset 0 1px 0 rgba(255,255,255,0.55);
    transition: transform 180ms ease, box-shadow 180ms ease;
    animation: apSkyButtonPulse 2.1s ease-in-out infinite;
}

.ap-skyscraper-cta__button:hover,
.ap-skyscraper-cta__button:focus {
    color: #061f58;
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow:
        0 20px 38px rgba(0, 0, 0, 0.3),
        0 0 0 9px rgba(255, 222, 87, 0.08),
        inset 0 1px 0 rgba(255,255,255,0.55);
}

.ap-skyscraper-cta__button b {
    transition: transform 180ms ease;
}

.ap-skyscraper-cta__button:hover b,
.ap-skyscraper-cta__button:focus b {
    transform: translateX(3px);
}

.ap-skyscraper-cta__note {
    position: relative;
    z-index: 2;
    max-width: 210px;
    margin: 14px auto 0;
    color: rgba(232, 245, 255, 0.82);
    font-size: 11px;
    line-height: 1.3;
    text-align: center;
}

.ap-skyscraper-cta__note::before {
    content: "◇";
    display: inline-block;
    margin-right: 5px;
    color: #80f0ff;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__logo {
    height: 22px;
    max-width: 130px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__kicker {
    font-size: 9px;
    padding: 5px 8px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__heading {
    font-size: 29px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__body {
    font-size: 11px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__visual {
    height: 205px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__features {
    grid-template-columns: 1fr;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__button {
    font-size: 14px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__audio-tile {
    right: 0;
    width: 62px;
    height: 62px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__player {
    left: 0;
    right: 0;
}

@keyframes apSkySweep {
    0%, 40% { transform: translateX(-85%); opacity: 0; }
    52% { opacity: 1; }
    76%, 100% { transform: translateX(85%); opacity: 0; }
}

@keyframes apSkyGlow {
    0%, 100% { opacity: 0.7; transform: scale(1); }
    50% { opacity: 1; transform: scale(1.015); }
}

@keyframes apSkySpin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes apSkyGrid {
    0%, 100% { opacity: 0.24; transform: translateY(0); }
    50% { opacity: 0.52; transform: translateY(5px); }
}

@keyframes apSkyDot {
    0%, 100% { transform: scale(0.82); opacity: 0.8; }
    50% { transform: scale(1.18); opacity: 1; }
}

@keyframes apSkyFloatA {
    0%, 100% { transform: translate3d(0,0,0) rotate(-1deg); }
    50% { transform: translate3d(0,-9px,0) rotate(1deg); }
}

@keyframes apSkyFloatB {
    0%, 100% { transform: translate3d(0,0,0) rotate(1deg); }
    50% { transform: translate3d(-8px,7px,0) rotate(-1.2deg); }
}

@keyframes apSkyFloatC {
    0%, 100% { transform: translate3d(0,0,0); }
    50% { transform: translate3d(7px,-6px,0); }
}

@keyframes apSkyWave {
    0%, 100% { transform: scaleY(0.62); opacity: 0.72; }
    50% { transform: scaleY(1.18); opacity: 1; }
}

@keyframes apSkyMiniWave {
    0%, 100% { transform: scaleY(0.7); opacity: 0.7; }
    50% { transform: scaleY(1.2); opacity: 1; }
}

@keyframes apSkyButtonPulse {
    0%, 100% {
        box-shadow:
            0 16px 32px rgba(0, 0, 0, 0.25),
            0 0 0 0 rgba(255, 222, 87, 0.34),
            inset 0 1px 0 rgba(255,255,255,0.55);
    }
    50% {
        box-shadow:
            0 18px 36px rgba(0, 0, 0, 0.3),
            0 0 0 11px rgba(255, 222, 87, 0.06),
            inset 0 1px 0 rgba(255,255,255,0.55);
    }
}

@media (max-width: 959px) {
    .ap-skyscraper-cta-wrap--sticky {
        position: static;
    }
}

@media (max-height: 859px) {
    .ap-skyscraper-cta-wrap--sticky {
        position: static;
    }
}

@media (max-width: 360px) {
    .ap-skyscraper-cta {
        min-height: 720px;
        padding-left: 18px;
        padding-right: 18px;
    }

    .ap-skyscraper-cta__heading {
        font-size: 38px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .ap-skyscraper-cta,
    .ap-skyscraper-cta *,
    .ap-skyscraper-cta::before,
    .ap-skyscraper-cta::after {
        animation: none !important;
        transition: none !important;
    }
}

/* v0.2.1 copy alignment: longer main CTA wording */
.ap-skyscraper-cta__heading {
    font-size: 38px;
    line-height: 0.96;
    max-width: 270px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__heading {
    font-size: 27px;
    line-height: 0.98;
}

@media (max-width: 360px) {
    .ap-skyscraper-cta__heading {
        font-size: 35px;
    }
}

/* v0.2.2 longer main CTA wording fit */
.ap-skyscraper-cta__heading {
    font-size: 34px;
    line-height: 0.96;
    max-width: 270px;
}

.ap-skyscraper-cta__body {
    font-size: 12.5px;
    line-height: 1.45;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__heading {
    font-size: 25px;
    line-height: 0.98;
}

@media (max-width: 360px) {
    .ap-skyscraper-cta__heading {
        font-size: 32px;
    }
}

/* v0.2.3 PDF Autopsy copy fit */
.ap-skyscraper-cta__heading {
    font-size: 38px;
    line-height: 0.96;
    max-width: 270px;
}

.ap-skyscraper-cta__body {
    font-size: 12.5px;
    line-height: 1.48;
}

.ap-skyscraper-cta__note {
    max-width: 230px;
}

.ap-skyscraper-cta--wide-skyscraper .ap-skyscraper-cta__heading {
    font-size: 27px;
    line-height: 0.98;
}

/* v0.2.4 force sticky sidebar behaviour */
@media (min-width: 960px) {
    .ap-skyscraper-cta-wrap.ap-skyscraper-cta-wrap--sticky {
        position: sticky !important;
        top: 88px !important;
        align-self: flex-start !important;
        z-index: 30 !important;
    }
}

/* Keep sticky active even on shorter screens. Use a smaller top gap so more of the unit is visible. */
@media (min-width: 960px) and (max-height: 859px) {
    .ap-skyscraper-cta-wrap.ap-skyscraper-cta-wrap--sticky {
        position: sticky !important;
        top: 24px !important;
    }
}

/* v0.2.5 sticky fix: make the WP widget sticky, not only the inner shortcode wrapper */
@media (min-width: 960px) {
    .ap-skyscraper-cta-widget-sticky {
        position: sticky !important;
        top: 88px !important;
        align-self: flex-start !important;
        z-index: 40 !important;
    }

    .ap-skyscraper-cta-widget-sticky .ap-skyscraper-cta-wrap--sticky {
        position: static !important;
        top: auto !important;
    }

    .ap-skyscraper-cta-sidebar-has-sticky,
    .ap-skyscraper-cta-sidebar-has-sticky * {
        overflow: visible;
    }
}

@media (min-width: 960px) and (max-height: 859px) {
    .ap-skyscraper-cta-widget-sticky {
        top: 24px !important;
    }
}

/* v0.2.6 JS fixed-position sticky fallback */
.ap-skyscraper-cta-fixed-placeholder {
    width: 100%;
    max-width: 100%;
    pointer-events: none;
}

.ap-skyscraper-cta-widget-fixed {
    margin-top: 0 !important;
    transform: translateZ(0);
}

@media (max-width: 959px) {
    .ap-skyscraper-cta-widget-fixed {
        position: static !important;
        top: auto !important;
        left: auto !important;
        width: auto !important;
    }

    .ap-skyscraper-cta-fixed-placeholder {
        display: none !important;
        height: 0 !important;
    }
}

/* v0.2.7 footer-aware sticky stop */
.ap-skyscraper-cta-widget-footer-stop {
    transition: top 80ms linear;
}

/* v0.2.7 footer-aware sticky stop */
.ap-skyscraper-cta-widget-footer-stop {
    transition: top 80ms linear;
}

/* v0.2.8 keep fixed skyscraper fully inside viewport */
@media (min-width: 960px) {
    .ap-skyscraper-cta-widget-fixed {
        top: 16px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta {
        min-height: 0 !important;
        height: calc(100vh - 32px) !important;
        max-height: 760px !important;
        padding-top: clamp(16px, 2.6vh, 26px) !important;
        padding-bottom: clamp(12px, 2vh, 20px) !important;
        display: flex !important;
        flex-direction: column !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__brand {
        margin-bottom: clamp(10px, 1.8vh, 18px) !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__logo {
        height: clamp(22px, 3.1vh, 30px) !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__kicker {
        margin-bottom: clamp(8px, 1.3vh, 12px) !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__heading {
        font-size: clamp(28px, 4.4vh, 38px) !important;
        line-height: 0.94 !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__body {
        margin-top: clamp(8px, 1.4vh, 14px) !important;
        font-size: clamp(10px, 1.45vh, 12.5px) !important;
        line-height: 1.38 !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__visual {
        flex: 1 1 auto !important;
        min-height: 170px !important;
        height: auto !important;
        margin-top: clamp(10px, 1.8vh, 20px) !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__features {
        margin-top: clamp(8px, 1.4vh, 14px) !important;
        padding: clamp(7px, 1.1vh, 10px) !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__button {
        min-height: clamp(42px, 6vh, 50px) !important;
        margin-top: clamp(8px, 1.5vh, 16px) !important;
        padding: 10px 14px !important;
        font-size: clamp(14px, 2vh, 18px) !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__note {
        margin-top: clamp(7px, 1.2vh, 12px) !important;
        font-size: clamp(9px, 1.25vh, 11px) !important;
        line-height: 1.2 !important;
    }
}

/* Extra compact mode for laptop-height screens */
@media (min-width: 960px) and (max-height: 820px) {
    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__visual {
        min-height: 145px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__doc-stack {
        transform: scale(0.86) !important;
        transform-origin: left top !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__audio-tile {
        transform: scale(0.86) !important;
        transform-origin: right top !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__player {
        min-height: 44px !important;
    }
}

/* v0.2.9 use JS scale-to-fit instead of squeezing internal layout */
@media (min-width: 960px) {
    .ap-skyscraper-cta-widget-fixed {
        margin-top: 0 !important;
        will-change: top, transform;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta {
        height: auto !important;
        min-height: 760px !important;
        max-height: none !important;
        display: block !important;
        padding: 32px 22px 24px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__brand {
        margin-bottom: 22px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__logo {
        height: 30px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__kicker {
        margin-bottom: 12px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__heading {
        font-size: 38px !important;
        line-height: 0.96 !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__body {
        margin-top: 14px !important;
        font-size: 12.5px !important;
        line-height: 1.48 !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__visual {
        height: 260px !important;
        min-height: 260px !important;
        margin-top: 22px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__features {
        margin-top: 18px !important;
        padding: 10px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__button {
        min-height: 50px !important;
        margin-top: 18px !important;
        padding: 12px 16px !important;
        font-size: 18px !important;
    }

    .ap-skyscraper-cta-widget-fixed .ap-skyscraper-cta__note {
        margin-top: 14px !important;
        font-size: 11px !important;
        line-height: 1.3 !important;
    }
}

@media (max-width: 959px) {
    .ap-skyscraper-cta-widget-fixed {
        transform: none !important;
    }
}
