/* Yoyatta Marketing Styles — Clean, merged (final)
   Signature: Daijin
   Notes:
   - ONE source of truth for hero reel tiles (fill via cover + top anchor, no letterboxing)
   - Duplicate/legacy hero rules removed
   - Tweak --hero-tile to resize tiles
*/

/* =========================
   Root tokens
   ========================= */
:root {
    --bg: #0b1220;
    --bg-2: #0e1326;
    --card: #11182b;
    --text: #e6ebff;
    --muted: #9fb2ffcc;
    --accent: #7aa2ff;
    --accent-2: #b388ff;
    --ring: #2a3b6b;
    --ok: #77ffcd;

    --radius-xl: 24px;
    --radius-lg: 18px;

    --shadow-1: 0 10px 30px rgba(0, 0, 0, .35);
    --shadow-2: 0 20px 60px rgba(0, 0, 0, .45);

    --maxw: 1280px;
    --speed: 800ms;
    --gap: 14px;
    --header-h: 64px;

    /* Images (cards) */
    --shot-ratio: 1242/2688;
    --img-fit: contain;
    --img-pos: center center;
    --img-bg: #000;
    --img-pad: 12px;

    /* Glass */
    --glass-bg: rgba(255, 255, 255, .06);
    --glass-stroke: rgba(255, 255, 255, .14);
    --glass-blur: 16px;

    /* Reels & cards */
    --reel-padding-x: clamp(24px, 10vw, 140px);
    --card-w: 360px;
    --pad-v: 22px;
    --pad-h: 20px;
    --text-pad-x: 20px;

    /* Flow switch */
    --flow-stick-top: calc(var(--header-h) + 10px);

    /* Hero tiles */
    --hero-tile: clamp(120px, 20vw, 160px);
    /* tile size */
    --hero-fit: cover;
    /* fill the square; crops sides as needed */
    --hero-pos: 50% 0%;
    /* top-center anchor */
}

@media (prefers-color-scheme:light) {
    :root {
        --bg: #f7f8fe;
        --bg-2: #f1f4ff;
        --card: #fff;
        --text: #0a0f1f;
        --muted: #4b587f;
        --ring: #dfe6ff;
        --shadow-1: 0 8px 26px rgba(14, 29, 77, .08);
        --shadow-2: 0 16px 52px rgba(14, 29, 77, .12);
        --glass-bg: rgba(255, 255, 255, .62);
        --glass-stroke: rgba(10, 15, 31, .08);
    }
}

/* =========================
   Base
   ========================= */
html,
body {
    margin: 0;
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    background:
        radial-gradient(1200px 800px at 20% -10%, rgba(122, 162, 255, .20), transparent 60%),
        radial-gradient(900px 600px at 80% 10%, rgba(179, 136, 255, .20), transparent 65%),
        var(--bg);
    color: var(--text);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    scroll-behavior: smooth;
}

.container {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 0 20px
}

/* Links */
a {
    color: var(--text);
    text-decoration: none
}

a:hover {
    text-decoration: underline
}

/* Header */
.header {
    position: sticky;
    top: 0;
    z-index: 40;
    backdrop-filter: saturate(180%) blur(10px);
    background: color-mix(in oklab, var(--bg), transparent 60%);
    border-bottom: 1px solid color-mix(in oklab, var(--ring), transparent 70%);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 64px
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: 700;
    letter-spacing: .1px
}

.brand img {
    width: 28px;
    height: 28px;
    border-radius: 8px
}

.nav {
    display: none;
    gap: 18px;
    align-items: center
}

.cta {
    display: flex;
    align-items: center;
    gap: 12px
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 40px;
    padding: 0 14px;
    border-radius: 12px;
    border: 0;
    background: linear-gradient(180deg, color-mix(in oklab, var(--accent), white 10%), var(--accent));
    color: #fff;
    font-weight: 600;
    box-shadow: var(--shadow-1)
}

.btn:hover {
    filter: brightness(1.03)
}

.badge {
    height: 40px;
    display: inline-block
}

@media (min-width:880px) {
    .nav {
        display: flex
    }
}

