:root{--run-dark:#10231f;--run-green:#20c76f;--run-lime:#d7ff4f;--run-blue:#1463ff;--run-ink:#15211d;--run-muted:#66736f;--run-soft:#f4f8f5}body{color:var(--run-ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;letter-spacing:0}.bg-run{background:rgba(16,35,31,.96);backdrop-filter:blur(14px)}.hero{min-height:78vh;display:flex;align-items:flex-end;padding:8rem 0 4rem;background:linear-gradient(90deg,rgba(16,35,31,.94),rgba(16,35,31,.58)),url("https://images.unsplash.com/photo-1552674605-db6ffd4facb5?auto=format&fit=crop&w=1800&q=80") center/cover;color:white}.hero h1,.page-header h1{max-width:900px;font-size:clamp(2.4rem,6vw,5.5rem);line-height:.98;font-weight:850}.lead{max-width:760px}.eyebrow{color:var(--run-green);font-size:.78rem;font-weight:800;letter-spacing:.12rem;text-transform:uppercase}.search-panel,.metric-panel{border-radius:8px;padding:1.25rem;background:white;color:var(--run-ink)}.section{padding:4rem 0}.section-alt{background:var(--run-soft)}.section-title{margin-bottom:1.5rem}.section-title h2{font-weight:800}.event-card{min-height:230px;display:flex;flex-direction:column;justify-content:space-between;padding:1.25rem;border:1px solid #dfe8e3;border-radius:8px;color:inherit;text-decoration:none;background:white;transition:transform .2s ease,box-shadow .2s ease}.event-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(20,99,255,.12)}.event-card h3{margin:1.5rem 0 .75rem;font-size:1.25rem;font-weight:800}.event-card-footer,.metric-line{display:flex;justify-content:space-between;gap:1rem;border-top:1px solid #edf2ef;padding-top:.75rem}.event-list{display:grid;gap:.75rem}.event-row{display:grid;grid-template-columns:72px 1fr;gap:1rem;align-items:center;padding:1rem;border-radius:8px;color:inherit;background:white;text-decoration:none}.event-date{border-radius:8px;padding:.75rem;color:var(--run-dark);background:var(--run-lime);font-weight:900;text-align:center}.event-row small{display:block;color:var(--run-muted)}.page-header{padding:8rem 0 3rem;color:white;background:var(--run-dark)}.event-detail-header{background:linear-gradient(90deg,rgba(16,35,31,.95),rgba(16,35,31,.62)),url("https://images.unsplash.com/photo-1502904550040-7534597429ae?auto=format&fit=crop&w=1800&q=80") center/cover}.filter-bar{display:grid;grid-template-columns:2fr 1fr .6fr .8fr auto;gap:.75rem;margin-top:1.5rem}.compact-filter{max-width:560px;grid-template-columns:1fr auto;margin-top:0}.info-grid{display:grid;grid-template-columns:140px 1fr;gap:.75rem 1.25rem}.info-grid dt{color:var(--run-muted)}.narrow{max-width:820px}.privacy-banner{position:fixed;right:1rem;bottom:1rem;z-index:1050;max-width:620px;padding:1rem;border-radius:8px;color:white;background:var(--run-dark)}.dashboard-shell{min-height:100vh;display:grid;grid-template-columns:280px 1fr;padding-top:56px;background:#f6f8f7}.dashboard-sidebar{position:sticky;top:56px;height:calc(100vh - 56px);padding:1.5rem;background:var(--run-dark);color:white}.dashboard-brand{display:block;margin-bottom:2rem;color:white;font-size:1.25rem;font-weight:900;text-decoration:none}.dashboard-nav{display:grid;gap:.4rem}.dashboard-nav a{display:block;padding:.75rem .9rem;border-radius:8px;color:rgba(255,255,255,.82);text-decoration:none}.dashboard-nav a:hover{color:white;background:rgba(255,255,255,.1)}.dashboard-main{padding:2rem}.dashboard-topbar,.panel-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.dashboard-topbar h1{margin:0;font-weight:850}.dashboard-actions,.form-actions{display:flex;gap:.75rem;align-items:center;justify-content:flex-end;flex-wrap:wrap}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-bottom:1rem}.stat-card,.panel{border:1px solid #e0e8e4;border-radius:8px;background:white}.stat-card{padding:1.25rem}.stat-card span{display:block;color:var(--run-muted);font-size:.9rem}.stat-card strong{display:block;margin-top:.6rem;font-size:2rem;line-height:1}.panel{padding:1.25rem;margin-bottom:1rem}.panel-header h2{margin:0;font-size:1.25rem;font-weight:850}.status-pill{display:inline-flex;align-items:center;min-height:28px;padding:.25rem .6rem;border-radius:999px;color:#0f5132;background:#d1f7df;font-size:.82rem;font-weight:800}.dashboard-form{display:grid;gap:1rem}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.field,.formset-row label{display:grid;gap:.4rem;color:var(--run-muted);font-size:.9rem;font-weight:700}.span-2{grid-column:span 2}.check-field{display:flex;gap:.5rem;align-items:center;color:var(--run-ink);font-weight:700}.formset-grid{display:grid;gap:.75rem}.formset-row{display:grid;grid-template-columns:1.2fr .8fr .8fr .8fr auto;gap:.75rem;align-items:end;padding:.9rem;border:1px solid #edf2ef;border-radius:8px;background:#fbfdfc}.formset-row.category-row{grid-template-columns:1.2fr .8fr .8fr 1fr auto}.auth-page{min-height:100vh;display:grid;place-items:center;padding:7rem 1rem 3rem;background:linear-gradient(90deg,rgba(16,35,31,.94),rgba(16,35,31,.7)),url("https://images.unsplash.com/photo-1476480862126-209bfaa8edc8?auto=format&fit=crop&w=1800&q=80") center/cover}.auth-card{width:min(100%,440px);padding:1.5rem;border-radius:8px;background:white}.auth-card h1{margin-bottom:1rem;font-size:2rem;font-weight:850}.auth-card input{display:block;width:100%;min-height:44px;padding:.375rem .75rem;border:1px solid #dee2e6;border-radius:.375rem}@media(max-width:980px){.dashboard-shell{grid-template-columns:1fr}.dashboard-sidebar{position:static;height:auto}.dashboard-nav{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.stat-grid,.form-grid,.formset-row,.formset-row.category-row{grid-template-columns:1fr}.span-2{grid-column:auto}.dashboard-topbar{align-items:flex-start;flex-direction:column}.compact-filter{grid-template-columns:1fr}}@media(max-width:768px){.filter-bar{grid-template-columns:1fr}.hero{min-height:auto;padding-top:7rem}.info-grid{grid-template-columns:1fr}}

.auth-link {
    color: #08753d;
    font-weight: 800;
    text-decoration: none;
}

.auth-link:hover,
.auth-link:focus {
    color: #064e3b;
    text-decoration: underline;
}

.premium-navbar {
    min-height: 72px;
    padding: 10px 0;
    background:
        linear-gradient(120deg, rgba(3, 18, 15, .96), rgba(7, 41, 32, .92) 55%, rgba(3, 18, 15, .96)) !important;
    border-bottom: 1px solid rgba(209, 250, 229, .12);
    box-shadow: 0 18px 50px rgba(2, 8, 7, .22);
}

.premium-navbar::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(90deg, transparent, rgba(34, 197, 94, .08), transparent);
}

