/* DockFlow Marketing Sections */

.df-guest-flow-section,
.df-guest-flow-section * {
    box-sizing: border-box;
}

.df-guest-flow-section {
    --df-green: #74FE94;
    --df-black: #000000;
    --df-ink: #ffffff;
    --df-panel: #080A09;
    --df-panel-soft: #111411;
    --df-muted: #A8B0AA;
    --df-border: #222822;
    --df-float-a-x: 0px;
    --df-float-a-y: 0px;
    --df-float-b-x: 0px;
    --df-float-b-y: 0px;
    --df-signature-dash: 100;
    --df-scan-y: 0px;
    --df-mini-scan-y: 0px;

    position: relative;
    overflow: hidden;
    isolation: isolate;
    width: 100%;
    padding: 120px 24px;
    background: #000000;
    color: #ffffff;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.df-guest-flow-bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at 74% 44%, rgba(116, 254, 148, 0.1), transparent 33%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.04), transparent 34%),
        #000000;
}

.df-guest-flow-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(255, 255, 255, 0.032) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.032) 1px, transparent 1px);
    background-size: 88px 88px;
    mask-image: radial-gradient(circle at 70% 48%, black, transparent 63%);
    opacity: 0.25;
}

.df-guest-flow-inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.86fr);
    gap: clamp(54px, 7vw, 104px);
    align-items: center;
    width: min(1180px, 100%);
    margin: 0 auto;
}

.df-section-eyebrow {
    margin: 0 0 18px;
    color: var(--df-green);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.df-section-title {
    max-width: 690px;
    margin: 0;
    color: var(--df-ink);
    font-size: 48px;
    font-weight: 500;
    line-height: 1.02;
    letter-spacing: -1px;
}

.df-section-body {
    max-width: 630px;
    margin: 22px 0 0;
    color: var(--df-muted);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.8;
}

.df-guest-flow-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 42px;
}

.df-guest-flow-card {
    position: relative;
    min-height: 226px;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, 0.085);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(17, 20, 17, 0.92), rgba(8, 10, 9, 0.94));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.055), 0 24px 80px rgba(0, 0, 0, 0.32);
}

.df-guest-flow-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(116, 254, 148, 0.085), transparent 38%);
    opacity: 0;
    transition: opacity 220ms ease;
}

.df-guest-flow-card:hover::after {
    opacity: 1;
}

.df-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    margin-bottom: 42px;
    border: 1px solid rgba(116, 254, 148, 0.22);
    border-radius: 999px;
    color: var(--df-green);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: -0.2px;
    background: rgba(116, 254, 148, 0.055);
}

.df-guest-flow-card h3 {
    margin: 0;
    color: var(--df-ink);
    font-size: 18px;
    font-weight: 500;
    line-height: 1.24;
    letter-spacing: -0.35px;
}

.df-guest-flow-card p {
    margin: 12px 0 0;
    color: var(--df-muted);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.65;
}

.df-guest-flow-visual {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 720px;
}

.df-phone-shell {
    position: relative;
    z-index: 2;
    width: min(354px, 82vw);
    padding: 10px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 48px;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.045) 42%, rgba(255, 255, 255, 0.11));
    box-shadow: 0 44px 120px rgba(0, 0, 0, 0.5), 0 0 36px rgba(116, 254, 148, 0.075);
}

.df-phone-shell::before {
    content: "";
    position: absolute;
    top: 19px;
    left: 50%;
    z-index: 4;
    width: 86px;
    height: 22px;
    border-radius: 999px;
    background: #000000;
    transform: translateX(-50%);
}

.df-phone-glass {
    overflow: hidden;
    min-height: 672px;
    padding: 30px 18px 18px;
    border: 1px solid rgba(255, 255, 255, 0.085);
    border-radius: 38px;
    background: radial-gradient(circle at 50% 0%, rgba(116, 254, 148, 0.12), transparent 32%), linear-gradient(180deg, #080A09, #000000 72%);
}

.df-phone-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    min-height: 34px;
}

.df-phone-topbar img {
    display: block;
    width: 116px;
    max-width: 48%;
    height: auto;
}

.df-phone-topbar span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border: 1px solid rgba(116, 254, 148, 0.18);
    border-radius: 999px;
    color: var(--df-green);
    font-size: 10px;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
    background: rgba(116, 254, 148, 0.07);
}

.df-ticket-card {
    margin-top: 24px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(17, 20, 17, 0.98), rgba(8, 10, 9, 0.98));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 24px 62px rgba(0, 0, 0, 0.32);
}

.df-ticket-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.df-ticket-kicker {
    display: block;
    margin-bottom: 9px;
    color: var(--df-muted);
    font-size: 11px;
    font-weight: 400;
    line-height: 1;
}

.df-ticket-header h3 {
    margin: 0;
    color: var(--df-ink);
    font-size: 28px;
    font-weight: 500;
    line-height: 1.02;
    letter-spacing: -0.7px;
}

.df-ticket-status {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    color: #020302;
    font-size: 10px;
    font-weight: 500;
    background: var(--df-green);
}

.df-booking-ref {
    margin: 14px 0 0;
    color: rgba(255, 255, 255, 0.68);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: -0.1px;
}

.df-ticket-info {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
    margin-top: 18px;
}

.df-ticket-info-card,
.df-ticket-checks div {
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.035);
}

.df-ticket-info-card {
    min-width: 0;
    min-height: 58px;
    padding: 8px 7px;
    border-radius: 15px;
}

.df-ticket-info-card span,
.df-ticket-checks span {
    display: flex;
    align-items: center;
    gap: 5px;
    min-width: 0;
    color: rgba(168, 176, 170, 0.85);
    font-size: 9.5px;
    font-weight: 300;
    line-height: 1.1;
    white-space: nowrap;
}

.df-ticket-info-card svg {
    flex: 0 0 auto;
    display: block;
    width: 11px;
    height: 11px;
    color: rgba(116, 254, 148, 0.78);
}

.df-ticket-info-card strong,
.df-ticket-checks strong {
    display: block;
    margin-top: 8px;
    color: var(--df-ink);
    font-size: 10.4px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -0.18px;
    white-space: nowrap;
}

.df-qr-wrap {
    position: relative;
    overflow: hidden;
    display: grid;
    place-items: center;
    width: 164px;
    height: 164px;
    margin: 22px auto 0;
    padding: 12px;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.36);
}

.df-qr-wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.df-phone-scan-line,
.df-mini-scan-line {
    position: absolute;
    left: 10%;
    right: 10%;
    height: 2px;
    border-radius: 999px;
    background: rgba(116, 254, 148, 0.92);
    box-shadow: 0 0 16px rgba(116, 254, 148, 0.62);
}

.df-phone-scan-line {
    top: 12%;
    transform: translateY(var(--df-scan-y));
}

.df-qr-caption {
    margin: 12px 0 0;
    color: rgba(255, 255, 255, 0.68);
    font-size: 11px;
    font-weight: 300;
    line-height: 1.3;
    text-align: center;
}

.df-ticket-checks {
    display: grid;
    gap: 8px;
    margin-top: 18px;
}

.df-ticket-checks div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 42px;
    padding: 10px 12px;
    border-radius: 14px;
}

.df-ticket-checks span {
    display: block;
    font-size: 10px;
}

.df-ticket-checks strong {
    margin-top: 0;
    font-size: 11px;
    text-align: right;
}

.df-phone-nav {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
    margin-top: 14px;
    padding: 7px;
    border: 1px solid rgba(255, 255, 255, 0.075);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.035);
}

.df-phone-nav span {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    min-width: 0;
    min-height: 42px;
    border-radius: 14px;
    color: rgba(255, 255, 255, 0.5);
    font-size: 9px;
    font-weight: 400;
    line-height: 1;
}

.df-phone-nav svg {
    display: block;
    width: 14px;
    height: 14px;
    flex: 0 0 auto;
}