/* =========================
   Hero
   ========================= */
.hero {
    position: relative;
    overflow: clip;
    padding: 64px 0 24px
}

.hero h1 {
    font-size: clamp(32px, 5vw, 60px);
    line-height: 1.04;
    letter-spacing: -.02em;
    margin: 0
}

.hero p.lead {
    font-size: clamp(16px, 2.2vw, 22px);
    color: var(--muted);
    margin: 18px 0 26px
}

.chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px
}

.chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 1px solid var(--glass-stroke);
    background: var(--glass-bg);
    padding: 8px 12px;
    border-radius: 999px;
    font-weight: 600;
    backdrop-filter: blur(10px) saturate(140%);
    -webkit-backdrop-filter: blur(10px) saturate(140%)
}

/* =========================
   Generic Reel ("ticker")
   ========================= */
.reel {
    position: relative;
    border-bottom: 1px solid color-mix(in oklab, var(--ring), transparent 70%);
    background: color-mix(in oklab, var(--bg), transparent 30%);
}

.reel .container {
    max-width: var(--maxw)
}

.reel-viewport {
    overflow: hidden
}

.reel-track {
    display: inline-flex;
    gap: var(--gap);
    white-space: nowrap;
    align-items: center;
    padding: 10px 0;
    animation: reel-move 80s linear infinite;
    will-change: transform;
}

@keyframes reel-move {
    from {
        transform: translateX(0)
    }

    to {
        transform: translateX(-50%)
    }
}

@media (hover:hover) {
    .reel-viewport:hover .reel-track {
        animation-play-state: paused
    }
}

@media (prefers-reduced-motion:reduce) {
    .reel-track {
        animation: none
    }
}

/* Generic reel item (used outside hero) */
.reel:not(.reel-in-hero) .reel-item {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 12px;
    border-radius: 16px;
    font-weight: 700;
    font-size: 13.5px;
    letter-spacing: .2px;
    border: 1px solid var(--glass-stroke);
    background: var(--glass-bg);
    min-width: 220px;
    white-space: normal;
    text-align: center;
    box-shadow: var(--shadow-1);
    backdrop-filter: blur(var(--glass-blur)) saturate(140%);
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(140%);
}

/* =========================
   HERO — single source of truth (fill square, top-anchored)
   ========================= */
.reel.reel-in-hero .reel-track {
    gap: 10px
}

.reel.reel-in-hero .reel-item {
    position: relative;
    display: block;
    width: var(--hero-tile);
    height: var(--hero-tile);
    min-width: var(--hero-tile);
    min-height: var(--hero-tile);
    flex: 0 0 var(--hero-tile);
    border-radius: 20px;
    overflow: hidden;
    background: var(--img-bg);
    border: 1px solid color-mix(in oklab, var(--ring), transparent 40%);
    box-shadow: var(--shadow-1);
}

.reel.reel-in-hero .reel-item>img.tile-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: var(--hero-fit);
    /* cover */
    object-position: var(--hero-pos);
    /* top center */
    filter: brightness(.95) saturate(.92);
}

@media (hover:hover) {
    .reel.reel-in-hero .reel-item:hover .tile-img {
        filter: brightness(1) saturate(1)
    }
}

/* soft dark fade for label readability */
.reel.reel-in-hero .reel-item::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(to top, rgba(0, 0, 0, .55) 0%, rgba(0, 0, 0, .18) 40%, transparent 65%);
}

/* compact glass label */
.reel.reel-in-hero .tile-label {
    position: absolute;
    left: 8px;
    right: 8px;
    bottom: 8px;
    z-index: 1;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px solid var(--glass-stroke);
    background: color-mix(in oklab, var(--glass-bg), black 10%);
    font-weight: 800;
    letter-spacing: .2px;
    font-size: 12.5px;
    backdrop-filter: blur(var(--glass-blur)) saturate(140%);
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(140%);
}

@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))) {
    .reel.reel-in-hero .tile-label {
        background: rgba(0, 0, 0, .45)
    }
}

/* =========================
   Sections & cards
   ========================= */
