:root {
    --ink: #0f1e52;
    --blue: #2948a5;
    --blue-soft: #edf2ff;
    --yellow: #f9ca13;
    --yellow-deep: #efb90b;
    --orange: #f2a130;
    --red: #ef4423;
    --canvas: #f5f6fb;
    --surface: #ffffff;
    --muted: #6c7286;
    --line: #e8eaf1;
    --shadow: 0 16px 38px rgba(18, 35, 108, .12);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--ink);
    background: var(--canvas);
}

* { box-sizing: border-box; }
html, body, #app { min-height: 100%; margin: 0; }
body { background: linear-gradient(180deg, #fff 0, var(--canvas) 340px); }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }

/* Mobile first: the gutter is intentional. It protects touch targets from curved screens,
   avoids an edge-to-edge web-page feel, and gives cards breathing room. */
.app-shell { min-height: 100vh; padding: 0 12px 110px; }
.content-shell { width: min(100%, 720px); margin-inline: auto; }

/* Buddy-aligned home */
.buddy-hero { position: relative; overflow: visible; min-height: 228px; margin-inline: -12px; padding: 13px 17px 0; border-radius: 0; background: linear-gradient(148deg, #fbd519 0%, var(--yellow) 72%, #f5bf0d 100%); box-shadow: 0 16px 32px rgba(201,151,0,.22); }
.hero-status { position: relative; z-index: 3; display: inline-flex; align-items: center; gap: 6px; max-width: 100%; padding: 6px 9px; border-radius: 999px; background: rgba(255,255,255,.43); color: #27304b; font-size: .61rem; font-weight: 850; backdrop-filter: blur(8px); }
.status-dot { width: 7px; height: 7px; border-radius: 50%; background: #42b879; box-shadow: 0 0 0 3px rgba(66,184,121,.16); }
.status-dot.is-offline { background: var(--orange); box-shadow: 0 0 0 3px rgba(242,161,48,.18); }
.status-divider { width: 1px; height: 11px; background: rgba(15,30,82,.18); }
.buddy-hero-topline { position: relative; z-index: 1; display: flex; justify-content: space-between; min-height: 166px; padding-top: 13px; }
.hero-copy { position: relative; z-index: 3; max-width: 67%; }
.hero-kicker { margin: 0 0 4px; color: rgba(15,30,82,.63); font-size: .63rem; font-weight: 900; letter-spacing: .07em; text-transform: uppercase; }
.buddy-hero h1 { margin: 0; max-width: 228px; color: #171916; font-size: 1.47rem; line-height: 1.12; letter-spacing: -.055em; }
.hero-subtitle { max-width: 236px; margin: 9px 0 0; color: rgba(15,30,82,.67); font-size: .69rem; font-weight: 650; line-height: 1.35; }
.hero-illustration { position: relative; width: 110px; flex: 0 0 110px; }
.illustration-sun { position: absolute; right: -17px; top: 1px; width: 75px; height: 75px; border-radius: 50%; background: rgba(255,255,255,.27); }
.illustration-ribbon { position: absolute; border-radius: 999px; opacity: .92; transform: rotate(-25deg); }
.ribbon-blue { right: 7px; bottom: 42px; width: 78px; height: 10px; background: var(--blue); }
.ribbon-orange { right: -4px; bottom: 28px; width: 72px; height: 10px; background: linear-gradient(90deg,var(--orange),var(--red)); }
.illustration-person { position: absolute; bottom: 2px; display: grid; place-items: center; width: 62px; height: 83px; border-radius: 50px 50px 17px 17px; color: var(--ink); font-size: 2.4rem; line-height: 1; transform: rotate(-12deg); }
.person-one { right: 41px; background: #f8f2dc; }
.person-two { right: -7px; bottom: -2px; background: #e6a72e; transform: rotate(13deg); }
.hero-search { position: relative; z-index: 4; display: grid; grid-template-columns: 27px 1fr 22px; gap: 8px; align-items: center; min-height: 44px; margin: 2px 14px -20px; padding: 8px 10px; border-radius: 14px; background: rgba(255,255,255,.97); color: #6e7280; box-shadow: 0 10px 22px rgba(76,53,0,.18); transform: translateY(20px); font-size: .71rem; font-weight: 750; }
.search-mark { font-size: 1.25rem; color: var(--blue); }.search-arrow { text-align: right; color: var(--orange); font-size: 1.1rem; }
.quick-actions { display: grid; grid-template-columns: repeat(4,1fr); gap: 9px; margin: 56px 1px 19px; }
.quick-action { display: grid; justify-items: center; gap: 6px; color: #343640; font-size: .66rem; font-weight: 800; }
.quick-icon { display: grid; place-items: center; width: 44px; height: 44px; border-radius: 14px; color: #fff; font-size: 1.2rem; box-shadow: 0 7px 14px rgba(18,35,108,.13); }.icon-orange { background: linear-gradient(135deg,var(--orange),var(--red)); }.icon-blue { background: linear-gradient(135deg,#4770d3,var(--blue)); }.icon-red { background: linear-gradient(135deg,#f97054,var(--red)); }.icon-ink { background: linear-gradient(135deg,#373d66,var(--ink)); }
.member-card { padding: 16px; border-radius: 19px; background: linear-gradient(132deg, #11142e, #29335f); color: #fff; box-shadow: var(--shadow); border: 1px solid rgba(75,105,201,.22); }
.member-card-topline { display: flex; align-items: center; justify-content: space-between; color: rgba(255,255,255,.67); font-size: .68rem; font-weight: 800; }.member-card-accent { color: #ffd738; }
.member-card-row { display: flex; align-items: center; justify-content: space-between; margin-top: 8px; }.member-card strong, .member-card span { display: block; }.member-card strong { font-size: 1.1rem; }.member-card-row span { margin-top: 3px; color: rgba(255,255,255,.65); font-size: .72rem; }
.card-arrow-button { display: grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg,var(--orange),var(--red)); color: #fff; font-size: 1.6rem; line-height: 1; }
.dashboard-section { margin-top: 23px; }.dashboard-heading { display: flex; align-items: center; justify-content: space-between; margin-bottom: 11px; }.dashboard-heading h2 { margin: 0; font-size: .98rem; letter-spacing: -.02em; }.dashboard-heading a { color: var(--blue); font-size: .69rem; font-weight: 850; }.dashboard-heading a span { font-size: 1.1rem; vertical-align: -1px; }
.journey-cards { display: grid; gap: 10px; }.journey-card { display: grid; grid-template-columns: 43px 1fr 18px; gap: 10px; align-items: center; padding: 12px; border: 1px solid var(--line); border-radius: 17px; background: var(--surface); box-shadow: 0 4px 14px rgba(18,35,108,.04); }.journey-card-highlight { border-color: rgba(242,161,48,.54); background: linear-gradient(115deg, #fff8ec, #fff); }.journey-icon { display: grid; place-items: center; width: 43px; height: 43px; border-radius: 14px; color: #fff; font-size: 1.25rem; }.journey-icon.orange { background: linear-gradient(135deg,var(--orange),var(--red)); }.journey-icon.blue { background: linear-gradient(135deg,#4770d3,var(--blue)); }.journey-copy strong, .journey-copy small { display: block; }.journey-copy strong { font-size: .8rem; }.journey-copy small { margin-top: 3px; color: var(--muted); font-size: .67rem; line-height: 1.25; }.journey-chevron { color: #9c9fa9; font-size: 1.35rem; }
.journey-tiles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }.journey-tile { display: grid; justify-items: center; gap: 6px; color: #454755; font-size: .62rem; font-weight: 800; text-align: center; }.tile-orb { display: grid; place-items: center; width: 45px; height: 45px; border-radius: 50%; color: #fff; font-size: 1.1rem; }.orb-orange { background: linear-gradient(135deg, var(--orange), var(--red)); }.orb-blue { background: linear-gradient(135deg, #4368cb, var(--blue)); }.orb-red { background: linear-gradient(135deg, #f86d51, var(--red)); }.orb-ink { background: linear-gradient(135deg, #363a5a, var(--ink)); }
.info-strip { display: flex; gap: 10px; align-items: center; padding: 12px; border-radius: 15px; background: #f0f4ff; border-left: 3px solid var(--blue); }.info-strip-icon { color: #40a970; font-size: .83rem; }.info-strip p { margin: 0; color: var(--muted); font-size: .66rem; line-height: 1.35; }.info-strip strong { color: var(--ink); }

/* Bottom navigation */
.bottom-nav { position: fixed; z-index: 50; left: 50%; bottom: 10px; transform: translateX(-50%); display: grid; grid-template-columns: repeat(5, 1fr); align-items: end; width: calc(100% - 22px); max-width: 540px; height: 67px; padding: 6px 4px; border: 1px solid rgba(255,255,255,.75); border-radius: 20px; background: rgba(255,255,255,.97); box-shadow: 0 10px 31px rgba(15,30,82,.18); backdrop-filter: blur(16px); }
.nav-item { position: relative; height: 51px; border: 0; background: transparent; color: #777b87; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; gap: 3px; font-size: .59rem; font-weight: 800; cursor: pointer; }.nav-icon { height: 22px; color: #333641; font-size: 1.08rem; line-height: 1; }.nav-item.active, .nav-item.active .nav-icon { color: var(--blue); }.nav-action { color: #5b5e67; }.action-orb { position: absolute; top: -21px; display: grid; place-items: center; width: 50px; height: 50px; border: 4px solid var(--canvas); border-radius: 17px; background: linear-gradient(135deg,var(--orange),var(--red)); color: #fff; box-shadow: 0 9px 18px rgba(239,68,35,.28); font-size: 1.55rem; }.nav-action > span:last-child { margin-top: 0; }
.tool-sheet-backdrop { position: fixed; z-index: 60; inset: 0; display: flex; align-items: flex-end; justify-content: center; background: rgba(12,18,46,.45); backdrop-filter: blur(4px); }.tool-sheet { width: 100%; max-width: 640px; padding: 12px 17px 105px; border-radius: 27px 27px 0 0; background: #fff; box-shadow: 0 -14px 38px rgba(15,30,82,.18); }.sheet-handle { width: 39px; height: 5px; margin: 0 auto 15px; border-radius: 999px; background: #dfe1e8; }.sheet-heading { display: flex; justify-content: space-between; align-items: flex-start; }.eyebrow { margin: 0 0 5px; color: var(--orange); font-size: .63rem; font-weight: 900; letter-spacing: .11em; text-transform: uppercase; }.sheet-heading h2 { margin: 0; font-size: 1.22rem; letter-spacing: -.04em; }.icon-button { width: 31px; height: 31px; border: 0; border-radius: 10px; background: #f3f4f8; color: var(--ink); font-size: 1.4rem; line-height: 1; cursor: pointer; }.tool-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 9px; margin-top: 17px; }.tool-grid button { min-height: 112px; padding: 13px; border: 1px solid var(--line); border-radius: 17px; background: #fff; color: var(--ink); text-align: left; cursor: pointer; }.tool-icon, .tool-grid strong, .tool-grid small { display: block; }.tool-icon { width: 32px; height: 32px; display: grid; place-items: center; margin-bottom: 9px; border-radius: 10px; background: #fff0db; color: var(--red); font-size: 1rem; }.tool-grid strong { font-size: .76rem; }.tool-grid small { margin-top: 3px; color: var(--muted); font-size: .65rem; }

/* Existing operational pages retain compatible styles */
.hero-panel,.panel,.scanner-panel,.content-panel,.sync-panel,.database-panel { padding: 18px; border: 1px solid var(--line); border-radius: 20px; background: var(--surface); box-shadow: var(--shadow); }.card-grid { display: grid; gap: 12px; margin-top: 16px; }.feature-card { padding: 17px; border: 1px solid var(--line); border-radius: 17px; background: var(--surface); }.feature-card h2 { margin: 7px 0; }.feature-card p { margin: 0; color: var(--muted); }.feature-card > span { color: var(--red); font-size: .76rem; font-weight: 800; }.page-header { margin: 4px 0 16px; }.page-header h1 { margin: 0; font-size: 1.55rem; letter-spacing: -.04em; }.page-header p { color: var(--muted); line-height: 1.5; }.scanner-layout { display: grid; gap: 14px; }.scanner-video { display: block; width: 100%; min-height: 220px; border-radius: 16px; background: #101a42; object-fit: cover; }.toolbar { display: flex; gap: 10px; margin-top: 14px; }.toolbar button,.panel button { padding: 11px 14px; border: 0; border-radius: 12px; background: var(--blue-soft); color: var(--blue); font-weight: 800; cursor: pointer; }.toolbar button.primary,.panel button.primary { background: linear-gradient(135deg,var(--orange),var(--red)); color: #fff; }.toolbar button:disabled { opacity: .45; cursor: not-allowed; }.small-muted { color: var(--muted); font-size: .76rem; line-height: 1.4; }.detail-list { display: grid; grid-template-columns: 95px 1fr; gap: 10px; margin: 14px 0; font-size: .85rem; }.detail-list dt { color: var(--muted); font-weight: 800; }.detail-list dd { margin: 0; overflow-wrap: anywhere; }.page-header+.panel,.page-header+.database-panel,.page-header+.content-panel,.page-header+.sync-panel { margin-top: 14px; }

@media (min-width: 560px) { .app-shell { padding-inline: 22px; } .buddy-hero { margin-inline: -22px; border-radius: 0; min-height: 244px; padding: 16px 24px 0; } .buddy-hero-topline { min-height: 177px; } .buddy-hero h1 { max-width: 330px; font-size: 2rem; } .hero-subtitle { max-width: 300px; font-size: .76rem; } .hero-illustration { width: 155px; flex-basis: 155px; } .hero-search { margin-inline: 24px; margin-bottom: -22px; transform: translateY(22px); } .quick-actions { max-width: 360px; margin-top: 60px; } .journey-cards { grid-template-columns: repeat(2, 1fr); } .journey-card { min-height: 92px; } .journey-tiles { max-width: 400px; } .tool-grid { grid-template-columns: repeat(4, 1fr); } .tool-grid button { min-height: 126px; } .card-grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 800px) { .content-shell { width: min(100%, 860px); } .buddy-hero { min-height: 278px; padding: 21px 30px 0; } .buddy-hero-topline { min-height: 199px; } .buddy-hero h1 { max-width: 420px; font-size: 2.45rem; } .hero-subtitle { font-size: .86rem; } .hero-illustration { width: 205px; flex-basis: 205px; } .hero-search { max-width: 550px; margin-inline: 30px; margin-bottom: -24px; transform: translateY(24px); } .dashboard-section { margin-top: 28px; } .journey-tiles { max-width: 480px; } .bottom-nav { max-width: 590px; } .scanner-layout { grid-template-columns: 1.2fr .8fr; } }


/* Gateway sticky scan dock
   The full yellow hero scrolls naturally. When it leaves the viewport, this compact
   yellow dock becomes visible and preserves the primary scan action at the top. */
.gateway-sticky-scan {
    position: fixed;
    z-index: 45;
    top: 0;
    left: 50%;
    width: min(100%, 720px);
    padding: calc(env(safe-area-inset-top, 0px) + 8px) 12px 12px;
    background: linear-gradient(148deg, #fbd519 0%, var(--yellow) 72%, #f5bf0d 100%);
    box-shadow: 0 10px 24px rgba(201,151,0,.21);
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, -120%);
    transition: transform 220ms ease, opacity 180ms ease;
}

.gateway-sticky-scan.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, 0);
}

.gateway-sticky-scan-link {
    display: grid;
    grid-template-columns: 29px 1fr 22px;
    gap: 8px;
    align-items: center;
    min-height: 45px;
    padding: 8px 10px;
    border-radius: 14px;
    background: rgba(255,255,255,.97);
    color: #565b6d;
    box-shadow: 0 7px 15px rgba(76,53,0,.16);
    font-size: .73rem;
    font-weight: 800;
}

.gateway-sticky-scan-icon {
    color: var(--blue);
    font-size: 1.28rem;
}

.gateway-sticky-scan-arrow {
    color: var(--orange);
    font-size: 1.1rem;
    text-align: right;
}

@media (min-width: 560px) {
    .gateway-sticky-scan {
        width: min(100%, 860px);
        padding-inline: 22px;
    }
}


/* Global scanner overlay: one camera control, accessible from every route. */
.scanner-overlay-backdrop { position: fixed; z-index: 100; inset: 0; display: flex; align-items: flex-end; background: rgba(8, 14, 43, .58); backdrop-filter: blur(7px); }
.scanner-overlay { width: 100%; max-width: 720px; margin-inline: auto; padding: 15px 14px calc(env(safe-area-inset-bottom, 0px) + 18px); border-radius: 27px 27px 0 0; background: #fff; box-shadow: 0 -18px 42px rgba(15,30,82,.24); }
.scanner-overlay-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 15px; }
.scanner-overlay-header h2 { margin: 0; color: var(--ink); font-size: 1.27rem; letter-spacing: -.04em; }
.scanner-close { display: grid; place-items: center; width: 33px; height: 33px; border: 0; border-radius: 11px; background: #f1f3f8; color: var(--ink); font-size: 1.45rem; line-height: 1; cursor: pointer; }
.scanner-camera-frame { position: relative; overflow: hidden; border-radius: 20px; background: #101a42; aspect-ratio: 4 / 3; }
.scanner-overlay-video { width: 100%; height: 100%; object-fit: cover; display: block; }
.scanner-guide { position: absolute; inset: 18%; border: 2px solid rgba(255,255,255,.95); border-radius: 18px; box-shadow: 0 0 0 999px rgba(7,12,34,.18); }
.scanner-guide::before, .scanner-guide::after { content: ""; position: absolute; width: 29px; height: 29px; border-color: var(--yellow); border-style: solid; }
.scanner-guide::before { left: -3px; top: -3px; border-width: 4px 0 0 4px; border-radius: 12px 0 0; }
.scanner-guide::after { right: -3px; bottom: -3px; border-width: 0 4px 4px 0; border-radius: 0 0 12px; }
.scanner-overlay-help { min-height: 34px; margin: 13px 4px; color: var(--muted); font-size: .73rem; line-height: 1.4; }
.scanner-overlay-actions { display: flex; gap: 10px; }
.scanner-primary-button, .scanner-secondary-button { min-height: 48px; border-radius: 15px; font-weight: 850; cursor: pointer; }
.scanner-primary-button { flex: 1; border: 0; background: linear-gradient(135deg, var(--orange), var(--red)); color: #fff; box-shadow: 0 9px 20px rgba(239,68,35,.20); }
.scanner-secondary-button { min-width: 85px; border: 1px solid var(--line); background: #fff; color: var(--blue); }
.scanner-primary-button:disabled, .scanner-secondary-button:disabled { opacity: .45; cursor: not-allowed; }
.scanner-result-card { padding: 17px; border: 1px solid #dce8e0; border-radius: 20px; background: linear-gradient(140deg, #f1fbf5, #fff); }
.scanner-result-icon { display: grid; place-items: center; width: 37px; height: 37px; margin-bottom: 12px; border-radius: 13px; background: #3dab76; color: #fff; font-size: 1.15rem; font-weight: 900; }
.scanner-result-card h3 { margin: 0; font-size: 1rem; }.scanner-result-card > p:not(.eyebrow) { margin: 6px 0 0; color: var(--muted); font-size: .74rem; line-height: 1.45; }
.scanner-result-details { display: grid; grid-template-columns: 60px 1fr; gap: 7px 10px; margin: 15px 0 0; padding-top: 13px; border-top: 1px solid #dbe8df; font-size: .7rem; }.scanner-result-details dt { color: var(--muted); font-weight: 850; }.scanner-result-details dd { margin: 0; overflow-wrap: anywhere; color: var(--ink); }
.scanner-result-done { width: 100%; margin-top: 13px; }
.scan-launch-page { padding: 28px 6px; }.scan-launch-page h1 { margin: 5px 0; font-size: 1.45rem; }.scan-launch-page p:last-child { color: var(--muted); }
@media (min-width: 560px) { .scanner-overlay { margin-bottom: 0; padding: 20px 22px 28px; border-radius: 28px 28px 0 0; } }

/* Member campaign and information experience */
.campaign-feature-card { display: block; cursor: pointer; background: linear-gradient(132deg, #15183b, #30448c); }
.campaign-feature-card .member-card-topline { color: rgba(255,255,255,.7); }
.campaign-feature-card .member-card-row span { max-width: 265px; }
.member-information-tiles { grid-template-columns: repeat(4, 1fr); }

.information-page { min-height: 100vh; padding: 17px 2px 35px; }
.information-back { display: inline-flex; align-items: center; gap: 4px; color: var(--blue); font-size: .76rem; font-weight: 850; }
.information-back:first-letter { font-size: 1.45rem; }
.information-hero { position: relative; overflow: hidden; margin-top: 26px; padding: 22px 19px; border-radius: 24px; background: linear-gradient(148deg, #fbd519 0%, var(--yellow) 72%, #f5bf0d 100%); box-shadow: 0 13px 28px rgba(201,151,0,.17); }
.information-hero::after { content: ""; position: absolute; right: -30px; bottom: -47px; width: 150px; height: 150px; border-radius: 50%; background: rgba(255,255,255,.25); }
.information-kicker { position: relative; z-index: 1; margin: 0 0 6px; color: rgba(15,30,82,.62); font-size: .66rem; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; }
.information-hero h1 { position: relative; z-index: 1; max-width: 300px; margin: 0; color: #171916; font-size: 1.85rem; line-height: 1.06; letter-spacing: -.06em; }
.information-hero > p:last-child { position: relative; z-index: 1; max-width: 300px; margin: 11px 0 0; color: rgba(15,30,82,.71); font-size: .77rem; font-weight: 650; line-height: 1.45; }
.information-link-grid { display: grid; gap: 11px; margin-top: 18px; }
.information-link-card { display: grid; grid-template-columns: 43px 1fr 18px; gap: 11px; align-items: center; min-height: 75px; padding: 12px; border: 1px solid var(--line); border-radius: 19px; background: #fff; box-shadow: 0 6px 16px rgba(18,35,108,.05); }
.information-link-icon { display: grid; place-items: center; width: 43px; height: 43px; border-radius: 14px; color: #fff; font-size: 1.15rem; }
.card-welcome .information-link-icon { background: linear-gradient(135deg,var(--orange),var(--red)); }.card-benefits .information-link-icon { background: linear-gradient(135deg,#4770d3,var(--blue)); }.card-terms .information-link-icon { background: linear-gradient(135deg,#f86d51,var(--red)); }.card-campaigns .information-link-icon { background: linear-gradient(135deg,#373d66,var(--ink)); }
.information-link-card strong, .information-link-card small { display: block; }.information-link-card strong { font-size: .81rem; }.information-link-card small { margin-top: 3px; color: var(--muted); font-size: .67rem; }.information-link-card b { color: var(--orange); font-size: 1.45rem; font-weight: 500; text-align: right; }
.content-reading-card { margin-top: 18px; padding: 18px; border: 1px solid var(--line); border-radius: 21px; background: #fff; box-shadow: 0 7px 18px rgba(18,35,108,.05); }.content-reading-card h2 { margin: 0; font-size: 1rem; }.content-reading-card p { color: var(--muted); font-size: .76rem; line-height: 1.55; }.content-primary-link { display: flex; align-items: center; justify-content: space-between; margin-top: 16px; padding: 13px 14px; border-radius: 14px; background: linear-gradient(135deg,var(--orange),var(--red)); color: #fff; font-size: .77rem; font-weight: 850; }.content-primary-link span { font-size: 1.4rem; }
.benefit-list { display: grid; gap: 10px; margin-top: 18px; }.benefit-list article { display: flex; gap: 12px; padding: 15px; border: 1px solid var(--line); border-radius: 18px; background: #fff; }.benefit-list article > span { display: grid; flex: 0 0 35px; place-items: center; width: 35px; height: 35px; border-radius: 12px; background: #eef3ff; color: var(--blue); font-size: 1rem; }.benefit-list h2 { margin: 1px 0 0; font-size: .84rem; }.benefit-list p { margin: 5px 0 0; color: var(--muted); font-size: .7rem; line-height: 1.4; }
.terms-card { border-left: 3px solid var(--blue); }
.campaign-listing-card { display: flex; align-items: center; justify-content: space-between; gap: 15px; margin-top: 18px; padding: 19px; border-radius: 22px; background: linear-gradient(132deg, #161a3f, #30448c); color: #fff; box-shadow: 0 12px 26px rgba(18,35,108,.16); }.campaign-listing-card p { margin: 0 0 5px; color: #ffd738; font-size: .65rem; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }.campaign-listing-card h2 { margin: 0; font-size: 1.32rem; }.campaign-listing-card span { display: block; max-width: 260px; margin-top: 5px; color: rgba(255,255,255,.67); font-size: .7rem; line-height: 1.4; }.campaign-listing-card b { display: grid; place-items: center; flex: 0 0 31px; width: 31px; height: 31px; border-radius: 50%; background: linear-gradient(135deg,var(--orange),var(--red)); font-size: 1.55rem; font-weight: 400; }
.win-a-car-hero { position: relative; overflow: hidden; min-height: 210px; margin-top: 25px; padding: 24px 19px; border-radius: 25px; background: linear-gradient(132deg, #ef4423 0%, #f06a2f 49%, #f2a130 100%); color: #fff; box-shadow: 0 14px 30px rgba(239,68,35,.2); }.win-a-car-hero > p { position: relative; z-index: 2; margin: 0; color: rgba(255,255,255,.78); font-size: .66rem; font-weight: 900; letter-spacing: .11em; text-transform: uppercase; }.win-a-car-hero h1 { position: relative; z-index: 2; margin: 11px 0 0; font-size: 2.3rem; line-height: 1; letter-spacing: -.07em; }.win-a-car-hero h2 { position: relative; z-index: 2; margin: 8px 0 0; font-size: .96rem; }.win-a-car-orb { position: absolute; border-radius: 50%; background: rgba(255,255,255,.2); }.orb-one { width: 132px; height: 132px; right: -19px; top: -16px; }.orb-two { width: 72px; height: 72px; right: 67px; bottom: -35px; }.win-a-car-road { position: absolute; right: -20px; bottom: 13px; width: 180px; height: 34px; border-top: 8px solid rgba(15,30,82,.65); border-radius: 50%; transform: rotate(-11deg); }.win-a-car-intro { margin: 19px 3px 0; }.win-a-car-intro h2 { margin: 0; font-size: 1.12rem; }.win-a-car-intro p { margin: 7px 0 0; color: var(--muted); font-size: .76rem; line-height: 1.45; }
.campaign-action-grid { display: grid; gap: 11px; margin-top: 17px; }.campaign-action-grid a { display: grid; grid-template-columns: 43px 1fr 16px; gap: 10px; align-items: center; min-height: 79px; padding: 12px; border: 1px solid var(--line); border-radius: 19px; background: #fff; box-shadow: 0 6px 15px rgba(18,35,108,.05); }.campaign-action-icon { display: grid; place-items: center; width: 43px; height: 43px; border-radius: 14px; background: linear-gradient(135deg,var(--orange),var(--red)); color: #fff; font-size: 1.15rem; }.blue-action { background: linear-gradient(135deg,#4770d3,var(--blue)); }.campaign-action-grid strong, .campaign-action-grid small { display: block; }.campaign-action-grid strong { font-size: .8rem; }.campaign-action-grid small { margin-top: 3px; color: var(--muted); font-size: .66rem; }.campaign-action-grid b { color: var(--orange); font-size: 1.35rem; font-weight: 500; }.campaign-terms-link { display: flex; align-items: center; justify-content: space-between; margin: 17px 3px 0; color: var(--blue); font-size: .74rem; font-weight: 850; }.campaign-terms-link span { font-size: 1.4rem; }
@media (min-width: 560px) { .information-page { max-width: 620px; margin-inline: auto; padding-top: 23px; }.information-hero { padding: 29px 25px; }.information-hero h1 { max-width: 410px; font-size: 2.2rem; }.campaign-action-grid { grid-template-columns: repeat(2,1fr); } }

/* Startup stability: visible fallback if a non-critical component fails. */
.app-recovery-panel {
    margin-top: 28px;
    padding: 20px;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: #fff;
    box-shadow: var(--shadow);
}
.app-recovery-panel h1 {
    margin: 4px 0 8px;
    color: var(--ink);
    font-size: 1.3rem;
}
.app-recovery-panel p:not(.eyebrow) {
    margin: 0;
    color: var(--muted);
    font-size: .78rem;
    line-height: 1.5;
}
.app-recovery-button {
    display: inline-flex;
    margin-top: 15px;
    padding: 10px 14px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--orange), var(--red));
    color: #fff;
    font-size: .76rem;
    font-weight: 850;
}

/* Standard Blazor error banner: hidden unless Blazor explicitly activates it. */
#blazor-error-ui {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    right: 0;
    bottom: 0;
    padding: .65rem 1rem;
    background: #fff4c9;
    color: #352d00;
    box-shadow: 0 -5px 18px rgba(15, 30, 82, .16);
    font-size: .78rem;
}

    #blazor-error-ui .dismiss {
        position: absolute;
        top: .5rem;
        right: .85rem;
        cursor: pointer;
        color: inherit;
    }