.df-phone-nav em {
    display: block;
    overflow: hidden;
    max-width: 100%;
    font-style: normal;
    line-height: 1;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.df-phone-nav .is-active {
    color: #020302;
    background: var(--df-green);
}

.df-float-card {
    position: absolute;
    z-index: 3;
    width: 126px;
    height: 126px;
    padding: 13px;
    border: 1px solid rgba(255, 255, 255, 0.11);
    border-radius: 25px;
    background: linear-gradient(180deg, rgba(17, 20, 17, 0.94), rgba(8, 10, 9, 0.94));
    box-shadow: 0 24px 76px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.055);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    will-change: transform;
    transition: transform 100ms linear;
}

.df-float-card-waiver {
    top: 118px;
    left: 12px;
    transform: translate3d(calc(-14px + var(--df-float-a-x)), var(--df-float-a-y), 0);
}

.df-float-card-checkin {
    right: 6px;
    bottom: 144px;
    transform: translate3d(calc(14px + var(--df-float-b-x)), var(--df-float-b-y), 0);
}

.df-float-card-head {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 18px;
    color: #ffffff;
    font-size: 11.5px;
    font-weight: 500;
    line-height: 1;
}

.df-float-card-head svg {
    flex: 0 0 auto;
    display: block;
    width: 15px;
    height: 15px;
    color: var(--df-green);
}

.df-float-card p {
    margin: 9px 0 0;
    color: var(--df-muted);
    font-size: 11px;
    font-weight: 300;
    line-height: 1.2;
}

.df-signature-doodle {
    display: block;
    width: 100%;
    height: 38px;
    margin-top: 10px;
    overflow: visible;
}

.df-signature-doodle-line,
.df-signature-doodle-base {
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.df-signature-doodle-line {
    stroke: var(--df-green);
    stroke-width: 2.5;
    stroke-dasharray: 100;
    stroke-dashoffset: var(--df-signature-dash);
    filter: drop-shadow(0 0 8px rgba(116, 254, 148, 0.32));
}

.df-signature-doodle-base {
    stroke: rgba(255, 255, 255, 0.18);
    stroke-width: 1.2;
}

.df-mini-qr-wrap {
    position: relative;
    overflow: hidden;
    width: 48px;
    height: 48px;
    margin-top: 10px;
    padding: 5px;
    border-radius: 13px;
    background: #ffffff;
}

.df-mini-qr-wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.df-mini-scan-line {
    top: 6px;
    left: 8px;
    right: 8px;
    height: 2px;
    transform: translateY(var(--df-mini-scan-y));
}

@media (max-width: 1100px) {
    .df-guest-flow-inner {
        grid-template-columns: 1fr;
        gap: 72px;
    }

    .df-guest-flow-copy {
        max-width: 820px;
    }

    .df-guest-flow-visual {
        min-height: 680px;
    }

    .df-section-title {
        font-size: 40px;
    }
}

@media (max-width: 760px) {
    .df-guest-flow-section {
        padding: 86px 18px;
    }

    .df-section-title {
        font-size: 32px;
        line-height: 1.06;
    }

    .df-section-body {
        line-height: 1.72;
    }

    .df-guest-flow-grid {
        grid-template-columns: 1fr;
        gap: 12px;
        margin-top: 32px;
    }

    .df-guest-flow-card {
        min-height: auto;
        padding: 22px;
        border-radius: 24px;
    }

    .df-step-number {
        margin-bottom: 28px;
    }

    .df-guest-flow-visual {
        min-height: 664px;
        padding: 0 12px;
    }

    .df-phone-shell {
        width: min(326px, 84vw);
        border-radius: 44px;
    }

    .df-phone-glass {
        min-height: 632px;
        padding: 30px 15px 16px;
        border-radius: 34px;
    }

    .df-ticket-header h3 {
        font-size: 25px;
    }

    .df-ticket-info {
        gap: 6px;
    }

    .df-ticket-info-card {
        min-height: 55px;
        padding: 8px 6px;
    }

    .df-ticket-info-card span {
        gap: 4px;
        font-size: 9px;
    }

    .df-ticket-info-card strong {
        margin-top: 7px;
        font-size: 9.7px;
        letter-spacing: -0.24px;
    }

    .df-ticket-info-card svg {
        width: 10px;
        height: 10px;
    }

    .df-qr-wrap {
        width: 148px;
        height: 148px;
    }

    .df-float-card {
        width: 108px;
        height: 108px;
        padding: 11px;
        border-radius: 21px;
    }

    .df-float-card-head {
        font-size: 10.5px;
    }

    .df-float-card-head svg {
        width: 14px;
        height: 14px;
    }

    .df-float-card p {
        margin-top: 7px;
        font-size: 10.5px;
    }

    .df-float-card-waiver {
        top: 76px;
        left: 50%;
        transform: translate3d(calc(-160px + var(--df-float-a-x)), var(--df-float-a-y), 0);
    }

    .df-float-card-checkin {
        right: 50%;
        bottom: 92px;
        transform: translate3d(calc(160px + var(--df-float-b-x)), var(--df-float-b-y), 0);
    }

    .df-signature-doodle {
        height: 31px;
        margin-top: 8px;
    }

    .df-mini-qr-wrap {
        width: 42px;
        height: 42px;
        margin-top: 8px;
        border-radius: 12px;
    }
}

@media (max-width: 440px) {
    .df-guest-flow-visual {
        min-height: 642px;
        padding: 0;
    }

    .df-phone-shell {
        width: min(304px, 88vw);
    }

    .df-phone-glass {
        min-height: 610px;
    }

    .df-phone-topbar img {
        width: 106px;
    }

    .df-phone-topbar span {
        padding: 0 8px;
        font-size: 9px;
    }

    .df-ticket-card {
        padding: 15px;
        border-radius: 25px;
    }

    .df-ticket-header h3 {
        font-size: 23px;
    }

    .df-ticket-info {
        gap: 5px;
    }

    .df-ticket-info-card {
        min-height: 52px;
        padding: 7px 5px;
        border-radius: 13px;
    }

    .df-ticket-info-card span {
        font-size: 8.4px;
    }

    .df-ticket-info-card strong {
        font-size: 8.9px;
        letter-spacing: -0.3px;
    }

    .df-phone-nav span {
        min-height: 39px;
        font-size: 8.2px;
    }

    .df-phone-nav svg {
        width: 13px;
        height: 13px;
    }

    .df-float-card {
        width: 98px;
        height: 98px;
        padding: 9px;
        border-radius: 19px;
    }

    .df-float-card-head {
        gap: 6px;
        font-size: 9.8px;
    }

    .df-float-card-head svg {
        width: 13px;
        height: 13px;
    }

    .df-float-card p {
        font-size: 9.7px;
    }

    .df-float-card-waiver {
        transform: translate3d(calc(-138px + var(--df-float-a-x)), var(--df-float-a-y), 0);
    }

    .df-float-card-checkin {
        transform: translate3d(calc(138px + var(--df-float-b-x)), var(--df-float-b-y), 0);
    }

    .df-signature-doodle {
        height: 27px;
        margin-top: 6px;
    }

    .df-signature-doodle-line {
        stroke-width: 2.8;
    }

    .df-mini-qr-wrap {
        width: 37px;
        height: 37px;
        margin-top: 6px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .df-float-card,
    .df-guest-flow-card::after {
        transition: none;
    }

    .df-guest-flow-section {
        --df-float-a-x: 0px;
        --df-float-a-y: 0px;
        --df-float-b-x: 0px;
        --df-float-b-y: 0px;
        --df-signature-dash: 0;
        --df-scan-y: 58px;
        --df-mini-scan-y: 18px;
    }
}

/* Team Operations Section */
.df-team-ops-section,
.df-team-ops-section * {
    box-sizing: border-box;
}

.df-team-ops-section {
    --df-green: #74FE94;
    --df-black: #000000;
    --df-ink: #080A09;
    --df-panel: #080A09;
    --df-panel-soft: #111411;
    --df-muted: #A8B0AA;
    --df-copy-muted: #4E5650;
    --df-border: #222822;
    --df-team-console-y: 0px;
    --df-team-cloud-y: 0px;
    --df-team-card-a: 0px;
    --df-team-card-b: 0px;
    --df-team-glow-y: 0px;

    position: relative;
    overflow: hidden;
    isolation: isolate;
    width: 100%;
    padding: 124px 24px;
    background: linear-gradient(180deg, #F7F9F7 0%, #FFFFFF 48%, #F3F6F4 100%);
    color: var(--df-ink);
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.df-team-ops-bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at 78% calc(42% + var(--df-team-glow-y)), rgba(116, 254, 148, 0.16), transparent 31%),
        radial-gradient(circle at 14% 30%, rgba(8, 10, 9, 0.07), transparent 30%);
}

.df-team-ops-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(8, 10, 9, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(8, 10, 9, 0.04) 1px, transparent 1px);
    background-size: 92px 92px;
    mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
    opacity: 0.35;
}

.df-team-ops-wrap {
    width: min(1220px, 100%);
    margin: 0 auto;
}

.df-team-ops-header {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.55fr);
    gap: clamp(34px, 6vw, 86px);
    align-items: end;
    margin-bottom: 58px;
}