.section {
    padding: 56px 0
}

.section h2 {
    font-size: clamp(26px, 3.2vw, 40px);
    letter-spacing: -.02em;
    margin: 0 0 12px
}

.section p.sub {
    color: var(--muted);
    margin: 8px 0 24px;
    font-size: 18px
}

.card {
    background: var(--glass-bg);
    border: 1px solid var(--glass-stroke);
    border-radius: var(--radius-xl);
    padding: var(--pad-v) var(--pad-h);
    box-shadow: var(--shadow-1);
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(var(--glass-blur)) saturate(140%);
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(140%);
    width: var(--card-w);
    box-sizing: border-box;
    transform: scale(var(--scale, .90));
    transition: transform 340ms cubic-bezier(.2, .8, .2, 1), box-shadow 300ms ease, border-color 200ms ease;
    scroll-snap-align: center;
    margin: 0 auto;
}

.card h3 {
    margin: 6px 0 8px;
    font-size: 20px;
    position: relative
}

.card p {
    margin: 0;
    color: var(--muted)
}

.card .card-icon img {
    width: 20px;
    height: 20px;
    display: block
}

/* media area inside card */
.media {
    border-radius: 14px;
    overflow: hidden;
    margin-top: 12px;
    background: var(--img-bg);
    aspect-ratio: var(--shot-ratio);
    width: calc(var(--card-w) - 2*var(--pad-h));
    margin-left: auto;
    margin-right: auto;
    padding: var(--img-pad);
    box-sizing: border-box;
}

.media img {
    width: 100%;
    height: 100%;
    object-fit: var(--img-fit);
    object-position: var(--img-pos);
    display: block;
    filter: brightness(var(--dim, .92)) saturate(var(--sat, .80));
    transition: filter 300ms ease;
    border-radius: max(0px, calc(14px - var(--img-pad)));
}

.is-center {
    --scale: 1;
    --dim: 1;
    --sat: 1;
    box-shadow: var(--shadow-2);
    border-color: color-mix(in oklab, var(--accent), white 30%)
}

/* Title badges */
.card h3::before {
    content: "";
    display: inline-block;
    margin-right: 8px;
    padding: 2px 8px;
    border-radius: 999px;
    border: 1px solid var(--glass-stroke);
    background: var(--glass-bg);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .2px;
    vertical-align: middle;
}

.card[data-tags*="host"] h3::before {
    content: "Host"
}

.card[data-tags*="booker"] h3::before {
    content: "Booker"
}

.card[data-tags*="forms"] h3::before {
    content: "Forms"
}

.card[data-tags*="security"] h3::before {
    content: "Security"
}

/* =========================
   Horizontal reel (cards)
   ========================= */
.row-reel {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    position: relative
}

.row-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    gap: calc(var(--gap) + 6px);
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    scroll-snap-stop: always;
    -webkit-overflow-scrolling: touch;
    padding-block: 10px 26px;
    padding-inline: max(calc((100vw - var(--card-w))/2), 16px);
}

.row-track::-webkit-scrollbar {
    height: 10px
}

.row-track::-webkit-scrollbar-thumb {
    background: color-mix(in oklab, var(--ring), white 6%);
    border-radius: 999px
}

/* Step pill */
.step .step-num {
    position: absolute;
    top: 14px;
    left: var(--pad-h);
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid var(--glass-stroke);
    background: var(--glass-bg);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .2px;
}

/* =========================
   BIG sticky flow switch
   ========================= */
.flow-switch {
    position: sticky;
    top: var(--flow-stick-top);
    z-index: 35;
    margin: 8px 0 14px;
    display: grid;
    justify-content: center;
    gap: 10px
}

.seg {
    display: inline-flex;
    background: var(--glass-bg);
    border: 1px solid var(--glass-stroke);
    padding: 4px;
    border-radius: 999px;
    box-shadow: var(--shadow-1);
    backdrop-filter: blur(10px) saturate(140%);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
}