.premium-navbar .container {
    position: relative;
}

.header-brand {
    display: inline-flex;
    align-items: center;
    padding: 0;
}

.header-brand img {
    display: block;
    width: 168px;
    height: auto;
    filter: drop-shadow(0 8px 18px rgba(34, 197, 94, .16));
}

.premium-navbar .navbar-nav {
    gap: 8px;
}

.premium-navbar .nav-link {
    color: rgba(226, 232, 240, .82);
    border-radius: 999px;
    padding: 10px 14px;
    font-weight: 750;
    transition: color .2s ease, background-color .2s ease, box-shadow .2s ease;
}

.premium-navbar .nav-link:hover,
.premium-navbar .nav-link:focus {
    color: #ffffff;
    background: rgba(255, 255, 255, .08);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .08);
}

.premium-navbar .btn-light {
    border: 0;
    border-radius: 999px;
    padding: 9px 16px;
    color: #04231c;
    background: linear-gradient(135deg, #f8fafc, #d1fae5);
    box-shadow: 0 10px 24px rgba(34, 197, 94, .18);
    font-weight: 850;
}

.nav-user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #052e24;
    background: linear-gradient(135deg, #d7ff4f, #20c76f);
    box-shadow: 0 8px 18px rgba(32, 199, 111, .26);
    font-size: 12px;
    font-weight: 900;
}

.premium-navbar .dropdown-menu {
    border: 1px solid rgba(15, 35, 31, .08);
    border-radius: 8px;
    padding: 8px;
    box-shadow: 0 22px 50px rgba(2, 8, 7, .18);
}

.premium-navbar .dropdown-item {
    border-radius: 8px;
    padding: 10px 12px;
    font-weight: 700;
}

.premium-navbar .dropdown-item:hover,
.premium-navbar .dropdown-item:focus {
    background: #edfdf4;
    color: #08753d;
}

.premium-navbar .navbar-toggler {
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 8px;
    padding: 8px 10px;
    box-shadow: none;
}

.hero {
    min-height: 86vh;
    align-items: flex-end;
    padding: 9rem 0 3.5rem;
    background:
        linear-gradient(90deg, rgba(3, 18, 15, .94) 0%, rgba(3, 18, 15, .78) 42%, rgba(3, 18, 15, .38) 100%),
        linear-gradient(180deg, rgba(3, 18, 15, .08) 0%, rgba(3, 18, 15, .86) 100%),
        url("https://images.unsplash.com/photo-1552674605-db6ffd4facb5?auto=format&fit=crop&w=1800&q=80") center/cover;
}

.hero-content {
    display: grid;
    gap: 42px;
}

.hero .row {
    align-items: end;
}

.hero h1 {
    max-width: 900px;
    font-size: clamp(3.2rem, 7vw, 6.6rem);
    line-height: .94;
    letter-spacing: 0;
    font-weight: 950;
}

.hero .lead {
    max-width: 820px;
    color: rgba(255, 255, 255, .86);
    font-size: clamp(1.05rem, 2vw, 1.35rem);
    font-weight: 650;
    line-height: 1.55;
}

.hero-search-panel {
    display: grid;
    grid-template-columns: minmax(220px, .7fr) minmax(0, 1.3fr);
    align-items: end;
    gap: 28px;
    border: 1px solid rgba(209, 250, 229, .18);
    width: 100%;
    padding: 28px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(240, 253, 244, .94));
    box-shadow: 0 30px 90px rgba(2, 8, 7, .3);
}

.hero-search-kicker {
    display: inline-block;
    margin-bottom: 8px;
    color: #08753d;
    font-size: .78rem;
    font-weight: 950;
    letter-spacing: .1rem;
    text-transform: uppercase;
}

.hero-search-panel .form-label {
    display: block;
    margin-bottom: 0;
    color: #10231f;
    font-size: clamp(1.25rem, 2vw, 1.65rem);
    font-weight: 900;
    line-height: 1.08;
}

.hero-search-control {
    margin-top: 0;
    box-shadow: 0 16px 40px rgba(15, 35, 31, .1);
}

.hero-search-control .form-control,
.hero-search-control .btn {
    min-height: 66px;
    font-size: 1rem;
    font-weight: 800;
}

.hero-search-control .form-control {
    border-color: #dbe7e1;
    padding-left: 22px;
}

.hero-search-control .btn {
    min-width: 150px;
    font-weight: 900;
}

.hero-search-panel small {
    display: block;
    margin-top: 10px;
    color: #64748b;
    font-weight: 700;
}

@media (max-width: 991.98px) {
    .premium-navbar .navbar-collapse {
        margin-top: 12px;
        padding: 14px;
        border: 1px solid rgba(255, 255, 255, .1);
        border-radius: 8px;
        background: rgba(3, 18, 15, .88);
    }

    .premium-navbar .navbar-nav {
        align-items: stretch !important;
    }

    .header-brand img {
        width: 150px;
    }

    .hero-search-panel {
        grid-template-columns: 1fr;
        gap: 18px;
    }
}