.df-team-ops-eyebrow {
    color: var(--df-ink);
}

.df-team-ops-title {
    max-width: 820px;
    color: var(--df-ink);
}

.df-team-ops-intro {
    max-width: 470px;
    color: var(--df-copy-muted);
}

.df-team-ops-stage {
    display: grid;
    grid-template-columns: minmax(280px, 0.42fr) minmax(0, 0.58fr);
    gap: 22px;
    align-items: stretch;
}

.df-role-cloud {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    transform: translate3d(0, var(--df-team-cloud-y), 0);
}

.df-role-card {
    position: relative;
    min-height: 158px;
    padding: 22px;
    border: 1px solid rgba(8, 10, 9, 0.075);
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 18px 42px rgba(8, 10, 9, 0.065);
    backdrop-filter: blur(12px);
}

.df-role-card::after {
    content: "";
    position: absolute;
    top: 24px;
    right: 22px;
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: var(--df-green);
    box-shadow: 0 0 0 6px rgba(116, 254, 148, 0.12);
    opacity: 0.9;
}

.df-role-card-1,
.df-role-card-3 {
    transform: translate3d(0, var(--df-team-card-a), 0);
}

.df-role-card-2,
.df-role-card-4 {
    transform: translate3d(18px, var(--df-team-card-b), 0);
}

.df-role-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 28px;
}

.df-role-card-top span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 11px;
    border: 0;
    border-radius: 999px;
    background: var(--df-green);
    color: var(--df-ink);
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    box-shadow: none;
}

.df-role-card-top i {
    display: block;
    width: 38px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(8, 10, 9, 0.18));
}

.df-role-card h3 {
    margin: 0;
    color: var(--df-ink);
    font-size: 19px;
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.38px;
}

.df-role-card p {
    margin: 12px 0 0;
    color: var(--df-copy-muted);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.62;
}

.df-ops-console {
    position: relative;
    overflow: hidden;
    min-height: 690px;
    padding: 28px;
    border: 1px solid rgba(8, 10, 9, 0.16);
    border-radius: 36px;
    background:
        radial-gradient(circle at 76% 14%, rgba(116, 254, 148, 0.13), transparent 28%),
        linear-gradient(145deg, #111411 0%, #080A09 48%, #000000 100%);
    box-shadow: 0 34px 90px rgba(8, 10, 9, 0.22);
    color: #FFFFFF;
    transform: translate3d(0, var(--df-team-console-y), 0);
}

.df-ops-console::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
    background-size: 58px 58px;
    mask-image: radial-gradient(circle at 70% 34%, #000, transparent 72%);
    opacity: 0.5;
}

.df-ops-console > * {
    position: relative;
    z-index: 1;
}

.df-ops-console-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 22px;
    margin-bottom: 24px;
}

.df-console-kicker {
    display: block;
    margin-bottom: 12px;
    color: var(--df-green);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 1;
    text-transform: uppercase;
}

.df-ops-console-top h3 {
    max-width: 520px;
    margin: 0;
    color: #FFFFFF;
    font-size: 32px;
    font-weight: 500;
    line-height: 1.08;
    letter-spacing: -0.8px;
}

.df-console-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 32px;
    padding: 0 12px;
    border: 1px solid rgba(116, 254, 148, 0.22);
    border-radius: 999px;
    background: rgba(116, 254, 148, 0.08);
    color: #DDFEE6;
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}

.df-console-status i {
    display: block;
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: var(--df-green);
    box-shadow: 0 0 0 5px rgba(116, 254, 148, 0.14);
}

.df-ops-console-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(225px, 0.75fr);
    gap: 14px;
}

.df-console-panel {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.058);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.df-console-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 18px 0;
    margin-bottom: 18px;
}

.df-console-panel-head span {
    color: var(--df-muted);
    font-size: 12px;
    font-weight: 300;
    line-height: 1;
}

.df-console-panel-head strong {
    color: #FFFFFF;
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}

.df-console-schedule {
    min-height: 340px;
    padding-bottom: 18px;
}

.df-schedule-list {
    display: grid;
    gap: 10px;
    padding: 0 14px;
}

.df-schedule-row {
    display: grid;
    grid-template-columns: 48px 1fr auto;
    gap: 12px;
    align-items: center;
    min-height: 72px;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    background: rgba(0, 0, 0, 0.2);
}

.df-schedule-time {
    display: flex;
    width: 48px;
    height: 48px;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: rgba(116, 254, 148, 0.09);
    color: var(--df-green);
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
}

.df-schedule-row strong {
    display: block;
    margin-bottom: 6px;
    color: #FFFFFF;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.2px;
}

.df-schedule-row em {
    display: block;
    color: var(--df-muted);
    font-size: 12px;
    font-style: normal;
    font-weight: 300;
    line-height: 1;
}

.df-schedule-pill {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 9px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 999px;
    color: #D9E0DB;
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}

.df-console-manifest {
    display: grid;
    min-height: 340px;
    align-content: start;
    padding-bottom: 18px;
}

.df-manifest-ring {
    display: grid;
    place-items: center;
    width: 178px;
    height: 178px;
    margin: 16px auto 22px;
    border-radius: 999px;
    background:
        radial-gradient(circle at center, #080A09 0 58%, transparent 59%),
        conic-gradient(var(--df-green) 0 320deg, rgba(255, 255, 255, 0.1) 320deg 360deg);
    box-shadow: 0 0 32px rgba(116, 254, 148, 0.08);
}

.df-manifest-ring div {
    display: grid;
    place-items: center;
    width: 132px;
    height: 132px;
    border-radius: inherit;
    background: #080A09;
}

.df-manifest-ring strong {
    display: block;
    margin-top: 8px;
    color: #FFFFFF;
    font-size: 34px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -1px;
}

.df-manifest-ring span {
    display: block;
    margin-top: -10px;
    color: var(--df-muted);
    font-size: 12px;
    font-weight: 300;
    line-height: 1;
}

.df-manifest-bars {
    display: grid;
    gap: 8px;
    padding: 0 18px;
}

.df-manifest-bars span {
    display: block;
    overflow: hidden;
    height: 7px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
}

.df-manifest-bars span::before {
    content: "";
    display: block;
    width: var(--df-bar);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(116, 254, 148, 0.35), var(--df-green));
}

.df-manifest-bar-1 { --df-bar: 92%; }
.df-manifest-bar-2 { --df-bar: 76%; }
.df-manifest-bar-3 { --df-bar: 64%; }

.df-console-signals {
    grid-column: span 2;
    padding-bottom: 16px;
}

.df-signal-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    padding: 0 16px;
}

.df-signal-card {
    min-height: 104px;
    padding: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    background: rgba(0, 0, 0, 0.18);
}

.df-signal-card strong {
    display: block;
    margin-bottom: 20px;
    color: var(--df-green);
    font-size: 25px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -0.6px;
}

.df-signal-card span {
    display: block;
    color: var(--df-muted);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.35;
}

.df-owner-strip {
    display: grid;
    grid-template-columns: minmax(0, 0.48fr) minmax(0, 0.52fr);
    gap: 18px;
    align-items: center;
    margin-top: 14px;
    padding: 16px;
    border: 1px solid rgba(116, 254, 148, 0.14);
    border-radius: 24px;
    background: rgba(116, 254, 148, 0.06);
}