.seg.seg-xl {
    position: relative;
    gap: 4px;
    padding: 6px;
    border-radius: 999px;
    background:
        radial-gradient(160% 140% at 20% 0%, rgba(255, 255, 255, .12), transparent 60%),
        linear-gradient(180deg, color-mix(in oklab, var(--card), white 10%), color-mix(in oklab, var(--card), black 6%));
    border: 1px solid color-mix(in oklab, var(--ring), transparent 25%);
    box-shadow: 0 10px 30px rgba(0, 0, 0, .35), inset 0 0 0 1px rgba(255, 255, 255, .06);
}

.seg.seg-xl .seg-thumb {
    position: absolute;
    inset: 6px auto 6px 6px;
    border-radius: 999px;
    pointer-events: none;
    background:
        radial-gradient(140% 140% at 30% 20%, rgba(255, 255, 255, .22), transparent 60%),
        linear-gradient(180deg, color-mix(in oklab, var(--accent), white 20%), color-mix(in oklab, var(--accent), black 4%));
    box-shadow: 0 8px 28px color-mix(in oklab, var(--accent), black 40%), inset 0 0 0 1px rgba(255, 255, 255, .12);
    height: calc(100% - 12px);
    width: 0;
    transition: transform .28s cubic-bezier(.2, .7, .2, 1), width .28s cubic-bezier(.2, .7, .2, 1);
}

@media (prefers-reduced-motion:reduce) {
    .seg.seg-xl .seg-thumb {
        transition: none
    }
}

.seg button {
    appearance: none;
    border: 0;
    margin: 0;
    padding: 12px 18px;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: .2px;
    color: var(--muted);
    background: transparent;
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}

.seg button .ico {
    width: 22px;
    height: 22px;
    filter: drop-shadow(0 1px 3px rgba(0, 0, 0, .35))
}

.seg button[aria-selected="true"] {
    color: var(--text)
}

.flow-jump {
    justify-self: center;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 14px;
    border-radius: 999px;
    border: 1px solid var(--glass-stroke);
    background: var(--glass-bg);
    font-weight: 800;
    letter-spacing: .2px;
    box-shadow: var(--shadow-1);
    backdrop-filter: blur(10px) saturate(140%);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
    cursor: pointer;
}

/* =========================
   Reel controls (icon-only)
   ========================= */
.reel-controls {
    width: min(100%, var(--maxw));
    margin: 6px auto 10px;
    padding: 0 20px;
    display: flex;
    justify-content: center;
    gap: 10px;
}

.reel-nav-btn {
    display: inline-grid;
    place-items: center;
    width: 60px;
    height: 60px;
    padding: 0;
    border-radius: 999px;
    position: relative;
    overflow: hidden;
    border: 1px solid color-mix(in oklab, var(--accent), white 30%);
    background:
        radial-gradient(140% 140% at 30% 20%, rgba(255, 255, 255, .16), transparent 60%),
        linear-gradient(180deg, color-mix(in oklab, var(--accent), white 18%), color-mix(in oklab, var(--accent), black 4%));
    box-shadow: 0 6px 20px rgba(0, 0, 0, .35), inset 0 0 0 1px rgba(255, 255, 255, .10);
    transition: transform .15s ease, box-shadow .3s ease, border-color .2s ease, filter .2s ease;
    cursor: pointer;
}

.reel-nav-btn .ico {
    width: 35px;
    height: 35px;
    filter: drop-shadow(0 2px 6px rgba(0, 0, 0, .35))
}

.reel-nav-btn:hover {
    box-shadow: 0 10px 30px rgba(122, 162, 255, .35), inset 0 0 0 1px rgba(255, 255, 255, .14);
    border-color: color-mix(in oklab, var(--accent), white 45%);
}

.reel-nav-btn:active {
    transform: translateY(.5px) scale(.98)
}

.reel-nav-btn::after {
    content: "";
    position: absolute;
    inset: -60% -30%;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, .65) 45%, rgba(255, 255, 255, .15) 60%, transparent 100%);
    transform: translateX(-100%) rotate(12deg);
    pointer-events: none;
}

.reel-nav-btn:hover::after {
    animation: sheen 900ms cubic-bezier(.2, .6, .2, 1) forwards
}