.premium-featured-section {
    background:
        linear-gradient(180deg, #ffffff 0%, #f4f8f5 100%);
}

.premium-featured-title {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
}

.premium-race-carousel {
    position: relative;
    --premium-race-height: 390px;
    height: var(--premium-race-height);
    border: 1px solid rgba(16, 35, 31, .1);
    border-radius: 8px;
    box-shadow: 0 22px 55px rgba(16, 35, 31, .14);
    overflow: hidden;
}

.premium-race-carousel .carousel-inner,
.premium-race-carousel .carousel-item {
    height: 100%;
}

.premium-race-carousel.carousel-fade .carousel-item {
    opacity: 0;
    transition: opacity .9s cubic-bezier(.22, 1, .36, 1);
}

.premium-race-carousel.carousel-fade .carousel-item.active,
.premium-race-carousel.carousel-fade .carousel-item-next.carousel-item-start,
.premium-race-carousel.carousel-fade .carousel-item-prev.carousel-item-end {
    opacity: 1;
}

.premium-race-carousel.carousel-fade .active.carousel-item-start,
.premium-race-carousel.carousel-fade .active.carousel-item-end {
    opacity: 0;
}

.premium-race-carousel.carousel-fade .carousel-item-next,
.premium-race-carousel.carousel-fade .carousel-item-prev,
.premium-race-carousel.carousel-fade .carousel-item.active,
.premium-race-carousel.carousel-fade .active.carousel-item-start,
.premium-race-carousel.carousel-fade .active.carousel-item-end {
    transform: none;
}

.premium-race-slide {
    position: relative;
    height: var(--premium-race-height);
    display: grid;
    grid-template-columns: minmax(300px, .72fr) minmax(0, 1.28fr);
    gap: 24px;
    align-items: stretch;
    overflow: hidden;
    color: white;
    background: #10231f;
    text-decoration: none;
}

.premium-race-slide::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(3, 18, 15, .96) 0%, rgba(3, 18, 15, .86) 34%, rgba(3, 18, 15, .42) 66%, rgba(3, 18, 15, .18) 100%),
        linear-gradient(135deg, rgba(32, 199, 111, .24), transparent 44%);
}

.premium-race-slide-bg {
    position: absolute;
    inset: 0;
    opacity: .58;
    filter: blur(16px) saturate(1.15);
    transform: scale(1.08);
}

.premium-race-slide-bg img,
.premium-race-slide-media img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.premium-race-slide-copy {
    position: relative;
    z-index: 2;
    height: var(--premium-race-height);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 34px 36px;
}

.premium-race-slide-copy p {
    margin: 14px 0 0;
    color: rgba(255, 255, 255, .82);
    font-weight: 850;
}