.df-owner-strip > div:first-child span {
    display: block;
    margin-bottom: 10px;
    color: var(--df-green);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 1;
    text-transform: uppercase;
}

.df-owner-strip > div:first-child strong {
    display: block;
    max-width: 360px;
    color: #FFFFFF;
    font-size: 17px;
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: -0.32px;
}

.df-owner-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.df-owner-metrics div {
    min-height: 94px;
    padding: 15px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    background: rgba(0, 0, 0, 0.22);
}

.df-owner-metrics strong {
    display: block;
    margin-bottom: 18px;
    color: #FFFFFF;
    font-size: 20px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -0.45px;
}

.df-owner-metrics span {
    display: block;
    color: var(--df-muted);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.35;
}

@media (max-width: 1100px) {
    .df-team-ops-header,
    .df-team-ops-stage {
        grid-template-columns: 1fr;
    }

    .df-team-ops-intro {
        max-width: 680px;
    }

    .df-role-cloud {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .df-role-card-2,
    .df-role-card-4 {
        transform: translate3d(0, var(--df-team-card-b), 0);
    }
}

@media (max-width: 980px) {
    .df-team-ops-section {
        padding: 100px 24px;
    }

    .df-team-ops-title {
        font-size: 40px;
    }

    .df-ops-console-top h3 {
        font-size: 28px;
    }
}

@media (max-width: 760px) {
    .df-team-ops-section {
        padding: 84px 20px;
    }

    .df-team-ops-header {
        margin-bottom: 36px;
    }

    .df-team-ops-title {
        font-size: 32px;
        line-height: 1.08;
    }

    .df-role-cloud,
    .df-ops-console-grid,
    .df-owner-strip,
    .df-owner-metrics,
    .df-signal-grid {
        grid-template-columns: 1fr;
    }

    .df-role-cloud {
        gap: 12px;
    }

    .df-role-card,
    .df-role-card-1,
    .df-role-card-2,
    .df-role-card-3,
    .df-role-card-4 {
        transform: none;
    }

    .df-role-card {
        min-height: auto;
        padding: 20px;
        border-radius: 24px;
    }

    .df-ops-console {
        min-height: auto;
        padding: 22px;
        border-radius: 30px;
    }

    .df-ops-console-top {
        display: grid;
    }

    .df-console-status {
        width: fit-content;
    }

    .df-console-schedule,
    .df-console-manifest {
        min-height: auto;
    }

    .df-console-signals {
        grid-column: span 1;
    }

    .df-schedule-row {
        grid-template-columns: 44px 1fr;
    }

    .df-schedule-pill {
        grid-column: 2;
        width: fit-content;
    }

    .df-manifest-ring {
        width: 154px;
        height: 154px;
    }

    .df-manifest-ring div {
        width: 116px;
        height: 116px;
    }
}

/* Growth Section */

.df-growth-section,
.df-growth-section * {
    box-sizing: border-box;
}

.df-growth-section {
    --df-green: #74FE94;
    --df-black: #000000;
    --df-ink: #FFFFFF;
    --df-panel: #080A09;
    --df-panel-soft: #111411;
    --df-muted: #A8B0AA;
    --df-border: #222822;
    --df-copy-muted: #D9E0DB;
    --df-growth-dashboard-y: 0px;
    --df-growth-card-a: 0px;
    --df-growth-card-b: 0px;
    --df-growth-glow-y: 0px;
    --df-growth-curve: 76;

    position: relative;
    overflow: hidden;
    isolation: isolate;
    width: 100%;
    padding: 128px 24px;
    background: #000000;
    color: var(--df-ink);
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.df-growth-bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at 20% calc(22% + var(--df-growth-glow-y)), rgba(116, 254, 148, 0.10), transparent 34%),
        radial-gradient(circle at 84% 62%, rgba(255, 255, 255, 0.055), transparent 30%),
        linear-gradient(180deg, #000000 0%, #080A09 47%, #000000 100%);
}

.df-growth-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
    background-size: 96px 96px;
    mask-image: radial-gradient(circle at 50% 50%, #000 0%, transparent 69%);
    opacity: 0.42;
}

.df-growth-wrap {
    width: min(1220px, 100%);
    margin: 0 auto;
}

.df-growth-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 440px);
    gap: clamp(34px, 5vw, 78px);
    align-items: end;
    margin-bottom: 58px;
}

.df-growth-eyebrow {
    color: var(--df-green);
}

.df-growth-title {
    max-width: 780px;
    color: #FFFFFF;
}

.df-growth-intro {
    max-width: 440px;
    color: var(--df-muted);
}

.df-growth-stage {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(330px, 0.62fr);
    gap: 20px;
    align-items: stretch;
}

.df-growth-dashboard {
    position: relative;
    min-height: 720px;
    padding: 22px;
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 36px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025)),
        linear-gradient(145deg, rgba(17, 20, 17, 0.96), rgba(8, 10, 9, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 34px 100px rgba(0, 0, 0, 0.42);
    transform: translate3d(0, var(--df-growth-dashboard-y), 0);
    transition: transform 120ms linear;
}

.df-growth-dashboard::before {
    content: "";
    position: absolute;
    inset: 1px;
    z-index: 0;
    border-radius: 35px;
    pointer-events: none;
    background:
        radial-gradient(circle at 18% 16%, rgba(116, 254, 148, 0.13), transparent 26%),
        linear-gradient(135deg, rgba(116, 254, 148, 0.065), transparent 38%);
    opacity: 0.82;
}

.df-growth-dashboard > * {
    position: relative;
    z-index: 1;
}

.df-growth-dashboard-top {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    padding: 8px 8px 20px;
}

.df-growth-dashboard-top span,
.df-growth-panel-head span,
.df-growth-chart-head span,
.df-growth-action-card > div > span,
.df-growth-insight-card span {
    display: block;
    color: var(--df-muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1.6px;
    line-height: 1;
    text-transform: uppercase;
}

.df-growth-dashboard-top strong {
    display: block;
    margin-top: 8px;
    color: #FFFFFF;
    font-size: 22px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -0.45px;
}

.df-growth-live-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    border-radius: 999px;
    background: rgba(116, 254, 148, 0.11);
    color: #DDFEE6;
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}

.df-growth-live-pill i {
    display: block;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--df-green);
    box-shadow: 0 0 18px rgba(116, 254, 148, 0.52);
}

.df-growth-kpi-grid {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr 0.85fr;
    gap: 12px;
    margin-bottom: 12px;
}

.df-growth-kpi {
    min-height: 132px;
    padding: 19px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 24px;
    background: rgba(0, 0, 0, 0.2);
}

.df-growth-kpi-1 {
    background:
        radial-gradient(circle at 86% 15%, rgba(116, 254, 148, 0.17), transparent 35%),
        rgba(116, 254, 148, 0.055);
    border-color: rgba(116, 254, 148, 0.16);
}

.df-growth-kpi span,
.df-growth-channel-row span,
.df-growth-experience-row span {
    display: block;
    color: var(--df-muted);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.35;
}

.df-growth-kpi strong {
    display: block;
    margin: 17px 0 12px;
    color: #FFFFFF;
    font-size: 36px;
    font-weight: 500;
    line-height: 0.95;
    letter-spacing: -1px;
}

.df-growth-kpi em {
    display: block;
    color: #D9E0DB;
    font-size: 12px;
    font-style: normal;
    font-weight: 300;
    line-height: 1.35;
}

.df-growth-main-panel,
.df-growth-channel-panel,
.df-growth-experience-panel,
.df-growth-action-card,
.df-growth-insight-card {
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(0, 0, 0, 0.22);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
}

.df-growth-main-panel {
    min-height: 300px;
    padding: 20px;
    border-radius: 28px;
}

.df-growth-chart-head,
.df-growth-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.df-growth-chart-head strong,
.df-growth-panel-head strong {
    display: block;
    margin-top: 8px;
    color: #FFFFFF;
    font-size: 15px;
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: -0.25px;
}

.df-growth-chart-head em {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 58px;
    height: 34px;
    border-radius: 999px;
    background: var(--df-green);
    color: #000000;
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: 1;
}