@keyframes sheen {
    to {
        transform: translateX(120%) rotate(12deg)
    }
}

.reel-nav-btn[disabled] {
    opacity: .35;
    filter: grayscale(.25);
    box-shadow: none;
    cursor: default
}

/* =========================
   Footer & helpers
   ========================= */
.hero .reveal,
.section .reveal {
    transition: transform var(--speed) cubic-bezier(.2, .8, .2, 1), opacity var(--speed) ease;
}

.js-enabled .reveal {
    transform: translateY(18px);
    opacity: 0
}

.js-enabled .reveal.in {
    transform: translateY(0);
    opacity: 1
}

.footer {
    border-top: 1px solid color-mix(in oklab, var(--ring), transparent 70%);
    padding: 30px 0 50px;
    color: var(--muted);
    font-size: 14px
}

.footer a {
    color: inherit;
    text-decoration: underline
}

.skip-link {
    position: absolute;
    left: -999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden
}

.skip-link:focus {
    position: fixed;
    left: 20px;
    top: 20px;
    width: auto;
    height: auto;
    padding: 10px 12px;
    background: var(--card);
    color: var(--text);
    border-radius: 10px;
    z-index: 100;
    outline: 2px solid var(--ring)
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0
}

/* Fallback (no backdrop-filter) */
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))) {

    .card,
    .reel-item,
    .chip {
        background: color-mix(in oklab, var(--card), white 10%);
        border-color: color-mix(in oklab, var(--ring), transparent 30%);
    }
}

/* Motion reductions */
@media (prefers-reduced-motion:reduce) {
    .card {
        transform: none !important
    }

    .media img {
        filter: none !important
    }

    .reel-viewport .reel-track {
        animation: none
    }
}

/* Small phones: adapt card width */
@media (max-width:480px) {
    :root {
        --card-w: 86vw
    }
}

/* Avoid double inner padding for text (cards already have pad-h) */
.card .card-icon,
.card h3,
.card p {
    padding-left: 0;
    padding-right: 0
}

/* Tap-to-select affordance */
.row-track .card {
    cursor: pointer;
    -webkit-tap-highlight-color: transparent
}

/* Selected state */
.card.is-selected {
    outline: 2px solid color-mix(in oklab, var(--accent), white 40%);
    outline-offset: -2px;
    box-shadow: var(--shadow-2);
}

/* =========================
   Section-specific tweaks
   ========================= */
#security .row-reel {
    width: auto;
    margin-left: 0;
    margin-right: 0
}

#security .row-track {
    display: block;
    overflow: visible;
    scroll-snap-type: none;
    padding: 0
}

#security .row-track .card {
    width: min(720px, 100%);
    margin: 12px auto 0
}