.premium-race-badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    max-width: 100%;
    min-height: 28px;
    padding: 6px 10px;
    border-radius: 999px;
    color: #073125;
    background: linear-gradient(135deg, #d7ff4f, #20c76f);
    font-size: .72rem;
    font-weight: 900;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.premium-race-slide-copy h3 {
    max-width: 620px;
    margin: 18px 0 26px;
    color: white;
    font-size: 2.55rem;
    line-height: 1;
    font-weight: 900;
}

.premium-race-slide-meta {
    display: flex;
    align-items: center;
    gap: 18px;
    width: fit-content;
    border-top: 1px solid rgba(255, 255, 255, .18);
    padding-top: 14px;
    color: rgba(255, 255, 255, .9);
    font-weight: 850;
}

.premium-race-cta {
    width: fit-content;
    margin-top: 18px;
}

.premium-race-slide-meta span:first-child {
    display: grid;
    gap: 0;
    text-transform: uppercase;
    letter-spacing: .08rem;
    font-size: .72rem;
}

.premium-race-slide-meta strong {
    color: var(--run-lime);
    font-size: 2rem;
    line-height: 1;
    letter-spacing: 0;
}

.premium-race-slide-media {
    position: relative;
    z-index: 2;
    height: var(--premium-race-height);
    padding: 20px 54px 20px 0;
    overflow: hidden;
}

.premium-race-slide-media img {
    object-fit: contain;
    filter: drop-shadow(0 24px 42px rgba(0, 0, 0, .32));
}

.premium-race-carousel .carousel-item.active .premium-race-slide-bg {
    animation: premiumSlideAtmosphere 5.2s cubic-bezier(.22, 1, .36, 1) both;
}

.premium-race-carousel .carousel-item.active .premium-race-slide-copy {
    animation: premiumSlideCopy .72s cubic-bezier(.22, 1, .36, 1) both;
}

.premium-race-carousel .carousel-item.active .premium-race-slide-media {
    animation: premiumSlideMedia .9s cubic-bezier(.22, 1, .36, 1) both;
}

@keyframes premiumSlideAtmosphere {
    from {
        opacity: .42;
        transform: scale(1.04);
    }
    to {
        opacity: .58;
        transform: scale(1.1);
    }
}

@keyframes premiumSlideCopy {
    from {
        opacity: 0;
        transform: translateY(18px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes premiumSlideMedia {
    from {
        opacity: 0;
        transform: translateX(26px) scale(.985);
    }
    to {
        opacity: 1;
        transform: translateX(0) scale(1);
    }
}

.premium-race-indicators {
    right: 28px;
    bottom: 18px;
    left: auto;
    justify-content: flex-end;
    margin: 0;
}

.premium-race-indicators [data-bs-target] {
    width: 34px;
    height: 4px;
    border: 0;
    border-radius: 999px;
    background-color: rgba(255, 255, 255, .56);
}

.premium-race-indicators .active {
    background-color: var(--run-lime);
}

.premium-race-control {
    width: 44px;
    z-index: 5;
    opacity: .82;
    pointer-events: auto;
}

.premium-calendar-header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 24px;
}

.premium-calendar-header h2 {
    font-size: 2.35rem;
    line-height: 1;
    font-weight: 900;
}

.premium-calendar-list {
    display: grid;
    gap: 14px;
}

.premium-calendar-row {
    display: grid;
    grid-template-columns: 104px minmax(0, 1fr) auto;
    gap: 22px;
    align-items: center;
    min-height: 112px;
    padding: 18px 22px;
    border: 1px solid rgba(16, 35, 31, .08);
    border-radius: 8px;
    color: inherit;
    background: linear-gradient(135deg, #ffffff, #fbfffd);
    text-decoration: none;
    box-shadow: 0 16px 38px rgba(16, 35, 31, .06);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.premium-calendar-row:hover,
.premium-calendar-row:focus {
    transform: translateY(-2px);
    border-color: rgba(32, 199, 111, .45);
    color: inherit;
    box-shadow: 0 22px 52px rgba(16, 35, 31, .11);
}

.premium-calendar-date {
    min-height: 76px;
    display: grid;
    place-items: center;
    align-content: center;
    border-radius: 8px;
    color: #08251f;
    background: linear-gradient(135deg, var(--run-lime), #c8ff3d);
    text-transform: uppercase;
    letter-spacing: .08rem;
    font-size: .76rem;
    font-weight: 900;
    box-shadow: 0 12px 26px rgba(215, 255, 79, .28);
}

.premium-calendar-date strong {
    display: block;
    font-size: 2rem;
    line-height: 1;
    letter-spacing: 0;
}

.premium-calendar-main {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.premium-calendar-main strong {
    font-size: 1.35rem;
    line-height: 1.12;
    font-weight: 900;
}

.premium-calendar-main small {
    color: var(--run-muted);
    font-size: 1rem;
    font-weight: 750;
}

.premium-calendar-status {
    justify-self: end;
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    max-width: 220px;
    padding: 7px 12px;
    border-radius: 999px;
    color: #0f5132;
    background: #d1f7df;
    font-size: .82rem;
    font-weight: 900;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.calendar-more-actions {
    display: flex;
    width: 100%;
    justify-content: center;
    margin: 34px 0 6px;
}

.calendar-more-actions .btn {
    min-width: 260px;
    min-height: 60px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-inline: 28px;
    font-weight: 900;
}

.calendar-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-top: 22px;
}

.calendar-pagination-current {
    color: var(--run-muted);
    font-weight: 800;
}

.race-list-section {
    background:
        linear-gradient(180deg, #ffffff 0%, #f6faf8 48%, #ffffff 100%);
}

.race-list {
    display: grid;
    gap: 28px;
}

.race-list-archive {
    margin-top: 72px;
    padding-top: 40px;
    border-top: 2px solid rgba(16, 35, 31, .12);
}

.race-list-finished {
    gap: 20px;
}

.race-list-card {
    min-height: 280px;
    display: grid;
    grid-template-columns: minmax(280px, .42fr) minmax(0, .58fr);
    border: 1px solid rgba(16, 35, 31, .1);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 24px 70px rgba(16, 35, 31, .12);
    overflow: hidden;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.race-list-card-finished {
    min-height: 240px;
    border-color: rgba(16, 35, 31, .08);
    box-shadow: 0 18px 48px rgba(16, 35, 31, .09);
}

.race-list-card-finished:hover {
    border-color: rgba(16, 35, 31, .18);
    box-shadow: 0 22px 58px rgba(16, 35, 31, .12);
}

.race-list-card-finished .race-list-media,
.race-list-card-finished .race-list-media img {
    min-height: 240px;
}

.race-list-card-finished .race-list-media {
    background: #151d1a;
}

.race-list-card-finished .race-list-media img {
    filter: grayscale(1) saturate(0) contrast(1.08) brightness(.82) !important;
}

.race-list-card-finished .race-list-media::after {
    background:
        linear-gradient(90deg, rgba(8, 10, 9, .1), rgba(8, 10, 9, .74)),
        linear-gradient(135deg, rgba(18, 22, 20, .42), rgba(255, 255, 255, .06) 58%) !important;
    mix-blend-mode: normal;
}

.race-list-card-finished .race-list-date {
    color: #f7faf8 !important;
    background: rgba(16, 35, 31, .88) !important;
    box-shadow: 0 16px 34px rgba(16, 35, 31, .26) !important;
}

.race-list-card-finished .race-list-title {
    color: #17241f;
}

.race-list-card-finished .race-list-actions .btn {
    border-color: #75827d !important;
    color: #10231f !important;
    background: #edf2ef !important;
}

.race-list-card-finished .race-list-actions .btn:hover,
.race-list-card-finished .race-list-actions .btn:focus {
    border-color: #10231f !important;
    color: #ffffff !important;
    background: #10231f !important;
}

.race-list-card:hover {
    transform: translateY(-3px);
    border-color: rgba(32, 199, 111, .42);
    box-shadow: 0 30px 80px rgba(16, 35, 31, .16);
}

.race-list-media {
    position: relative;
    min-height: 280px;
    display: block;
    color: inherit;
    background: #10231f;
    text-decoration: none;
    overflow: hidden;
}

.race-list-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(3, 18, 15, .2), rgba(3, 18, 15, .82)),
        linear-gradient(135deg, rgba(215, 255, 79, .16), transparent 52%);
}

.race-list-media img {
    width: 100%;
    height: 100%;
    min-height: 280px;
    display: block;
    object-fit: cover;
    transform: scale(1.01);
    transition: transform .35s ease;
}

.race-list-card:hover .race-list-media img {
    transform: scale(1.05);
}

.race-list-date {
    position: absolute;
    left: 24px;
    bottom: 24px;
    z-index: 2;
    width: 92px;
    min-height: 92px;
    display: grid;
    place-items: center;
    align-content: center;
    border-radius: 8px;
    color: #08251f;
    background: linear-gradient(135deg, var(--run-lime), #c8ff3d);
    box-shadow: 0 18px 38px rgba(215, 255, 79, .32);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: .08rem;
    font-size: .78rem;
    font-weight: 900;
}

.race-list-date strong {
    display: block;
    font-size: 2.35rem;
    line-height: 1;
    letter-spacing: 0;
}

.race-list-content {
    min-width: 0;
    display: grid;
    align-content: center;
    gap: 22px;
    padding: 34px 38px;
}

.race-list-topline,
.race-list-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.race-list-status {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    max-width: 100%;
    padding: 7px 12px;
    border-radius: 999px;
    color: #0f5132;
    background: #d1f7df;
    font-size: .82rem;
    font-weight: 900;
}

.race-list-location {
    color: #60736b;
    font-weight: 850;
}

.race-list-title {
    color: #10231f;
    text-decoration: none;
    font-size: clamp(1.7rem, 3vw, 2.9rem);
    line-height: 1.03;
    font-weight: 950;
}

.race-list-title:hover,
.race-list-title:focus {
    color: #08753d;
}

.race-list-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    padding-top: 8px;
    border-top: 1px solid #edf2ef;
}

.race-list-meta span {
    min-width: 0;
    color: #10231f;
    font-size: 1.02rem;
    font-weight: 850;
}

.race-list-meta small {
    display: block;
    margin-bottom: 4px;
    color: var(--run-muted);
    font-size: .78rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: .08rem;
}

.race-empty-state {
    min-height: 260px;
    display: grid;
    align-content: center;
    justify-items: center;
    padding: 36px;
    border: 1px solid #dfe8e3;
    border-radius: 8px;
    background: #ffffff;
    text-align: center;
}

.race-empty-state h2 {
    margin: 0 0 8px;
    font-weight: 900;
}

.ambassador-hero {
    min-height: 76vh;
    display: flex;
    align-items: flex-end;
    padding: 8rem 0 4rem;
    color: #ffffff;
    background:
        linear-gradient(90deg, rgba(16, 35, 31, .96), rgba(16, 35, 31, .58)),
        url("https://images.unsplash.com/photo-1486218119243-13883505764c?auto=format&fit=crop&w=1800&q=80") center/cover;
}

.ambassador-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
    gap: 34px;
    align-items: end;
}

.ambassador-copy h1 {
    max-width: 920px;
    font-size: clamp(2.6rem, 6vw, 5.5rem);
    line-height: .98;
    font-weight: 950;
}

.ambassador-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 26px;
}

.ambassador-summary {
    padding: 28px;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 8px;
    background: rgba(8, 24, 20, .72);
    backdrop-filter: blur(14px);
}

.ambassador-summary span {
    display: block;
    margin-bottom: 14px;
    color: var(--run-lime);
    font-size: .8rem;
    font-weight: 900;
    letter-spacing: .12rem;
    text-transform: uppercase;
}

.ambassador-summary strong {
    display: block;
    font-size: 1.55rem;
    line-height: 1.12;
    font-weight: 900;
}

.ambassador-summary p {
    margin: 16px 0 0;
    color: rgba(255, 255, 255, .78);
    font-weight: 650;
}

.ambassador-section {
    background:
        linear-gradient(180deg, #ffffff 0%, #f6faf8 48%, #ffffff 100%);
}

.ambassador-info-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 44px;
}

.ambassador-info-grid article,
.ambassador-form,
.ambassador-form-copy {
    border: 1px solid rgba(16, 35, 31, .1);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 18px 48px rgba(16, 35, 31, .08);
}

.ambassador-info-grid article {
    padding: 26px;
}

.ambassador-info-grid h2,
.ambassador-form-copy h2 {
    margin: 0 0 12px;
    color: #10231f;
    font-weight: 950;
    line-height: 1.08;
}

.ambassador-info-grid p,
.ambassador-form-copy p {
    margin: 0;
    color: #60736b;
    font-weight: 650;
}

.ambassador-form-grid {
    display: grid;
    grid-template-columns: minmax(280px, .42fr) minmax(0, .58fr);
    gap: 24px;
    align-items: start;
}

.ambassador-form-copy {
    position: sticky;
    top: 92px;
    padding: 30px;
}

.ambassador-form {
    padding: 30px;
}

.ambassador-form .form-grid {
    margin-bottom: 20px;
}

.ambassador-form textarea.form-control {
    min-height: 120px;
}

.ambassador-form .field small {
    color: var(--run-muted);
    font-weight: 650;
}

.ambassador-terms-link {
    display: inline-flex;
    margin-top: 18px;
    color: #08753d;
    font-weight: 850;
    text-decoration: none;
}

.ambassador-terms-link:hover,
.ambassador-terms-link:focus {
    color: #10231f;
    text-decoration: underline;
}

.ambassador-submit-row {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}

.ambassador-terms-check {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    margin: 2px 0 20px;
    padding: 16px;
    border: 1px solid rgba(32, 199, 111, .28);
    border-radius: 8px;
    color: #10231f;
    background: #f4fbf7;
    font-size: .95rem;
    font-weight: 750;
    line-height: 1.45;
}

.ambassador-terms-check input {
    flex: 0 0 auto;
    margin-top: 3px;
}

.ambassador-terms-check a {
    color: #08753d;
    font-weight: 900;
}

.ambassador-terms-header {
    background:
        linear-gradient(90deg, rgba(16, 35, 31, .96), rgba(16, 35, 31, .62)),
        url("https://images.unsplash.com/photo-1530137073520-440b169bb7f3?auto=format&fit=crop&w=1800&q=80") center/cover;
}

.ambassador-terms-section {
    background: linear-gradient(180deg, #ffffff 0%, #f6faf8 100%);
}

.ambassador-terms-card {
    padding: 34px;
}

.ambassador-terms-card h2 {
    margin-top: 26px;
    color: #10231f;
    font-size: 1.45rem;
    font-weight: 950;
}

.ambassador-terms-card h2:first-of-type {
    margin-top: 0;
}

.ambassador-terms-card p,
.ambassador-terms-card li {
    color: #60736b;
    font-weight: 650;
    line-height: 1.65;
}

.ambassador-terms-card ul {
    display: grid;
    gap: 8px;
    margin-bottom: 0;
    padding-left: 1.2rem;
}

.ambassador-legal-note {
    margin-top: 28px;
    padding: 18px;
    border: 1px solid rgba(32, 199, 111, .28);
    border-radius: 8px;
    color: #10231f;
    background: #f4fbf7;
    font-weight: 700;
}

.ambassador-terms-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 26px;
}

@media (max-width: 991.98px) {
    .ambassador-hero {
        min-height: auto;
        padding: 7.5rem 0 3rem;
    }

    .ambassador-hero-grid,
    .ambassador-info-grid,
    .ambassador-form-grid {
        grid-template-columns: 1fr;
    }

    .ambassador-form-copy {
        position: static;
    }
}

@media (max-width: 767.98px) {
    .ambassador-copy h1 {
        font-size: clamp(2.45rem, 12vw, 4rem);
    }

    .ambassador-summary,
    .ambassador-info-grid article,
    .ambassador-form,
    .ambassador-form-copy {
        padding: 22px;
    }

    .ambassador-actions .btn,
    .ambassador-form .btn,
    .ambassador-terms-actions .btn {
        width: 100%;
    }

    .ambassador-terms-card {
        padding: 24px;
    }
}

.ambassador-premium-banner {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: center;
    margin-top: 30px;
    padding: 34px 38px;
    border: 1px solid rgba(215, 255, 79, .22);
    border-radius: 8px;
    color: #ffffff;
    background:
        linear-gradient(90deg, rgba(16, 35, 31, .98), rgba(16, 35, 31, .76)),
        url("https://images.unsplash.com/photo-1553969546-6f7388a7e07c?auto=format&fit=crop&w=1800&q=80") center/cover;
    box-shadow: 0 26px 70px rgba(16, 35, 31, .18);
    overflow: hidden;
}

.ambassador-premium-banner::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(215, 255, 79, .18), transparent 46%);
}

.ambassador-premium-copy,
.ambassador-premium-actions {
    position: relative;
    z-index: 1;
}

.ambassador-premium-copy h3 {
    max-width: 780px;
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 3.2rem);
    line-height: 1.02;
    font-weight: 950;
}

.ambassador-premium-copy p {
    max-width: 720px;
    margin: 14px 0 0;
    color: rgba(255, 255, 255, .78);
    font-size: 1.05rem;
    font-weight: 700;
}

.ambassador-premium-actions {
    display: grid;
    gap: 14px;
    justify-items: end;
}

.ambassador-premium-actions span {
    color: var(--run-lime);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .12rem;
    text-transform: uppercase;
}

@media (max-width: 991.98px) {
    .ambassador-premium-banner {
        grid-template-columns: 1fr;
    }

    .ambassador-premium-actions {
        justify-items: start;
    }
}

@media (max-width: 767.98px) {
    .ambassador-premium-banner {
        padding: 24px;
    }

    .ambassador-premium-actions .btn {
        width: 100%;
    }
}

@media (max-width: 767.98px) {
    .hero {
        min-height: auto;
        padding: 7.5rem 0 2.5rem;
    }

    .hero h1 {
        font-size: clamp(2.7rem, 13vw, 4.2rem);
    }

    .hero-search-panel {
        padding: 18px;
    }

    .hero-search-control {
        display: grid;
        gap: 10px;
    }

    .hero-search-control .form-control,
    .hero-search-control .btn {
        width: 100%;
        border-radius: 8px !important;
    }

    .premium-featured-title {
        align-items: flex-start;
        flex-direction: column;
    }

    .premium-race-carousel {
        --premium-race-height: 320px;
    }

    .premium-race-slide {
        grid-template-columns: 1fr;
        height: var(--premium-race-height);
    }

    .premium-race-slide::after {
        background:
            linear-gradient(180deg, rgba(3, 18, 15, .5) 0%, rgba(3, 18, 15, .78) 50%, rgba(3, 18, 15, .96) 100%),
            linear-gradient(135deg, rgba(32, 199, 111, .24), transparent 44%);
    }

    .premium-race-slide-copy {
        height: var(--premium-race-height);
        padding: 24px;
    }

    .premium-race-slide-copy h3 {
        font-size: 2rem;
    }

    .premium-race-slide-media {
        display: none;
    }

    .premium-race-indicators {
        right: 20px;
        bottom: 14px;
    }

    .premium-calendar-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .premium-calendar-header h2 {
        font-size: 2rem;
    }

    .premium-calendar-row {
        grid-template-columns: 78px minmax(0, 1fr);
        gap: 14px;
        min-height: 104px;
        padding: 14px;
    }

    .premium-calendar-date {
        min-height: 70px;
    }

    .premium-calendar-main strong {
        font-size: 1.1rem;
    }

    .premium-calendar-status {
        grid-column: 1 / -1;
        justify-self: start;
    }

    .calendar-pagination {
        align-items: stretch;
        flex-direction: column;
    }

    .race-list {
        gap: 20px;
    }

    .race-list-card {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .race-list-media,
    .race-list-media img {
        min-height: 220px;
    }

    .race-list-content {
        padding: 24px;
    }

    .race-list-meta {
        grid-template-columns: 1fr;
    }

    .race-list-actions .btn {
        width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .premium-race-carousel.carousel-fade .carousel-item,
    .premium-race-carousel .carousel-item.active .premium-race-slide-bg,
    .premium-race-carousel .carousel-item.active .premium-race-slide-copy,
    .premium-race-carousel .carousel-item.active .premium-race-slide-media {
        animation: none;
        transition: none;
    }
}
.event-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(320px, .8fr);
  gap: 28px;
  align-items: stretch;
  margin-bottom: 36px;
}

.event-image-card,
.event-action-card,
.content-card,
.metric-panel {
  background: #fff;
  border: 1px solid #e8eeee;
  border-radius: 22px;
  box-shadow: 0 12px 35px rgba(0,0,0,.06);
}

.event-image-card {
  padding: 12px;
}

.event-image-card img {
  width: 100%;
  height: 100%;
  max-height: 520px;
  object-fit: contain;
  border-radius: 16px;
  display: block;
}

.event-action-card {
  padding: 28px;
}

.status-pill {
  display: inline-block;
  background: #d8f7e5;
  color: #08753d;
  font-weight: 800;
  font-size: .8rem;
  padding: 7px 12px;
  border-radius: 999px;
  margin-bottom: 14px;
}

.status-pill-muted {
  color: #475569;
  background: #e2e8f0;
}

.status-pill-success {
  color: #0f5132;
  background: #d1f7df;
}

.status-pill-warning {
  color: #7a4d00;
  background: #fff2c2;
}

.status-pill-danger {
  color: #842029;
  background: #f8d7da;
}

.summary-line {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 0;
  border-bottom: 1px solid #eef2f1;
}

.summary-line span {
  color: #6b7c76;
  font-weight: 700;
}

.summary-line strong {
  text-align: right;
}

.vacancy-summary {
  margin-top: 18px;
  padding: 16px;
  border: 1px solid #cfeedd;
  border-radius: 16px;
  background: linear-gradient(135deg, #f2fff7, #ffffff);
}

.vacancy-summary span,
.vacancy-summary small {
  display: block;
  color: #5f716b;
  font-weight: 700;
}

.vacancy-summary strong {
  display: block;
  margin-top: 3px;
  color: #0b5d35;
  font-size: 2rem;
  line-height: 1.05;
}

.vacancy-summary small {
  margin-top: 6px;
  font-size: .86rem;
}

.vacancy-summary-sold-out {
  border-color: #f2c7ce;
  background: linear-gradient(135deg, #fff5f6, #ffffff);
}

.vacancy-summary-sold-out strong {
  color: #9f1d2f;
}

.content-card {
  padding: 24px;
  margin-bottom: 18px;
}

@media (max-width: 900px) {
  .event-main-grid {
    grid-template-columns: 1fr;
  }

  .event-image-card img {
    height: auto;
    max-height: none;
  }
}

.profile-header {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 18px;
}

.my-registrations-page {
    background:
        radial-gradient(circle at top right, rgba(32, 199, 111, .12), transparent 34%),
        linear-gradient(180deg, #f8fbf9 0, #ffffff 38%);
    min-height: 72vh;
}

.registrations-title {
    margin-bottom: 18px;
    color: #0b211b;
    font-weight: 900;
}

.registrations-list {
    display: grid;
    gap: 20px;
}

.registrations-section-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}

.registrations-section-heading-spaced {
    margin-top: 34px;
}

.registrations-section-heading h2 {
    margin: 0;
    color: #10231f;
    font-size: 1.25rem;
    font-weight: 900;
}

.registration-panel {
    border-color: rgba(15, 35, 31, .12);
    box-shadow: 0 14px 34px rgba(15, 35, 31, .07);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.registration-panel:hover {
    transform: translateY(-2px);
    border-color: rgba(32, 199, 111, .28);
    box-shadow: 0 20px 48px rgba(15, 35, 31, .1);
}

.registration-panel .panel-header {
    align-items: flex-start;
}

.registration-panel .panel-header h2 {
    color: #0b211b;
    font-size: 1.35rem;
    font-weight: 900;
}

.registration-panel .btn {
    border-radius: 8px;
    font-weight: 800;
}

.registrations-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    margin-top: 32px;
}

.registrations-page-status {
    color: #64736f;
    font-weight: 800;
}

.empty-registrations {
    max-width: 720px;
    padding: 32px;
    border: 1px solid #e0e8e4;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 18px 45px rgba(15, 35, 31, .08);
}

.how-section {
    padding: 90px 0;
    background:
        radial-gradient(circle at top left, rgba(34, 197, 94, 0.12), transparent 32%),
        #ffffff;
}

.section-subtitle {
    max-width: 720px;
    margin: 14px auto 0;
    color: #64748b;
    font-size: 1.05rem;
}

.how-card {
    height: 100%;
    background: #ffffff;
    border-radius: 28px;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 26px 60px rgba(15, 23, 42, 0.10);
    transition: transform .25s ease, box-shadow .25s ease;
}

.how-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 34px 80px rgba(15, 23, 42, 0.16);
}

.how-card-image {
    position: relative;
    height: 840px;
    overflow: hidden;
}

.how-card-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(2, 44, 34, 0.05), rgba(2, 44, 34, 0.65));
}

.how-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.how-card-image span {
    position: absolute;
    left: 24px;
    bottom: 22px;
    z-index: 2;
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #22c55e;
    color: #052e24;
    font-weight: 900;
    font-size: 1rem;
    box-shadow: 0 16px 30px rgba(34, 197, 94, .35);
}

.how-card-body {
    padding: 30px;
}

.how-card-body h3 {
    font-size: 1.35rem;
    font-weight: 900;
    color: #0f2f28;
    margin-bottom: 12px;
}

.how-card-body p {
    color: #64748b;
    line-height: 1.65;
    margin-bottom: 0;
}

.premium-footer {
    position: relative;
    background:
        radial-gradient(circle at top left, rgba(34, 197, 94, .18), transparent 30%),
        radial-gradient(circle at 82% 20%, rgba(215, 255, 79, .08), transparent 28%),
        linear-gradient(135deg, #041b15, #062820 55%, #03120f);
    color: #cbd5e1;
    padding: 82px 0 28px;
    overflow: hidden;
}

.premium-footer::before {
    content: "";
    position: absolute;
    right: -120px;
    top: -120px;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    background: rgba(34, 197, 94, .12);
    filter: blur(12px);
}

.footer-main {
    position: relative;
    display: grid;
    grid-template-columns: minmax(280px, .85fr) minmax(0, 1.15fr);
    gap: 72px;
    align-items: start;
}

.footer-logo {
    display: block;
    width: 224px;
    max-width: 100%;
    height: auto;
    margin-bottom: 22px;
}

.legal-page .content-card h2 {
    color: #10231f;
    font-size: 1.35rem;
    font-weight: 900;
    margin-bottom: 14px;
}

.legal-page .content-card p {
    color: #4b5c57;
    line-height: 1.75;
}

.auth-card .field a {
    color: #08753d;
    font-weight: 800;
}

.site-messages {
    position: fixed;
    top: 88px;
    left: 50%;
    z-index: 1040;
    max-width: 720px;
    transform: translateX(-50%);
}

.auth-card select {
    display: block;
    width: 100%;
    min-height: 44px;
    padding: .375rem .75rem;
    border: 1px solid #dee2e6;
    border-radius: .375rem;
}

.finance-config-panel {
    border-top: 3px solid #159557;
}

.finance-config-note,
.payment-security-note {
    border: 1px solid rgba(21, 149, 87, .18);
    border-radius: 8px;
    background: linear-gradient(135deg, rgba(21, 149, 87, .08), rgba(255, 255, 255, .9));
    color: #43625a;
    font-size: .92rem;
    font-weight: 650;
    line-height: 1.55;
    margin-bottom: 22px;
    padding: 14px 16px;
}

.finance-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 22px;
}

.finance-contract-card {
    border: 1px solid rgba(15, 47, 40, .12);
    border-radius: 8px;
    background: #f8fbfa;
    padding: 20px;
}

.finance-contract-card h3 {
    color: #10231f;
    font-size: 1.2rem;
    font-weight: 900;
    margin-bottom: 10px;
}

.finance-contract-card p {
    color: #64748b;
    margin-bottom: 4px;
}

.operational-kit-panel {
    border-color: rgba(32, 199, 111, .2);
    box-shadow: 0 18px 48px rgba(16, 35, 31, .08);
}

.operational-kit-intro {
    max-width: 980px;
    margin: -4px 0 20px;
    color: #60736b;
    font-weight: 700;
    line-height: 1.58;
}

.operational-kit-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.operational-kit-item {
    min-height: 220px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 18px;
    border: 1px solid rgba(16, 35, 31, .1);
    border-radius: 8px;
    background: #ffffff;
}

.operational-kit-item span {
    color: var(--run-green);
    font-size: .72rem;
    font-weight: 900;
    letter-spacing: .1rem;
    text-transform: uppercase;
}

.operational-kit-item h3 {
    margin: 10px 0 8px;
    color: #10231f;
    font-size: 1.18rem;
    font-weight: 950;
}

.operational-kit-item p {
    flex: 1;
    color: #60736b;
    font-size: .93rem;
    font-weight: 650;
    line-height: 1.48;
}

.operational-kit-item .btn {
    width: 100%;
}

.operational-kit-actions {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.operational-kit-item-muted {
    background: #f8fbfa;
}

.operational-kit-item-muted span {
    color: #64736f;
}

.payment-shell {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
}

.payment-summary-card,
.payment-method-card,
.payment-detail-card {
    box-shadow: 0 18px 45px rgba(15, 47, 40, .08);
}

.payment-method-options > div,
.payment-method-options ul {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.payment-method-options > div > div,
.payment-method-options li {
    border: 1px solid rgba(15, 47, 40, .14);
    border-radius: 8px;
    background: #fff;
    padding: 14px;
}

.payment-method-options label {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    color: #10231f;
    font-weight: 800;
}

.pix-box {
    border: 1px solid rgba(21, 149, 87, .22);
    border-radius: 8px;
    background: #f6fffb;
    margin-top: 20px;
    padding: 18px;
}

.pix-box code {
    display: block;
    overflow-wrap: anywhere;
    color: #0f5132;
    background: #ffffff;
    border: 1px solid rgba(21, 149, 87, .18);
    border-radius: 6px;
    margin: 10px 0;
    padding: 12px;
}

.participant-box {
    border: 1px solid rgba(15, 47, 40, .12);
    border-radius: 8px;
    background: #f8fbfa;
    margin-bottom: 18px;
    padding: 16px;
}

.participant-fields[hidden] {
    display: none;
}

.certificate-info-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    border: 1px solid rgba(21, 149, 87, .28);
    border-left: 4px solid #159557;
    border-radius: 8px;
    background: #f8fffb;
    padding: 18px 20px;
}

.certificate-info-card h4 {
    color: #10231f;
    font-size: 1.08rem;
    font-weight: 900;
}

.companion-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(180px, 1.15fr) minmax(90px, .5fr) auto;
    gap: 12px;
    align-items: end;
}

.companion-row label {
    min-width: 0;
}

.companion-row input,
.companion-row select {
    width: 100%;
}

@media (max-width: 992px) {
    .finance-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .operational-kit-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .finance-summary-grid,
    .operational-kit-grid,
    .payment-method-options > div,
    .payment-method-options ul {
        grid-template-columns: 1fr;
    }

    .certificate-info-card {
        align-items: flex-start;
        flex-direction: column;
    }

    .companion-row {
        grid-template-columns: 1fr;
    }
}

.footer-brand p {
    color: #94a3b8;
    max-width: 430px;
    line-height: 1.7;
    margin-bottom: 22px;
}

.footer-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

.footer-badges span {
    padding: 7px 11px;
    border-radius: 999px;
    background: rgba(255,255,255,.045);
    border: 1px solid rgba(209,250,229,.16);
    color: #d1fae5;
    font-size: .78rem;
    font-weight: 800;
}

.footer-links {
    display: grid;
    grid-template-columns: .8fr 1fr minmax(260px, 1.25fr);
    gap: 32px;
    align-items: start;
}

.footer-links h6 {
    color: #ffffff;
    font-weight: 900;
    margin-bottom: 18px;
}

.footer-links a {
    display: block;
    color: #94a3b8;
    text-decoration: none;
    margin-bottom: 12px;
    transition: color .2s ease, transform .2s ease;
}

.footer-links a:hover {
    color: #22c55e;
    transform: translateX(3px);
}

.footer-links p {
    color: #94a3b8;
    margin-bottom: 8px;
}

.footer-contact-card {
    border: 1px solid rgba(209,250,229,.14);
    border-radius: 8px;
    padding: 22px;
    background: rgba(255,255,255,.045);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

.footer-contact-card h6 {
    margin-bottom: 12px;
}

.footer-contact-email {
    color: #d1fae5 !important;
    font-weight: 900;
    overflow-wrap: anywhere;
}

.footer-contact-card .btn {
    margin-top: 8px;
    border-color: rgba(209,250,229,.32);
    color: #ecfdf5;
    font-weight: 850;
}

.footer-contact-card .btn:hover,
.footer-contact-card .btn:focus {
    color: #052e24;
    background: #d1fae5;
}

.footer-bottom {
    position: relative;
    border-top: 1px solid rgba(255,255,255,.12);
    margin-top: 62px;
    padding-top: 22px;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    color: #94a3b8;
    font-size: .92rem;
}

@media (max-width: 992px) {
    .footer-main {
        grid-template-columns: 1fr;
    }

    .footer-links {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-contact-card {
        grid-column: 1 / -1;
    }
}

@media (max-width: 768px) {
    .how-section {
        padding: 64px 0;
    }

    .how-card-image {
        height: 210px;
    }

    .footer-links {
        grid-template-columns: 1fr;
    }

    .footer-bottom {
        flex-direction: column;
    }
}

/* Global readability and sticky footer */
html {
    min-height: 100%;
    font-size: 19px;
}

body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    font-size: 1rem;
    line-height: 1.6;
}

main {
    flex: 1 0 auto;
    width: 100%;
}

.premium-footer {
    margin-top: auto;
}

body,
button,
input,
select,
textarea {
    font-size: 1rem;
}

p,
li,
label,
.field,
.formset-row label,
.footer-brand p,
.footer-links a,
.footer-links p,
.footer-bottom {
    font-size: 1rem;
}

input,
select,
textarea,
.form-control,
.form-select {
    min-height: 54px;
    font-size: 1rem;
}

.btn,
button {
    min-height: 50px;
    font-size: 1rem;
}

.premium-navbar .nav-link,
.premium-navbar .dropdown-item {
    font-size: 1rem;
}

.eyebrow {
    font-size: .86rem;
}

.status-pill {
    min-height: 32px;
    padding: .36rem .78rem;
    font-size: .92rem;
}

.content-card,
.event-card,
.auth-card,
.dashboard-card {
    font-size: 1rem;
}

.event-card h3,
.panel-header h2 {
    font-size: 1.38rem;
}

.info-grid {
    grid-template-columns: minmax(145px, 180px) 1fr;
    gap: .9rem 1.45rem;
}

.info-grid dt {
    font-size: 1rem;
}

.info-grid dd {
    font-size: 1rem;
    font-weight: 600;
}

.footer-badges span {
    font-size: .95rem;
}

.form-error-alert {
    border-color: #f1aeb5;
    background: #f8d7da;
    color: #842029;
    font-weight: 800;
}

.errorlist {
    margin: .55rem 0 0;
    padding-left: 1.2rem;
    color: #b42318;
    font-size: 1rem;
    font-weight: 900;
}

.field.has-error {
    color: #842029;
}

.field.has-error input,
.field.has-error select,
.field.has-error textarea,
input.is-invalid,
select.is-invalid,
textarea.is-invalid {
    border-color: #dc3545;
    background-color: #fff5f5;
    box-shadow: 0 0 0 .18rem rgba(220, 53, 69, .12);
}

.field.has-error input:focus,
.field.has-error select:focus,
.field.has-error textarea:focus,
input.is-invalid:focus,
select.is-invalid:focus,
textarea.is-invalid:focus {
    border-color: #b42318;
    box-shadow: 0 0 0 .22rem rgba(220, 53, 69, .2);
}

@media (max-width: 768px) {
    html {
        font-size: 18px;
    }

    .info-grid {
        grid-template-columns: 1fr;
    }

    .premium-footer {
        padding-top: 56px;
    }
}

.companion-add-section {
    padding-top: 7rem;
}

.companion-add-section .eyebrow {
    margin-bottom: .75rem;
    font-size: .98rem;
    letter-spacing: .18rem;
}

.companion-add-section h1 {
    margin-bottom: 1.15rem;
    font-size: clamp(2.25rem, 4vw, 3.15rem);
    font-weight: 900;
}

.companion-add-section .content-card {
    padding: 1.65rem;
}

.companion-add-section .field {
    gap: .6rem;
    font-size: 1.08rem;
}

.companion-add-section input,
.companion-add-section select {
    min-height: 58px;
    padding: .72rem .9rem;
    font-size: 1.08rem;
}

.companion-add-section .form-grid {
    gap: 1.1rem 1.25rem;
}

@media (max-width: 768px) {
    .companion-add-section {
        padding-top: 6rem;
    }

    .companion-add-section .content-card {
        padding: 1.25rem;
    }
}