.df-growth-chart {
    position: relative;
    overflow: hidden;
    margin-top: 16px;
    height: 204px;
    border-radius: 22px;
    background:
        linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.028) 1px, transparent 1px),
        rgba(255, 255, 255, 0.025);
    background-size: 48px 48px;
}

.df-growth-chart svg {
    width: 100%;
    height: 100%;
    display: block;
}

.df-growth-area {
    fill: url(#df-growth-fill);
}

.df-growth-grid-line {
    fill: none;
    stroke: rgba(255, 255, 255, 0.08);
    stroke-width: 1;
}

.df-growth-line {
    fill: none;
    stroke: var(--df-green);
    stroke-width: 4;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 100;
    stroke-dashoffset: calc(100 - var(--df-growth-curve));
    filter: drop-shadow(0 0 10px rgba(116, 254, 148, 0.34));
}

.df-growth-dot {
    fill: #080A09;
    stroke: var(--df-green);
    stroke-width: 3;
}

.df-growth-dot-4 {
    fill: var(--df-green);
}

.df-growth-dashboard-bottom {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: 12px;
    margin-top: 12px;
}

.df-growth-channel-panel,
.df-growth-experience-panel {
    min-height: 218px;
    padding: 18px;
    border-radius: 26px;
}

.df-growth-channel-list,
.df-growth-experience-list {
    display: grid;
    gap: 9px;
    margin-top: 18px;
}

.df-growth-channel-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 12px;
    align-items: center;
    padding: 11px 12px;
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.045);
}

.df-growth-channel-row strong,
.df-growth-channel-row em {
    color: #FFFFFF;
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}

.df-growth-channel-row em {
    color: var(--df-green);
}

.df-growth-experience-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 9px;
}

.df-growth-experience-row div {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
}

.df-growth-experience-row strong {
    color: #FFFFFF;
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}

.df-growth-experience-row i {
    display: block;
    overflow: hidden;
    height: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.07);
}

.df-growth-experience-row i::before {
    content: "";
    display: block;
    width: var(--df-growth-fill);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(116, 254, 148, 0.36), var(--df-green));
    transform: scaleX(calc(var(--df-growth-curve) / 100));
    transform-origin: left center;
}

.df-growth-insight-rail {
    display: grid;
    gap: 14px;
}

.df-growth-action-card {
    position: relative;
    overflow: hidden;
    min-height: 292px;
    padding: 24px;
    border-color: rgba(116, 254, 148, 0.16);
    border-radius: 30px;
    background:
        radial-gradient(circle at 85% 15%, rgba(116, 254, 148, 0.14), transparent 34%),
        rgba(116, 254, 148, 0.055);
    transform: translate3d(0, var(--df-growth-card-a), 0);
    transition: transform 120ms linear;
}

.df-growth-action-icon,
.df-growth-insight-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 16px;
    background: rgba(116, 254, 148, 0.1);
    color: var(--df-green);
}

.df-growth-action-icon svg,
.df-growth-insight-icon svg {
    width: 20px;
    height: 20px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.df-growth-action-card > div {
    margin-top: 20px;
}

.df-growth-action-card > div > span {
    color: var(--df-green);
}

.df-growth-action-card strong {
    display: block;
    max-width: 310px;
    margin-top: 10px;
    color: #FFFFFF;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.12;
    letter-spacing: -0.55px;
}

.df-growth-action-card ul {
    display: grid;
    gap: 9px;
    margin: 22px 0 0;
    padding: 0;
    list-style: none;
}

.df-growth-action-card li {
    position: relative;
    margin: 0;
    padding: 13px 14px 13px 34px;
    border-radius: 16px;
    background: rgba(0, 0, 0, 0.22);
    color: #D9E0DB;
    font-size: 13px;
    font-weight: 300;
    line-height: 1.45;
}

.df-growth-action-card li::before {
    content: "";
    position: absolute;
    left: 14px;
    top: 19px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--df-green);
    box-shadow: 0 0 14px rgba(116, 254, 148, 0.45);
}

.df-growth-insight-card {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: 15px;
    min-height: 148px;
    padding: 20px;
    border-radius: 26px;
    background: rgba(255, 255, 255, 0.045);
}

.df-growth-insight-1,
.df-growth-insight-3 {
    transform: translate3d(0, var(--df-growth-card-b), 0);
    transition: transform 120ms linear;
}

.df-growth-insight-2 {
    transform: translate3d(0, calc(var(--df-growth-card-b) * -1), 0);
    transition: transform 120ms linear;
}

.df-growth-insight-card h3 {
    margin: 10px 0 8px;
    color: #FFFFFF;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: -0.35px;
}

.df-growth-insight-card p {
    margin: 0;
    color: var(--df-muted);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.6;
}

@media (max-width: 1120px) {
    .df-growth-header,
    .df-growth-stage {
        grid-template-columns: 1fr;
    }

    .df-growth-intro {
        max-width: 680px;
    }

    .df-growth-insight-rail {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .df-growth-action-card {
        grid-row: span 2;
    }
}

@media (max-width: 980px) {
    .df-growth-section {
        padding: 102px 24px;
    }

    .df-growth-title {
        font-size: 40px;
    }

    .df-growth-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .df-growth-kpi strong {
        font-size: 30px;
    }
}

@media (max-width: 760px) {
    .df-growth-section {
        padding: 84px 20px;
    }

    .df-growth-header {
        margin-bottom: 38px;
    }

    .df-growth-title {
        font-size: 32px;
        line-height: 1.08;
    }

    .df-growth-stage,
    .df-growth-kpi-grid,
    .df-growth-dashboard-bottom,
    .df-growth-insight-rail {
        gap: 12px;
        grid-template-columns: 1fr;
    }

    .df-growth-dashboard,
    .df-growth-action-card,
    .df-growth-insight-1,
    .df-growth-insight-2,
    .df-growth-insight-3 {
        transform: none;
    }

    .df-growth-dashboard {
        min-height: auto;
        padding: 16px;
        border-radius: 30px;
    }

    .df-growth-dashboard::before {
        border-radius: 29px;
    }

    .df-growth-dashboard-top,
    .df-growth-chart-head,
    .df-growth-panel-head {
        display: grid;
    }

    .df-growth-live-pill,
    .df-growth-chart-head em {
        width: fit-content;
    }

    .df-growth-kpi {
        min-height: auto;
        padding: 17px;
        border-radius: 22px;
    }

    .df-growth-kpi strong {
        margin: 14px 0 10px;
        font-size: 32px;
    }

    .df-growth-main-panel,
    .df-growth-channel-panel,
    .df-growth-experience-panel {
        padding: 16px;
        border-radius: 24px;
    }

    .df-growth-chart {
        height: 172px;
    }

    .df-growth-channel-row {
        grid-template-columns: 1fr auto;
    }

    .df-growth-channel-row em {
        grid-column: 2;
    }

    .df-growth-action-card {
        min-height: auto;
        padding: 20px;
        border-radius: 26px;
    }

    .df-growth-action-card strong {
        font-size: 22px;
    }

    .df-growth-insight-card {
        min-height: auto;
        border-radius: 24px;
    }
}

@media (max-width: 520px) {
    .df-growth-dashboard-top {
        padding: 6px 4px 16px;
    }

    .df-growth-kpi-grid,
    .df-growth-dashboard-bottom,
    .df-growth-insight-rail {
        gap: 10px;
    }

    .df-growth-insight-card {
        grid-template-columns: 1fr;
    }
}

/* Final CTA */
.df-final-cta-section,
.df-final-cta-section * {
    box-sizing: border-box;
}

.df-final-cta-section {
    --df-green: #74FE94;
    --df-black: #000000;
    --df-ink: #080A09;
    --df-muted-dark: #4E5650;
    --df-muted: #6D756F;
    --df-border-light: rgba(8, 10, 9, 0.08);

    position: relative;
    overflow: hidden;
    isolation: isolate;
    width: 100%;
    padding: 112px 24px;
    background: linear-gradient(180deg, #F6F8F6 0%, #FFFFFF 58%, #F4F6F4 100%);
    color: var(--df-ink);
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.df-final-cta-bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at 16% 18%, rgba(116, 254, 148, 0.16), transparent 28%),
        radial-gradient(circle at 84% 72%, rgba(8, 10, 9, 0.055), transparent 30%);
}

.df-final-cta-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(8, 10, 9, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(8, 10, 9, 0.035) 1px, transparent 1px);
    background-size: 92px 92px;
    mask-image: linear-gradient(180deg, transparent, black 20%, black 76%, transparent);
    opacity: 0.4;
}