/* Bottom CTA — Daijin */
.bottom-cta {
    padding: 56px 0;
    margin-top: 48px;
    background: linear-gradient(180deg, color-mix(in oklab, #7aa2ff 15%, transparent), transparent 40%),
        color-mix(in oklab, var(--bg, #0b1220) 94%, black 6%);
    border-top: 1px solid color-mix(in oklab, white 8%, transparent);
}

.bottom-cta-inner {
    display: flex;
    gap: clamp(24px, 4vw, 48px);
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap
}

.bottom-cta-copy {
    max-width: 820px
}

.bottom-cta .brand-mini {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 800;
    font-size: 1.25rem
}

.bottom-cta .brand-mini img {
    width: 28px;
    height: 28px;
    border-radius: 6px
}

.bottom-cta .tagline {
    margin: .25rem 0 1rem;
    font-size: 1.125rem;
    opacity: .9
}

.bottom-cta .benefits {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: .5rem 1.25rem;
    margin: 1rem 0 0;
    padding: 0;
    list-style: none
}

.bottom-cta .benefits li {
    line-height: 1.5
}

.bottom-cta .benefits li::before {
    content: "";
    width: 1rem;
    height: 1rem;
    display: inline-block;
    vertical-align: -2px;
    margin-right: .5rem;
    background: url("https://api.iconify.design/tabler:check.svg?color=%237aa2ff") no-repeat center/contain;
}

.bottom-cta-actions {
    display: flex;
    align-items: center;
    gap: 14px
}

.btn-primary {
    --btn1: #7aa2ff;
    --btn2: #3b82f6;
    --btn3: #0ea5e9;
    padding: .75rem 1rem;
    border-radius: 999px;
    font-weight: 700;
    text-decoration: none;
    color: #fff;
    background: linear-gradient(180deg, color-mix(in oklab, var(--btn1) 65%, var(--btn2)),
            color-mix(in oklab, var(--btn1) 25%, var(--btn3)));
    box-shadow: 0 10px 30px rgba(0, 0, 0, .25), inset 0 1px 0 rgba(255, 255, 255, .08);
    transition: transform .15s ease, box-shadow .15s ease
}

.btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 34px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .12)
}

@media (max-width:720px) {
    .bottom-cta-inner {
        flex-direction: column;
        align-items: flex-start
    }

    .bottom-cta-actions {
        width: 100%;
        flex-wrap: wrap
    }
}

/* === Bottom CTA in a glass card === */
.card-cta {
  /* reuse .card aesthetics, but full-width & stable */
  width: 100%;
  max-width: 100%;
  transform: none;
  padding: clamp(20px, 4vw, 28px);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: clamp(20px, 3vw, 36px);
}
@media (max-width: 820px) {
  .card-cta { grid-template-columns: 1fr; }
}

/* Inner layout */
.card-cta .brand-mini img { width: 24px; height: 24px; border-radius: 6px; }
.card-cta .tagline { margin: .25rem 0 1rem; font-size: 1.05rem; opacity: .9; }
.card-cta .benefits {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .5rem 1.25rem; margin: 1rem 0 0; padding: 0; list-style: none;
}
.card-cta .benefits li { line-height: 1.5; }
.card-cta .benefits li::before {
  content: ""; display: inline-block; vertical-align: -2px; margin-right: .5rem;
  width: 14px; height: 14px; /* clamp the check icon */
  background: url("https://api.iconify.design/tabler:check.svg?color=%237aa2ff") no-repeat center/contain;
}

.card-cta .actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.card-cta .btn-primary { height: 44px; display: inline-flex; align-items: center; }

/* === Icon size normalization (prevents runaway SVG sizing) === */
:root { --ico-sm: 16px; --ico-md: 18px; --ico-lg: 22px; }

/* generic <img class="ico"> */
img.ico { width: var(--ico-md); height: var(--ico-md); object-fit: contain; flex: 0 0 auto; }

/* specific contexts */
.hero .lead img.ico { width: var(--ico-md); height: var(--ico-md); vertical-align: -3px; margin-right: 6px; }
.card .card-icon img, .card .card-icon .ico { width: var(--ico-md); height: var(--ico-md); }
.seg button .ico { width: var(--ico-lg); height: var(--ico-lg); }

/* If any inline styles were left on icons, override locally in CTA only */
#get img.ico { width: var(--ico-md) !important; height: var(--ico-md) !important; }

/* ===== App icon hard clamp (works anywhere) ===== */
:root { --app-icon-size: 28px; }  /* header/default size */

img.app-icon, img[src*="app-icon.png"]{
  width: var(--app-icon-size) !important;
  height: var(--app-icon-size) !important;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 6px;
  max-width: none;  /* ignore any global img {max-width:100%} */
  max-height: none;
}

/* If your bottom CTA is a glass card and you want a smaller brand mark there */
.card-cta .brand-mini .app-icon,
.bottom-cta .brand-mini .app-icon{
  width: 24px !important;
  height: 24px !important;
}

/* Keep App Store badge stable too */
.badge img { height: 40px; width: auto; display: block; }

/* Product Hunt badge — match App Store badge height */
.header .cta { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.ph-badge { display: inline-flex; align-items: center; line-height: 0; }
.ph-badge picture, .ph-badge img { display: block; }
.ph-badge img { height: 40px; width: auto; }

/* Slightly smaller on very small screens */
@media (max-width: 480px) {
  .ph-badge img { height: 36px; }
}