.df-final-cta-wrap {
    width: min(1180px, 100%);
    margin: 0 auto;
}

.df-final-cta-card {
    position: relative;
    overflow: hidden;
    max-width: 1050px;
    margin: 0 auto;
    padding: clamp(46px, 6vw, 74px);
    border: 1px solid var(--df-border-light);
    border-radius: 38px;
    background:
        linear-gradient(135deg, rgba(116, 254, 148, 0.12), rgba(255, 255, 255, 0) 38%),
        #FFFFFF;
    text-align: center;
    box-shadow: 0 28px 80px rgba(8, 10, 9, 0.08);
}

.df-final-cta-card::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 0;
    width: min(520px, 72%);
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(116, 254, 148, 0.82), transparent);
    transform: translateX(-50%);
}

.df-final-cta-card::after {
    content: "";
    position: absolute;
    right: -120px;
    bottom: -150px;
    width: 360px;
    height: 360px;
    border-radius: 999px;
    background: rgba(116, 254, 148, 0.12);
    filter: blur(2px);
    pointer-events: none;
}

.df-final-cta-eyebrow {
    color: #080A09;
}

.df-final-cta-title {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
    color: #080A09;
}

.df-final-cta-body {
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
    color: var(--df-muted-dark);
}

.df-final-cta-actions {
    position: relative;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    margin-top: 34px;
}

.df-final-cta-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 52px;
    padding: 0 20px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    text-decoration: none;
    transition: transform 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.df-final-cta-button svg,
.df-final-cta-proof svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.df-final-cta-button svg {
    transition: transform 180ms ease;
}

.df-final-cta-button:hover {
    transform: translateY(-1px);
}

.df-final-cta-button:hover svg {
    transform: translateX(2px);
}

.df-final-cta-button-primary {
    border: 1px solid var(--df-green);
    background: var(--df-green);
    color: #000000;
    box-shadow: 0 18px 34px rgba(116, 254, 148, 0.18);
}

.df-final-cta-button-primary:hover {
    box-shadow: 0 22px 42px rgba(116, 254, 148, 0.22);
}

.df-final-cta-button-secondary {
    border: 1px solid rgba(8, 10, 9, 0.12);
    background: #FFFFFF;
    color: #080A09;
}

.df-final-cta-button-secondary:hover {
    border-color: rgba(8, 10, 9, 0.22);
    background: #F7F9F7;
}

.df-final-cta-proof {
    position: relative;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-top: 26px;
}

.df-final-cta-proof span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(8, 10, 9, 0.045);
    color: #4E5650;
    font-size: 12px;
    font-weight: 300;
    line-height: 1;
}

.df-final-cta-proof svg {
    width: 14px;
    height: 14px;
    color: #080A09;
}

@media (max-width: 980px) {
    .df-final-cta-section {
        padding: 96px 24px;
    }

    .df-final-cta-title {
        font-size: 40px;
    }
}

@media (max-width: 720px) {
    .df-final-cta-section {
        padding: 78px 20px;
    }

    .df-final-cta-card {
        padding: 38px 24px;
        border-radius: 30px;
    }

    .df-final-cta-title {
        font-size: 32px;
        line-height: 1.08;
    }

    .df-final-cta-actions {
        display: grid;
        grid-template-columns: 1fr;
        margin-top: 28px;
    }

    .df-final-cta-button {
        width: 100%;
    }

    .df-final-cta-proof {
        display: grid;
        grid-template-columns: 1fr;
        justify-items: stretch;
    }

    .df-final-cta-proof span {
        justify-content: center;
    }
}

/* =========================================================
   START: DockFlow global footer shortcode
   Shortcode: [df_footer]
   ========================================================= */

.df-site-footer,
.df-site-footer * {
    box-sizing: border-box;
}

.df-site-footer {
    --df-footer-green: #74FE94;
    --df-footer-black: #000000;
    --df-footer-panel: #080A09;
    --df-footer-soft: #111411;
    --df-footer-border: #222822;
    --df-footer-muted: #A8B0AA;

    position: relative;
    overflow: hidden;
    isolation: isolate;
    width: 100%;
    background: #000000;
    color: #FFFFFF;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.df-site-footer-bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at 18% 18%, rgba(116, 254, 148, 0.10), transparent 34%),
        radial-gradient(circle at 82% 80%, rgba(116, 254, 148, 0.07), transparent 36%),
        linear-gradient(180deg, #080A09 0%, #000000 52%, #000000 100%);
}

.df-site-footer-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
    background-size: 96px 96px;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.42), transparent 72%);
    opacity: 0.28;
}

.df-site-footer-inner {
    width: min(1280px, 88%);
    margin: 0 auto;
    padding: 82px 0 30px;
}

.df-site-footer-main {
    display: grid;
    grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
    gap: clamp(56px, 7vw, 112px);
    align-items: start;
}

.df-site-footer-brand {
    max-width: 430px;
}

.df-site-footer-logo {
    display: inline-flex;
    align-items: center;
    width: 184px;
    max-width: 100%;
    margin-bottom: 28px;
    text-decoration: none;
}

.df-site-footer-logo img {
    display: block;
    width: 100%;
    height: auto;
}

.df-site-footer-copy {
    max-width: 410px;
    margin: 0;
    color: var(--df-footer-muted);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.75;
}

.df-site-footer-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.df-site-footer-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    text-decoration: none;
    transition: transform 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.df-site-footer-button svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    transition: transform 180ms ease;
}

.df-site-footer-button:hover {
    transform: translateY(-1px);
}

.df-site-footer-button:hover svg {
    transform: translateX(2px);
}

.df-site-footer-button-primary {
    border: 1px solid var(--df-footer-green);
    background: var(--df-footer-green);
    color: #000000;
    box-shadow: 0 18px 40px rgba(116, 254, 148, 0.16);
}

.df-site-footer-button-primary:hover {
    box-shadow: 0 22px 48px rgba(116, 254, 148, 0.22);
}

.df-site-footer-button-secondary {
    border: 1px solid rgba(255, 255, 255, 0.13);
    background: rgba(255, 255, 255, 0.055);
    color: #FFFFFF;
}

.df-site-footer-button-secondary:hover {
    border-color: rgba(255, 255, 255, 0.24);
    background: rgba(255, 255, 255, 0.085);
}

.df-site-footer-nav {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(24px, 3vw, 44px);
}

.df-site-footer-column h2 {
    margin: 0 0 18px;
    color: #FFFFFF;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: -0.1px;
}

.df-site-footer-menu,
.df-site-footer .menu {
    display: grid;
    gap: 11px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.df-site-footer-menu li,
.df-site-footer .menu li {
    margin: 0;
    padding: 0;
    line-height: 1.2;
}

.df-site-footer-menu a,
.df-site-footer .menu a {
    display: inline-flex;
    align-items: center;
    color: var(--df-footer-muted);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.35;
    text-decoration: none;
    transition: color 180ms ease, transform 180ms ease;
}

.df-site-footer-menu a:hover,
.df-site-footer .menu a:hover {
    color: #FFFFFF;
    transform: translateX(2px);
}

.df-site-footer-bottom {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: center;
    margin-top: 72px;
    padding-top: 24px;
    border-top: 1px solid rgba(255, 255, 255, 0.09);
}

.df-site-footer-bottom p {
    margin: 0;
    color: rgba(168, 176, 170, 0.82);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.4;
}

.df-site-footer-legal {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 18px;
}

.df-site-footer-legal a {
    color: rgba(168, 176, 170, 0.82);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.4;
    text-decoration: none;
    transition: color 180ms ease;
}

.df-site-footer-legal a:hover {
    color: #FFFFFF;
}

@media (max-width: 1080px) {
    .df-site-footer-main {
        grid-template-columns: 1fr;
        gap: 56px;
    }

    .df-site-footer-brand {
        max-width: 620px;
    }

    .df-site-footer-copy {
        max-width: 560px;
    }
}

@media (max-width: 780px) {
    .df-site-footer-inner {
        width: 88%;
        padding: 68px 0 26px;
    }

    .df-site-footer-nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 34px 26px;
    }

    .df-site-footer-bottom {
        display: grid;
        gap: 16px;
        margin-top: 54px;
    }

    .df-site-footer-legal {
        justify-content: flex-start;
    }
}

@media (max-width: 520px) {
    .df-site-footer-inner {
        padding: 58px 0 24px;
    }

    .df-site-footer-logo {
        width: 166px;
    }

    .df-site-footer-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .df-site-footer-button {
        width: 100%;
    }

    .df-site-footer-nav {
        grid-template-columns: 1fr;
        gap: 30px;
    }
}

/* =========================================================
   END: DockFlow global footer shortcode
   ========================================================= */

/* =========================================================
   START: DockFlow pricing page shortcode
   ========================================================= */

.df-pricing-page,
.df-pricing-page * {
    box-sizing: border-box;
}

.df-pricing-page {
    --df-green: #74FE94;
    --df-green-dark: #0B5D25;
    --df-black: #000000;
    --df-ink: #ffffff;
    --df-panel: #080A09;
    --df-panel-soft: #111411;
    --df-muted: #A8B0AA;
    --df-border: #222822;
    --df-light: #F7FBF6;
    --df-light-soft: #EAF1EB;
    --df-light-text: #080A09;

    position: relative;
    overflow: hidden;
    isolation: isolate;
    width: 100%;
    display: block;
    min-height: 0;
    margin: 0;
    padding: 86px 24px 70px;
    background: #000000;
    color: #ffffff;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Neutralize default Divi wrapper spacing around the full Pricing shortcode. */
.et_pb_section:has(.df-pricing-page),
.et_pb_row:has(.df-pricing-page),
.et_pb_column:has(.df-pricing-page),
.et_pb_module:has(.df-pricing-page) {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.et_pb_section:has(.df-pricing-page),
.et_pb_row:has(.df-pricing-page) {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    background: #000000 !important;
}

.et_pb_row:has(.df-pricing-page) {
    width: 100% !important;
    max-width: 100% !important;
}

.et_pb_code:has(.df-pricing-page),
.et_pb_text:has(.df-pricing-page),
.et_pb_code_inner:has(.df-pricing-page),
.et_pb_text_inner:has(.df-pricing-page) {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    background: #000000 !important;
}

.df-pricing-bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at 50% 0%, rgba(116, 254, 148, 0.14), transparent 34%),
        radial-gradient(circle at 18% 15%, rgba(116, 254, 148, 0.08), transparent 30%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 14%),
        #000000;
}

.df-pricing-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.022) 1px, transparent 1px);
    background-size: 112px 112px;
    mask-image: radial-gradient(circle at 50% 10%, black, transparent 60%);
    opacity: 0.18;
}

.df-pricing-bg::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 0;
    width: min(920px, 86vw);
    height: 1px;
    transform: translateX(-50%);
    background: linear-gradient(90deg, transparent, rgba(116, 254, 148, 0.54), transparent);
    opacity: 0.6;
}

.df-pricing-shell {
    width: min(1180px, 100%);
    margin: 0 auto;
}

.df-pricing-hero {
    max-width: 920px;
    margin: 0 auto 70px;
    text-align: center;
}

.df-pricing-eyebrow {
    justify-content: center;
    margin-bottom: 18px;
}

.df-pricing-title {
    max-width: 920px;
    margin: 0 auto;
    color: var(--df-ink);
    font-size: 60px;
    font-weight: 500;
    line-height: 0.98;
    letter-spacing: -1.5px;
}

.df-pricing-lede {
    max-width: 730px;
    margin: 24px auto 0;
    color: var(--df-muted);
    font-size: 15px;
    font-weight: 300;
    line-height: 1.82;
}

.df-pricing-actions {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 32px;
}

.df-pricing-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 50px;
    padding: 0 20px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    text-decoration: none;
    transition: transform 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.df-pricing-button svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    transition: transform 180ms ease;
}

.df-pricing-button:hover {
    transform: translateY(-1px);
}

.df-pricing-button:hover svg {
    transform: translateX(2px);
}

.df-pricing-button-primary {
    border: 1px solid var(--df-green);
    background: var(--df-green);
    color: #000000;
    box-shadow: 0 18px 44px rgba(116, 254, 148, 0.16);
}

.df-pricing-button-primary:hover {
    color: #000000;
    box-shadow: 0 22px 52px rgba(116, 254, 148, 0.22);
}

.df-pricing-button-secondary {
    border: 1px solid rgba(255, 255, 255, 0.13);
    background: rgba(255, 255, 255, 0.055);
    color: #ffffff;
}

.df-pricing-button-secondary:hover {
    border-color: rgba(255, 255, 255, 0.24);
    background: rgba(255, 255, 255, 0.085);
    color: #ffffff;
}

.df-pricing-table-section {
    position: relative;
    scroll-margin-top: 96px;
}

.df-pricing-billing-input {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    opacity: 0;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
}

.df-pricing-table-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: end;
    margin-bottom: 28px;
}

.df-pricing-table-head h2 {
    max-width: 660px;
    margin: 0;
    color: #ffffff;
    font-size: 48px;
    font-weight: 500;
    line-height: 1.02;
    letter-spacing: -1px;
}

.df-pricing-billing {
    justify-self: end;
    text-align: center;
}

.df-pricing-billing-toggle {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.df-pricing-billing-toggle label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 17px;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.58);
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    user-select: none;
    transition: background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

#df-billing-yearly:checked ~ .df-pricing-table-head label[for="df-billing-yearly"],
#df-billing-monthly:checked ~ .df-pricing-table-head label[for="df-billing-monthly"] {
    background: #ffffff;
    color: #000000;
    box-shadow: 0 12px 34px rgba(0, 0, 0, 0.2);
}

.df-pricing-billing p {
    max-width: 380px;
    margin: 12px 0 0;
    color: rgba(168, 176, 170, 0.82);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.55;
}

.df-pricing-plans {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    align-items: stretch;
}

.df-pricing-plan {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border: 1px solid rgba(8, 10, 9, 0.1);
    border-radius: 30px;
    background: linear-gradient(180deg, #FFFFFF, #F3F7F2);
    color: #080A09;
    box-shadow: 0 28px 74px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.92);
    overflow: hidden;
}

.df-pricing-plan::before {
    content: "";
    position: absolute;
    left: 22px;
    right: 22px;
    top: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(116, 254, 148, 0.55), transparent);
    opacity: 0.48;
}

.df-pricing-plan-featured {
    transform: translateY(-18px);
    border-color: rgba(116, 254, 148, 0.64);
    box-shadow:
        0 34px 92px rgba(0, 0, 0, 0.42),
        0 0 0 1px rgba(116, 254, 148, 0.22),
        0 0 72px rgba(116, 254, 148, 0.13),
        inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.df-pricing-popular-band {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    background:
        radial-gradient(circle at 50% -40%, rgba(255, 255, 255, 0.42), transparent 44%),
        var(--df-green);
    color: #000000;
    font-size: 11px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.df-pricing-plan-inner {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    padding: 28px 24px 24px;
}

.df-pricing-plan-featured .df-pricing-plan-inner {
    padding-top: 24px;
}

.df-pricing-plan-top {
    min-height: 170px;
}

.df-pricing-plan-kicker {
    display: inline-flex;
    align-items: center;
    color: var(--df-green-dark);
    font-size: 12px;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.df-pricing-plan h3 {
    margin: 16px 0 0;
    color: #000000;
    font-size: 32px;
    font-weight: 500;
    line-height: 1.05;
    letter-spacing: -0.7px;
}

.df-pricing-plan-top p {
    margin: 15px 0 0;
    color: rgba(8, 10, 9, 0.68);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.62;
}

.df-pricing-plan-price {
    margin-top: 4px;
    padding: 20px 0;
    border-top: 1px solid rgba(8, 10, 9, 0.1);
    border-bottom: 1px solid rgba(8, 10, 9, 0.1);
}

.df-pricing-price-option {
    display: none;
}

#df-billing-yearly:checked ~ .df-pricing-plans .df-price-yearly,
#df-billing-monthly:checked ~ .df-pricing-plans .df-price-monthly {
    display: block;
}

.df-pricing-plan-price strong {
    display: block;
    color: #000000;
    font-size: 42px;
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.95px;
}

.df-pricing-plan-price strong span {
    display: inline;
    margin-left: 4px;
    color: rgba(8, 10, 9, 0.62);
    font-size: 13px;
    font-weight: 300;
    letter-spacing: -0.1px;
}

.df-pricing-plan-price small {
    display: block;
    margin-top: 10px;
    color: rgba(8, 10, 9, 0.58);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.35;
}

.df-pricing-card-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    margin: 22px 0 0;
    border: 1px solid rgba(8, 10, 9, 0.18);
    border-radius: 999px;
    background: #ffffff;
    color: #000000;
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    text-decoration: none;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
    transition: transform 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.df-pricing-plan-featured .df-pricing-card-cta {
    border-color: var(--df-green);
    background: var(--df-green);
    color: #000000;
    box-shadow: 0 18px 42px rgba(116, 254, 148, 0.22);
}

.df-pricing-card-cta:hover {
    transform: translateY(-1px);
    border-color: rgba(8, 10, 9, 0.3);
    background: #F7FBF6;
    color: #000000;
}

.df-pricing-plan-featured .df-pricing-card-cta:hover {
    border-color: var(--df-green);
    background: var(--df-green);
    box-shadow: 0 22px 52px rgba(116, 254, 148, 0.28);
}

.df-pricing-feature-list {
    display: grid;
    gap: 12px;
    margin: 24px 0 0;
    padding: 0;
    list-style: none;
}

.df-pricing-feature-list li {
    display: grid;
    grid-template-columns: 18px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    margin: 0;
    padding: 0;
    color: rgba(8, 10, 9, 0.78);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.45;
}

.df-pricing-feature-list i {
    position: relative;
    display: block;
    width: 18px;
    height: 18px;
    margin-top: 1px;
    border: 1px solid rgba(11, 93, 37, 0.24);
    border-radius: 999px;
    background: rgba(116, 254, 148, 0.2);
}

.df-pricing-feature-list i::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 4px;
    width: 6px;
    height: 4px;
    border-left: 1.5px solid var(--df-green-dark);
    border-bottom: 1.5px solid var(--df-green-dark);
    transform: rotate(-45deg);
}

.df-pricing-faq-section,
.df-pricing-final-cta {
    margin-top: 82px;
}

.df-pricing-section-head {
    max-width: 760px;
}

.df-pricing-section-head-row {
    display: grid;
    grid-template-columns: minmax(0, 0.86fr) minmax(280px, 0.58fr);
    gap: clamp(28px, 5vw, 70px);
    align-items: end;
    max-width: none;
}

.df-pricing-section-head h2,
.df-pricing-final-cta h2 {
    margin: 0;
    color: #ffffff;
    font-size: 48px;
    font-weight: 500;
    line-height: 1.02;
    letter-spacing: -1px;
}

.df-pricing-section-head p:not(.df-section-eyebrow),
.df-pricing-final-cta p:not(.df-section-eyebrow) {
    max-width: 610px;
    margin: 20px 0 0;
    color: var(--df-muted);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.8;
}

.df-pricing-section-head-row > p {
    margin: 0;
}

.df-pricing-faq-list {
    display: grid;
    gap: 10px;
    margin-top: 30px;
}

.df-pricing-faq-list details {
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.04);
    overflow: hidden;
}

.df-pricing-faq-list summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    min-height: 70px;
    padding: 0 22px;
    color: #ffffff;
    font-size: 15px;
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: -0.18px;
    list-style: none;
    cursor: pointer;
}

.df-pricing-faq-list summary::-webkit-details-marker {
    display: none;
}

.df-pricing-faq-list summary i {
    position: relative;
    flex: 0 0 auto;
    width: 28px;
    height: 28px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.16);
}

.df-pricing-faq-list summary i::before,
.df-pricing-faq-list summary i::after {
    content: "";
    position: absolute;
    left: 8px;
    top: 13px;
    width: 10px;
    height: 1px;
    background: rgba(255, 255, 255, 0.72);
    transition: transform 180ms ease;
}

.df-pricing-faq-list summary i::after {
    transform: rotate(90deg);
}

.df-pricing-faq-list details[open] summary i::after {
    transform: rotate(0deg);
}

.df-pricing-faq-list details[open] {
    border-color: rgba(116, 254, 148, 0.18);
    background: rgba(116, 254, 148, 0.035);
}

.df-pricing-faq-list details p {
    max-width: 840px;
    margin: 0;
    padding: 0 22px 22px;
    color: var(--df-muted);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.76;
}

.df-pricing-final-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 34px;
    align-items: center;
    padding: 38px;
    border: 1px solid rgba(116, 254, 148, 0.18);
    border-radius: 38px;
    background:
        radial-gradient(circle at 84% 16%, rgba(116, 254, 148, 0.16), transparent 36%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.065), 0 34px 96px rgba(0, 0, 0, 0.34);
}

.df-pricing-final-cta h2 {
    max-width: 760px;
}

.df-pricing-final-cta p:not(.df-section-eyebrow) {
    max-width: 650px;
}

@media (max-width: 1120px) {
    .df-pricing-title {
        font-size: 48px;
    }

    .df-pricing-plans {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .df-pricing-plan-featured {
        transform: none;
    }

    .df-pricing-plan-top {
        min-height: 150px;
    }
}

@media (max-width: 900px) {
    .df-pricing-page {
        padding: 72px 24px 62px;
    }

    .df-pricing-table-head,
    .df-pricing-section-head-row,
    .df-pricing-final-cta {
        grid-template-columns: 1fr;
    }

    .df-pricing-table-head {
        align-items: start;
    }

    .df-pricing-billing {
        justify-self: start;
        text-align: left;
    }

    .df-pricing-section-head h2,
    .df-pricing-table-head h2,
    .df-pricing-final-cta h2 {
        font-size: 40px;
    }

    .df-pricing-section-head-row > p {
        max-width: 640px;
    }

    .df-pricing-final-cta .df-pricing-button {
        justify-self: start;
    }
}

@media (max-width: 680px) {
    .df-pricing-page {
        padding: 62px 18px 54px;
    }

    .df-pricing-hero {
        margin-bottom: 54px;
    }

    .df-pricing-title {
        font-size: 32px;
        line-height: 1.05;
        letter-spacing: -1px;
    }

    .df-pricing-lede {
        font-size: 14px;
    }

    .df-pricing-actions,
    .df-pricing-button {
        width: 100%;
    }

    .df-pricing-billing-toggle {
        width: 100%;
    }

    .df-pricing-billing,
    .df-pricing-billing-toggle label {
        width: 100%;
    }

    .df-pricing-plans {
        grid-template-columns: 1fr;
    }

    .df-pricing-plan-inner {
        padding: 24px 20px 22px;
    }

    .df-pricing-plan-top {
        min-height: auto;
    }

    .df-pricing-plan h3 {
        font-size: 28px;
    }

    .df-pricing-plan-price strong {
        font-size: 36px;
    }

    .df-pricing-faq-section,
    .df-pricing-final-cta {
        margin-top: 64px;
    }

    .df-pricing-final-cta {
        padding: 24px;
        border-radius: 30px;
    }

    .df-pricing-section-head h2,
    .df-pricing-table-head h2,
    .df-pricing-final-cta h2 {
        font-size: 32px;
        line-height: 1.08;
    }

    .df-pricing-faq-list summary {
        min-height: 66px;
        padding: 0 18px;
        font-size: 14px;
    }

    .df-pricing-faq-list details p {
        padding: 0 18px 20px;
    }
}

/* =========================================================
   END: DockFlow pricing page shortcode
   ========================================================= */


