/* =========================================
   1) ZÁKLADNÍ NASTAVENÍ & BARVY
   ========================================= */

:root {
    --mr-black: #000000;
    --mr-black-soft: #050608;
    --mr-yellow: #FBD106;
    --mr-yellow-strong: #FFC800;
    --mr-yellow-soft: rgba(251, 209, 6, 0.16);
    --mr-white: #FFFFFF;
    --mr-text-main: #111827;
    --mr-text-muted: #6B7280;
    --mr-border-soft: #E5E7EB;
}

body {
    font-family: 'Cabin', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background-color: #F5F5F7;
    color: var(--mr-text-main);
    line-height: 1.5;
}

/* =========================================
   2) HLAVIČKA / HERO (ÚVOD)
   ========================================= */

.my-pozadi-hlavicka {
    position: relative;
    background-image: linear-gradient(
        145deg,
        rgba(0, 0, 0, 0.90),
        rgba(0, 0, 0, 0.55)
    ), url(./images/03.jpeg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    min-height: 100vh;
    padding-top: 0;
    padding-bottom: 0;
    margin-bottom: 64px;
    color: var(--mr-white);
    display: flex;
    flex-direction: column;
    overflow: visible;
}

.my-pozadi-hlavicka-ostatni {
    position: relative;
    overflow: visible;
}

/* horní tmavý pruh s menu */
.my-pozadi-menu {
    position: relative;
    background-color: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--mr-white);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    z-index: 1200;
    overflow: visible;
}

.my-pozadi-menu .navbar,
.my-pozadi-menu .container,
.my-pozadi-menu .container-fluid,
.my-pozadi-menu .navbar-collapse {
    overflow: visible;
}

/* logo v navigaci */
.navbar-brand img {
    height: 52px;
}

/* nav odkazy */
.navbar .nav-link {
    color: #E5E7EB;
    padding: 0.75rem 0.9rem;
    position: relative;
    transition: color 0.15s ease-out;
}

.navbar .nav-link:hover {
    color: var(--mr-white);
}

/* aktivní odkaz – žlutý podtrh */
.navbar .nav-link.active,
li .active {
    color: var(--mr-white) !important;
}

.navbar .nav-link.active::after,
.navbar .nav-link:hover::after {
    content: "";
    position: absolute;
    left: 0.9rem;
    right: 0.9rem;
    bottom: 0.25rem;
    height: 3px;
    border-radius: 999px;
    background-color: var(--mr-yellow);
}

/* hamburger na mobilu */
.navbar-toggler {
    border-color: rgba(249, 250, 251, 0.7);
    padding: 0.25rem 0.5rem;
}

.navbar-toggler-icon {
    background-image:
      url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28 249,250,251, 0.95%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* hero obsah – zarovnání CTA doprostřed výšky */
.my-pozadi-hlavicka .px-4.py-5.my-5.text-center {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* =========================================
   3) CTA „ČAS NAJÍT SVÉ VÝSLEDKY“
   ========================================= */

/* CTA lichoběžník – návrat k jistému chování + centrovaný text */

.my-cas-najit,
.my-cas-najit2 {
    width: 260px;
    height: 65px;
    background-image: url(./images/lichobeznik.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    margin-left: auto;
    margin-right: auto;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transform-origin: center;
    transition: transform 0.12s ease-out,
                filter 0.15s ease-out;
}

/* umístění ve stránce */
.my-cas-najit {
    margin-top: 0;
}

.my-cas-najit2 {
    margin-top: 10vh;
}

/* vlastní text uvnitř lichoběžníku */
.my-cas-najit .my-novy-odkaz,
.my-cas-najit2 .my-novy-odkaz {
    display: block;
    height: 65px;
    line-height: 65px;
    padding: 0 18px;
    text-align: center;
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #000000;
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: hidden;
}

/* hover efekt – jen jemné zvětšení */
.my-cas-najit:hover,
.my-cas-najit2:hover {
    transform: translateY(-2px) scale(1.03);
    filter: brightness(1.07);
}


/* =========================================
   4) SEKCE „ZÁVODY“
   ========================================= */

.row.text-center h1 {
    font-size: 2.3rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 2rem 0 1.5rem;
    color: var(--mr-black);
}

/* =========================================
   4a) ZÁVODY – ROKY JAKO TABS + KARTY ROKŮ
   ========================================= */

/* horní TABS s roky */
.year-tabs {
    border-bottom: 1px solid var(--mr-border-soft);
    padding-bottom: 0.25rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    gap: 0.25rem;
}

.year-tabs .nav-link {
    border-radius: 999px;
    font-size: 0.9rem;
    font-weight: 600;
    padding: 0.35rem 0.9rem;
    background-color: #F3F4F6;
    color: #4B5563;
    border: none;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.10em;
}

.year-tabs .nav-link:hover {
    background-color: #E5E7EB;
    color: #111827;
}

.year-tabs .nav-link.active {
    background-color: var(--mr-black);
    color: var(--mr-white);
}

/* wrapper pro jeden rok – „karta roku“ */
.year-card {
    background-color: #F9FAFB;
    border-radius: 16px;
    border: 1px solid var(--mr-border-soft);
    padding: 16px 16px 8px;
    margin-bottom: 1.75rem;
}

.year-card .my-table {
    margin-bottom: 0;
    background-color: transparent;
}


/* =========================================
   5) FILTROVACÍ TLAČÍTKA (typ / série)
   ========================================= */

#myBtnContainer1,
#myBtnContainer2 {
    text-align: center;
}

.btnFilter1,
.btnFilter2 {
    margin: 0.25rem 0.35rem;
    padding: 0.45rem 1rem;
    border-radius: 999px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    background-color: #FFFFFF;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--mr-black);
    transition: background-color 0.15s ease-out,
                color 0.15s ease-out,
                border-color 0.15s ease-out,
                box-shadow 0.15s ease-out,
                transform 0.12s ease-out;
}

.btnFilter1:hover,
.btnFilter2:hover {
    background-color: #FFFFFF;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
    transform: translateY(-1px);
}

/* aktivní tlačítka – ČERNO/ŽLUTÁ KOMBINACE */
.activeFilter1,
.activeFilter2,
.activeFilter3 {
    background-color: var(--mr-yellow) !important;
    color: var(--mr-black) !important;
    border-color: var(--mr-yellow) !important;
    box-shadow: 0 14px 34px rgba(251, 209, 6, 0.45);
}

.activeFilter1:hover,
.activeFilter2:hover,
.activeFilter3:hover {
    background-color: var(--mr-yellow-strong) !important;
}

/* viditelnost řádků */
.tableRowFilterDefault {
    display: none;
}

.tableRowFilterShow {
    display: table-row;
}

/* =========================================
   6) TABULKA ZÁVODŮ – DESKTOP
   ========================================= */

.my-table {
    --bs-table-bg: transparent;
    --bs-table-striped-bg: transparent;
    border: none;
    border-collapse: separate;
    border-spacing: 0 8px;          /* mezera mezi „kartičkami“ */
    width: 100%;
}

/* hlavička tabulky */
.my-table thead tr {
    background-color: var(--mr-black);
    color: var(--mr-white);
}

.my-table th {
    border: none;
    text-align: left;
    vertical-align: middle;
    font-weight: 600;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.10em;
    padding: 0.75rem 1rem;
}

/* řádek = karta závodu (jednotná barva, žádné střídání) */
.my-table tbody tr {
    position: relative;
    background-color: #F3F4F6;  /* sjednocená světle šedá */
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.05);
    transition: box-shadow 0.15s ease-out,
                transform 0.12s ease-out,
                background-color 0.15s ease-out;
}

/* odstranění vizuálního střídání – vše stejná barva */
.my-table tbody tr:nth-child(even) {
    background-color: #F3F4F6;
}

/* žlutá čára pod závodem – odstraněno globálně */
.my-table tbody tr::after {
    display: none;
    content: none;
}

/* hover efekt */
.my-table tbody tr:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.10);
    background-color: #E5E7EB;
}

/* buňky */
.my-table tbody tr td {
    border: none;
    text-align: left;
    vertical-align: middle;
    padding: 0.8rem 1rem;
    font-size: 15px;
}

/* datum výrazněji */
.my-table tbody tr td:first-child {
    font-weight: 700;
    white-space: nowrap;
}

/* piktogram – úzký sloupec */
.my-table tbody tr td:nth-child(2) {
    width: 56px;
    text-align: center;
}

/* poslední sloupec – „pro závodníky“ */
.my-table tbody tr td:last-child {
    font-weight: 500;
}

/* odkazy v tabulce */
.my-table td a {
    color: var(--mr-black);
    font-weight: 600;
    text-decoration: none;
}

.my-table td a:hover {
    text-decoration: underline;
}

/* šedý text */
.my-sedy-v-tabulce {
    color: var(--mr-text-muted);
}

.my-serie-v-tabulce {
    font-size: 13px;
    color: var(--mr-text-muted);
}

/* =========================================
   6b) TABULKA ZÁVODŮ – MOBILNÍ ÚPRAVY
   ========================================= */

@media (max-width: 768px) {
    .my-table {
        border-spacing: 0 6px;
    }

    .my-table th {
        padding: 0.55rem 0.6rem;
        font-size: 11px;
        letter-spacing: 0.08em;
    }

    .my-table tbody tr td {
        padding: 0.55rem 0.6rem;
        font-size: 13px;
    }

    .my-table tbody tr td:first-child {
        font-size: 12px;
    }

    .my-table tbody tr td:nth-child(2) {
        width: 44px;
    }

    .my-table tbody tr td:last-child {
        min-width: auto;
        width: 100%;
    }
}



/* =========================================
   7) VYHLEDÁNÍ ZÁVODNÍKA (globální styl)
   ========================================= */

.vyhledej-zavodnika {
    width: 100%;
    max-width: 460px;
    display: block;
    margin: 0 auto 20px auto;
    text-align: center;
}

/* =========================================
   8) TLAČÍTKA – ŽLUTÉ (globální)
   ========================================= */

.my-btn-zluta,
.reg-button-prvni,
.reg-button-druhy,
.my-button-form {
    background-color: var(--mr-yellow);
    color: var(--mr-black);
    border: none;
    border-radius: 999px;
    padding: 0.7rem 1.9rem;
    font-size: 15px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    text-decoration: none;
    cursor: pointer;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.30);
    transition: background-color 0.15s ease-out,
                box-shadow 0.15s ease-out,
                transform 0.12s ease-out,
                color 0.15s ease-out;
}

.my-btn-zluta:hover,
.reg-button-prvni:hover,
.reg-button-druhy:hover,
.my-button-form:hover {
    background-color: var(--mr-yellow-strong);
    color: var(--mr-black);
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}

/* zachování původního layoutu pro reg tlačítka, pokud je používáš jinde */
.reg-button-prvni {
    margin-left: 60px;
}

.reg-button-druhy {
    margin-left: 30px;
}

/* =========================================
   9) INFO BOX
   ========================================= */

.my-info-box {
    background-color: #FFFBEA;
    border: 1px solid #FACC15;
    border-left-width: 4px;
    border-radius: 12px;
    padding: 14px 18px;
    margin-bottom: 30px;
    color: #78350F;
    font-size: 14px;
}

/* =========================================
   10) KONTAKTNÍ FORMULÁŘ
   ========================================= */

/* karta kolem formuláře */
form.p-4.p-md-5.border.rounded-3.bg-light {
    background-color: #F9FAFB !important;
    border-radius: 18px !important;
    border: 1px solid var(--mr-border-soft) !important;
    box-shadow: 0 22px 60px rgba(0, 0, 0, 0.12);
}

/* inputy / textarea */
.form-floating > .form-control,
.form-floating > textarea.form-control {
    border-radius: 12px;
    border-color: var(--mr-border-soft);
}

.form-floating > .form-control:focus,
.form-floating > textarea.form-control:focus {
    border-color: var(--mr-yellow);
    box-shadow: 0 0 0 0.15rem var(--mr-yellow-soft);
}

/* reCAPTCHA zarovnání */
.g-recaptcha {
    transform-origin: 0 0;
}

/* tlačítko odeslat – používá my-button-form */
.my-button-form {
    width: 100%;
}

/* =========================================
   11) PATIČKA
   ========================================= */

.my-pozadi-patka {
    position: relative;
    background-image: linear-gradient(
        180deg,
        #000000,
        #111827
    ), url(./images/02.jpeg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    padding-top: 40px;
    padding-bottom: 40px;
    margin-top: 60px;
    min-height: 220px;
    color: #E5E7EB;
}

/* spodní textová patička */
.my-paticka {
    color: #9CA3AF;
    font-size: 13px;
}

.my-paticka a,
.my-paticka a:active {
    color: #D1D5DB;
    text-decoration: none;
}

.my-paticka a:hover {
    color: var(--mr-yellow);
    text-decoration: underline;
}

/* helper, který máš u <hr class="my-12"> */
.my-12 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
}

/* =========================================
   12) BLOG (pokud používáš jinde)
   ========================================= */

.my-blog {}

.my-blog-vypis {}

.my-blog-vypis-item {
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--mr-border-soft);
}

.my-blog-vypis-name {
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 8px;
}

.my-blog-vypis-img {
    width: 320px;
    max-width: 40%;
    float: left;
    margin-right: 24px;
    margin-bottom: 16px;
}

.my-blog-vypis-img img {
    width: 100%;
    border-radius: 12px;
    display: block;
    object-fit: cover;
}

.my-blog-vypis-content {
    font-size: 15px;
    color: var(--mr-text-main);
}

.my-blog-bgimage {
    height: 220px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    margin-bottom: 20px;
    border-radius: 16px;
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}

/* =========================================
   13) RESPONSIVE ÚPRAVY
   ========================================= */

@media (max-width: 992px) {
    .my-pozadi-hlavicka {
        min-height: 90vh;
    }

    .container > .row[style*="min-height"] {
        border-radius: 16px;
        padding: 24px 18px 32px;
    }

    .reg-button-prvni,
    .reg-button-druhy {
        margin-left: 0;
        margin-right: 12px;
        margin-top: 16px;
    }
}

@media (max-width: 768px) {
    .my-pozadi-hlavicka .px-4.py-5.my-5.text-center {
        padding-top: 40px;
        padding-bottom: 40px;
    }

    .row.text-center h1 {
        font-size: 1.8rem;
        letter-spacing: 0.10em;
    }

    .my-cas-najit {
        margin-top: 0;
    }

    .my-blog-vypis-img {
        float: none;
        max-width: 100%;
        width: 100%;
        margin-right: 0;
    }

    .my-blog-vypis-item {
        padding-bottom: 20px;
    }
}

/* ======================================================
   MYRESULT – ÚVODNÍ VOLBA REGISTRACE / VOUCHERU
   ====================================================== */

.mr-reg-choice {
    text-align: center;
    padding: 40px 20px;
    margin: 20px auto 50px auto;
}

.mr-reg-choice-title {
    font-size: 1.9rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 10px;
}

.mr-reg-race-name {
    font-size: 1.35rem;
    font-weight: 600;
    margin-bottom: 30px;
    color: var(--mr-text-muted);
}

.mr-reg-buttons {
    display: flex;
    flex-direction: column;
    gap: 22px;
    max-width: 520px;
    margin: 0 auto;
}

/* --- hlavní žluté (registrace sebe) --- */
.mr-btn-main {
    background-color: var(--mr-yellow);
    color: var(--mr-black);
    font-weight: 800;
    border-radius: 16px;
    padding: 42px 46px;
    display: block;
    font-size: 1.25rem;
    box-shadow: 0 12px 30px rgba(0,0,0,0.22);
    text-decoration: none;
    transition: 0.18s ease-out;
}

.mr-btn-main span {
    display: block;
    font-size: 1rem;
    font-weight: 600;
    opacity: 0.85;
}

.mr-btn-outline span{
    display: block;
    font-size: 1rem;
    font-weight: 600;
    opacity: 0.85;
}


.mr-btn-main:hover {
    color: var(--mr-black-soft);
    background-color: var(--mr-yellow-strong);
    transform: translateY(-3px);
    box-shadow: 0 16px 42px rgba(0,0,0,0.30);
}

.mr-btn-outline:hover {
    color: var(--mr-black-soft);
    background-color: var(--mr-yellow-strong);
    transform: translateY(-3px);
    box-shadow: 0 16px 42px rgba(0,0,0,0.30);
}

/* --- bílé outline (voucher) --- */
.mr-btn-outline {
    background-color: #ffffff;
    color: var(--mr-black);
    border-radius: 16px;
    border: 3px solid var(--mr-yellow);
    padding: 42px 46px;
    display: block;
    font-size: 1.25rem;
    font-weight: 800;
    text-decoration: none;
    transition: 0.18s ease-out;
}


/* Dropdown v horním menu – lepší vzhled na tmavém pozadí */
.my-pozadi-menu .dropdown-menu {
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.10);
    box-shadow: 0 16px 44px rgba(0,0,0,0.35);
    z-index: 1210;
}
.my-pozadi-menu .dropdown-item {
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-size: 13px;
    padding: 0.65rem 1rem;
}
.my-pozadi-menu .dropdown-item.active,
.my-pozadi-menu .dropdown-item:active {
    background-color: rgba(251, 209, 6, 0.18);
    color: #ffffff;
}


.race-actions{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 12px;
  align-items: center;
}

.race-actions .my-btn-zluta,
.race-actions a,
.race-actions span{
  display: block;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
}

@media (max-width: 700px){
  .race-actions{
    grid-template-columns: 1fr;
  }
}

/* =========================================
   ONLINE VÝSLEDKY – HERO BOX
   ========================================= */

.my-online-zavody{
    background: var(--mr-yellow);
    color: var(--mr-black);
    padding: 24px 26px;
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,0.35);
    min-width: 420px;
}

.my-online-zavody h2{
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
}

.my-table-online{
    margin-bottom: 0;
    background: transparent;
}

.my-table-online td{
    padding: 6px 10px;
    font-weight: 600;
    border: none;
}

.my-table-online a{
    color: var(--mr-black);
    text-decoration: underline;
}

@media (max-width: 768px){
    .my-online-zavody{
        min-width: auto;
        width: 100%;
        padding: 20px 18px;
    }

    .my-table-online td{
        display: block;
        width: 100%;
        padding: 5px 0;
        text-align: left;
    }

    .my-table-online tr{
        display: block;
        padding: 10px 0;
        border-bottom: 1px solid rgba(0,0,0,0.12);
    }

    .my-table-online tr:last-child{
        border-bottom: none;
    }
}

/* =========================================
   ZMER SI SAM
   ========================================= */

.zss-page {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow: hidden;
    background: linear-gradient(180deg, #f4f5f7 0%, #eceff3 100%);
    color: var(--mr-text-main);
}

.zss-shell {
    width: min(1180px, calc(100% - 2rem));
    margin: 0 auto;
}

.zss-section {
    position: relative;
    padding: 84px 0;
}

.zss-section-contrast {
    background:
        linear-gradient(135deg, rgba(255, 200, 0, 0.08) 0%, rgba(255, 200, 0, 0.02) 40%, rgba(17, 24, 39, 0.04) 100%),
        #ffffff;
}

.zss-section-dark {
    background:
        linear-gradient(135deg, rgba(255, 200, 0, 0.08) 0%, rgba(255, 200, 0, 0.03) 30%, rgba(0, 0, 0, 0) 100%),
        #050608;
    color: #ffffff;
}

.zss-section-form {
    background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
}

.zss-section-heading {
    max-width: 720px;
    margin: 0 auto 40px;
    text-align: center;
}

.zss-section-heading-left {
    margin-left: 0;
    text-align: left;
}

.zss-section-heading h2 {
    margin: 0 0 14px;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.02;
    font-weight: 800;
}

.zss-section-heading p {
    margin: 0;
    color: inherit;
    opacity: 0.88;
    font-size: 1.05rem;
}

.zss-hero {
    position: relative;
    overflow: hidden;
    padding: 92px 0 84px;
    background:
        linear-gradient(115deg, rgba(0, 0, 0, 0.92) 0%, rgba(0, 0, 0, 0.80) 40%, rgba(0, 0, 0, 0.44) 100%),
        url(./images/03.jpeg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    color: #ffffff;
}

.zss-hero::before,
.zss-hero::after {
    content: "";
    position: absolute;
    inset: auto auto 0 0;
    pointer-events: none;
}

.zss-hero::before {
    width: 38vw;
    height: 12vw;
    min-width: 320px;
    min-height: 90px;
    background: linear-gradient(90deg, rgba(251, 209, 6, 0.88) 0%, rgba(251, 209, 6, 0.18) 100%);
    clip-path: polygon(0 38%, 100% 0, 100% 70%, 0 100%);
    bottom: -1px;
}

.zss-hero::after {
    top: 0;
    left: auto;
    right: -8vw;
    width: 32vw;
    height: 100%;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0) 100%);
    clip-path: polygon(32% 0, 100% 0, 68% 100%, 0 100%);
}

.zss-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr);
    gap: 34px;
    align-items: end;
}

.zss-hero-copy h1 {
    margin: 0 0 18px;
    max-width: 10ch;
    font-size: clamp(3rem, 6.4vw, 5.25rem);
    line-height: 0.92;
    font-weight: 800;
}

.zss-hero-perex {
    max-width: 700px;
    margin: 0;
    font-size: 1.18rem;
    color: rgba(255, 255, 255, 0.84);
}

.zss-hero-actions {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-top: 28px;
    flex-wrap: wrap;
}

.zss-hero-cta {
    min-width: 176px;
}

.zss-hero-note {
    max-width: 360px;
    color: rgba(255, 255, 255, 0.76);
    font-size: 0.96rem;
}

.zss-hero-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px;
}

.zss-hero-tags span {
    display: inline-flex;
    align-items: center;
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.10);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: #ffffff;
    font-size: 0.9rem;
    font-weight: 600;
}

.zss-hero-panel {
    position: relative;
    overflow: hidden;
    padding: 32px 30px;
    border-radius: 28px;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.12) 0%, rgba(12, 16, 24, 0.74) 100%);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 28px 60px rgba(0, 0, 0, 0.28);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.zss-hero-panel::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 120px;
    height: 120px;
    background: rgba(251, 209, 6, 0.24);
    clip-path: polygon(45% 0, 100% 0, 100% 55%, 0 100%, 0 45%);
}

.zss-panel-list {
    position: relative;
    z-index: 1;
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 18px;
}

.zss-panel-list li {
    display: grid;
    gap: 6px;
}

.zss-panel-list strong {
    color: #ffffff;
    font-size: 1.05rem;
}

.zss-panel-list span {
    color: rgba(255, 255, 255, 0.74);
}

.zss-steps-grid,
.zss-advantages-grid,
.zss-pricing-grid {
    display: grid;
    gap: 24px;
}

.zss-steps-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.zss-step-card {
    position: relative;
    overflow: hidden;
    padding: 28px 26px;
    border-radius: 24px;
    background: #ffffff;
    border: 1px solid rgba(17, 24, 39, 0.08);
    box-shadow: 0 24px 48px rgba(15, 23, 42, 0.08);
}

.zss-step-card::before {
    content: "";
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 6px;
    background: linear-gradient(90deg, var(--mr-yellow) 0%, rgba(251, 209, 6, 0) 100%);
}

.zss-step-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 58px;
    height: 58px;
    margin-bottom: 18px;
    border-radius: 18px;
    background: var(--mr-yellow);
    color: var(--mr-black);
}

.zss-step-icon svg {
    width: 30px;
    height: 30px;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.zss-step-number {
    display: block;
    margin-bottom: 10px;
    color: #b45309;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.zss-step-card h3,
.zss-advantage-card h3,
.zss-pricing-card strong,
.zss-contact-card h3 {
    margin: 0 0 10px;
}

.zss-step-card p,
.zss-advantage-card p,
.zss-pricing-card p,
.zss-equipment-card p,
.zss-contact-card p {
    margin: 0;
    color: inherit;
    opacity: 0.8;
}

.zss-content-grid,
.zss-form-layout,
.zss-faq-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.82fr);
    gap: 32px;
    align-items: start;
}

.zss-check-list {
    list-style: none;
    margin: 26px 0 0;
    padding: 0;
    display: grid;
    gap: 14px;
}

.zss-check-list li {
    position: relative;
    padding-left: 52px;
    min-height: 34px;
    font-size: 1rem;
    font-weight: 600;
}

.zss-check-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 34px;
    height: 34px;
    border-radius: 12px;
    background:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 12.5 10 16.5 18 8.5' stroke='%23000000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / 18px 18px no-repeat,
        var(--mr-yellow);
    box-shadow: 0 12px 20px rgba(251, 209, 6, 0.28);
}

.zss-equipment-card,
.zss-contact-card {
    position: relative;
    overflow: hidden;
    padding: 30px 28px;
    border-radius: 28px;
    background: #111827;
    color: #ffffff;
    box-shadow: 0 26px 54px rgba(15, 23, 42, 0.18);
}

.zss-equipment-card::before,
.zss-contact-card::before {
    content: "";
    position: absolute;
    inset: auto -20px -20px auto;
    width: 140px;
    height: 140px;
    background: rgba(251, 209, 6, 0.20);
    clip-path: polygon(35% 0, 100% 0, 100% 65%, 0 100%, 0 35%);
}

.zss-equipment-card h3 {
    position: relative;
    z-index: 1;
    margin: 0 0 10px;
    font-size: 1.6rem;
    line-height: 1.08;
}

.zss-equipment-points {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 14px;
    margin-top: 22px;
}

.zss-equipment-points strong {
    display: block;
    margin-bottom: 4px;
}

.zss-advantages-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.zss-advantage-card {
    position: relative;
    padding: 26px 24px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.10);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.zss-advantage-card::before {
    content: "";
    position: absolute;
    top: 20px;
    left: 24px;
    width: 44px;
    height: 4px;
    border-radius: 999px;
    background: var(--mr-yellow);
}

.zss-advantage-card h3 {
    padding-top: 20px;
}

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

.zss-pricing-card {
    padding: 30px 28px;
    border-radius: 24px;
    background: #ffffff;
    border: 1px solid rgba(17, 24, 39, 0.08);
    box-shadow: 0 22px 50px rgba(15, 23, 42, 0.08);
}

.zss-pricing-card h3,
.zss-pickup-card h3 {
    margin: 0 0 14px;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--mr-black);
}

.zss-pricing-card strong {
    display: block;
    font-size: clamp(1.9rem, 4vw, 2.8rem);
    font-weight: 800;
    line-height: 1;
}

.zss-pricing-card-highlight {
    background: linear-gradient(135deg, rgba(251, 209, 6, 0.98) 0%, rgba(255, 200, 0, 0.90) 100%);
    color: var(--mr-black);
}

.zss-pricing-card-highlight h3,
.zss-pricing-card-highlight p {
    color: rgba(0, 0, 0, 0.88);
}

.zss-pickup-card {
    margin-top: 24px;
    padding: 28px;
    border-radius: 24px;
    background: #ffffff;
    border: 1px solid rgba(17, 24, 39, 0.08);
    box-shadow: 0 22px 50px rgba(15, 23, 42, 0.08);
}

.zss-pickup-list {
    list-style: none;
    margin: 6px 0 16px;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.zss-pickup-list li {
    padding: 14px 16px;
    border-radius: 16px;
    background: #f8fafc;
    border: 1px solid rgba(17, 24, 39, 0.06);
    font-weight: 700;
    text-align: center;
}

.zss-pickup-card p {
    margin: 0;
    color: var(--mr-text-muted);
}

#zss-order-form {
    scroll-margin-top: 110px;
}

.zss-form-copy h2 {
    margin: 0 0 14px;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.02;
    font-weight: 800;
}

.zss-form-copy p {
    margin: 0;
    max-width: 620px;
    color: var(--mr-text-muted);
    font-size: 1.02rem;
}

.zss-order-summary {
    display: grid;
    gap: 16px;
    margin-top: 26px;
}

.zss-order-summary div {
    padding: 18px 20px;
    border-radius: 20px;
    background: #ffffff;
    border: 1px solid rgba(17, 24, 39, 0.08);
    box-shadow: 0 18px 34px rgba(15, 23, 42, 0.06);
}

.zss-order-summary strong {
    display: block;
    margin-bottom: 6px;
    color: var(--mr-black);
}

.zss-order-summary span,
.zss-order-summary a {
    color: var(--mr-text-muted);
    text-decoration: none;
}

.zss-order-summary a:hover {
    color: var(--mr-black);
    text-decoration: underline;
}

.zss-order-form {
    position: relative;
}

.zss-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 22px;
}

.zss-form-span-full {
    grid-column: 1 / -1;
}

.zss-form-footnote {
    margin: 16px 0 0;
    font-size: 0.88rem;
    color: var(--mr-text-muted);
    text-align: center;
}

.zss-form-alert {
    display: grid;
    gap: 6px;
    margin-bottom: 18px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid transparent;
    box-shadow: 0 16px 30px rgba(15, 23, 42, 0.08);
}

.zss-form-alert strong,
.zss-form-alert span {
    display: block;
}

.zss-form-alert.is-success {
    background: #ecfdf5;
    border-color: #a7f3d0;
    color: #065f46;
}

.zss-form-alert.is-warning {
    background: #fffbeb;
    border-color: #fde68a;
    color: #92400e;
}

.zss-form-alert.is-error {
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}

.zss-form-alert ul {
    margin: 0;
    padding-left: 18px;
}

.zss-faq-grid {
    align-items: stretch;
}

.zss-faq-accordion .accordion-item {
    margin-bottom: 14px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 18px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.04);
}

.zss-faq-accordion .accordion-button,
.zss-faq-accordion .accordion-button:not(.collapsed) {
    background: transparent;
    color: #ffffff;
    box-shadow: none;
    font-weight: 700;
}

.zss-faq-accordion .accordion-button::after {
    filter: invert(1);
}

.zss-faq-accordion .accordion-body {
    color: rgba(255, 255, 255, 0.76);
}

.zss-contact-card {
    display: grid;
    align-content: start;
    gap: 10px;
    min-height: 100%;
}

.zss-contact-card a,
.zss-contact-card span {
    position: relative;
    z-index: 1;
}

.zss-contact-card a {
    color: #ffffff;
    font-size: 1.18rem;
    font-weight: 700;
    text-decoration: none;
}

.zss-contact-card a:hover {
    color: var(--mr-yellow);
}

@media (max-width: 1100px) {
    .zss-advantages-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 992px) {
    .zss-section {
        padding: 72px 0;
    }

    .zss-hero-grid,
    .zss-content-grid,
    .zss-form-layout,
    .zss-faq-grid {
        grid-template-columns: 1fr;
    }

    .zss-hero-copy h1 {
        max-width: none;
    }

    .zss-hero-panel,
    .zss-equipment-card,
    .zss-contact-card {
        max-width: 720px;
    }
}

@media (max-width: 768px) {
    .zss-shell {
        width: min(100%, calc(100% - 1.2rem));
    }

    .zss-section {
        padding: 60px 0;
    }

    .zss-hero {
        padding: 68px 0 60px;
    }

    .zss-hero::before {
        width: 84vw;
        height: 26vw;
        min-width: 0;
        min-height: 0;
    }

    .zss-hero-actions {
        align-items: flex-start;
    }

    .zss-hero-cta {
        width: 100%;
    }

    .zss-steps-grid,
    .zss-advantages-grid,
    .zss-pricing-grid,
    .zss-form-grid {
        grid-template-columns: 1fr;
    }

    .zss-step-card,
    .zss-advantage-card,
    .zss-pricing-card {
        padding: 24px 22px;
    }

    .zss-pickup-card {
        padding: 24px 22px;
    }

    .zss-pickup-list {
        grid-template-columns: 1fr 1fr;
    }

    .zss-order-summary div,
    .zss-form-alert {
        padding: 16px;
    }
}

/* =========================================
   CAMS PORTAL HOMEPAGE
   ========================================= */

body.portal-cams.is-homepage {
    background-color: #07102a;
    background-image: linear-gradient(135deg, rgba(7, 14, 35, 0.78) 0%, rgba(15, 30, 74, 0.58) 44%, rgba(176, 17, 31, 0.40) 100%), var(--cams-cover-image);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
    min-height: 100vh;
}

body.portal-cams.is-homepage .my-pozadi-hlavicka {
    min-height: auto;
    margin-bottom: 28px;
    background: transparent;
}

body.portal-cams.is-homepage .my-pozadi-menu {
    background-color: rgba(7, 14, 35, 0.72);
    border-bottom-color: rgba(214, 28, 44, 0.28);
    box-shadow: 0 16px 36px rgba(4, 10, 26, 0.18);
}

body.portal-cams.is-homepage .my-paticka,
body.portal-cams.is-homepage .my-paticka a,
body.portal-cams.is-homepage .my-paticka a:active {
    color: rgba(255, 255, 255, 0.80);
}

body.portal-cams.is-homepage .my-paticka a:hover {
    color: #ffffff;
}

body.portal-cams.is-homepage .my-12 {
    border-color: rgba(255, 255, 255, 0.16);
}

.cams-portal-home {
    position: relative;
    overflow: hidden;
    margin: 8px 0 34px;
    padding: 34px;
    border-radius: 30px;
    background: linear-gradient(135deg, rgba(8, 18, 44, 0.84) 0%, rgba(18, 39, 92, 0.74) 55%, rgba(176, 17, 31, 0.42) 100%);
    border: 1px solid rgba(255, 255, 255, 0.14);
    color: #ffffff;
    box-shadow: 0 28px 70px rgba(9, 20, 46, 0.22);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.cams-portal-hero,
.cams-portal-grid {
    position: relative;
    z-index: 1;
}

.cams-portal-hero {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    align-items: center;
}

.cams-portal-copy {
    max-width: 880px;
}

.cams-portal-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.cams-portal-badge-inline {
    background: rgba(17, 24, 39, 0.08);
    color: #21345f;
}

.cams-portal-copy h1 {
    margin: 14px 0 16px;
    max-width: 75%;
    font-size: clamp(2.4rem, 5vw, 4.35rem);
    font-weight: 800;
    line-height: 0.95;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.cams-portal-lead {
    max-width: 58ch;
    margin: 0;
    font-size: 1.08rem;
    color: rgba(255, 255, 255, 0.88);
}

.cams-portal-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin: 26px 0;
}

.cams-portal-actions-split {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.cams-portal-actions-split .cams-portal-btn {
    width: 100%;
    min-height: 64px;
    padding: 0 28px;
    text-align: center;
}

.cams-portal-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 20px;
    border-radius: 999px;
    font-weight: 800;
    text-decoration: none;
    transition: transform 0.18s ease-out, box-shadow 0.18s ease-out, background-color 0.18s ease-out;
}

.cams-portal-btn:hover {
    transform: translateY(-2px);
    text-decoration: none;
}

.cams-portal-btn-primary {
    background: #ffffff;
    color: #09142e;
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22);
}

.cams-portal-btn-primary:hover {
    color: #09142e;
    background: #f4f6fb;
}

.cams-portal-btn-secondary {
    background: rgba(255, 255, 255, 0.10);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.20);
}

.cams-portal-btn-secondary:hover {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.18);
}

.cams-portal-btn-light {
    background: #d61c2c;
    color: #ffffff;
    margin-top: 18px;
}

.cams-portal-btn-light:hover {
    color: #ffffff;
    background: #b0111f;
}

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

.cams-portal-stat {
    padding: 16px 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.10);
    border: 1px solid rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.cams-portal-stat strong {
    display: block;
    font-size: 1.65rem;
    line-height: 1;
}

.cams-portal-stat span {
    display: block;
    margin-top: 6px;
    color: rgba(255, 255, 255, 0.78);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.72rem;
}

.cams-portal-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 22px;
}

.cams-portal-card {
    min-height: 100%;
    padding: 22px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.90);
    color: #101936;
    box-shadow: 0 14px 32px rgba(8, 19, 46, 0.10);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.cams-portal-card h2 {
    margin: 0 0 10px;
    font-size: 1.2rem;
    font-weight: 800;
    color: #09142e;
}

.cams-portal-card p {
    margin: 0;
    color: #000000;
}

.cams-portal-contact-card {
    background: linear-gradient(180deg, #fff8f8 0%, #ffffff 100%);
    border: 1px solid rgba(176, 17, 31, 0.12);
}

.cams-portal-card-label {
    display: inline-block;
    margin-bottom: 10px;
    color: #b0111f;
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.16em;
}

.cams-portal-contact-list {
    display: grid;
    gap: 12px;
    margin-top: 18px;
}

.cams-portal-contact-item {
    padding-top: 12px;
    border-top: 1px solid rgba(16, 25, 54, 0.08);
}

.cams-portal-contact-item span {
    display: block;
    color: #000000;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.cams-portal-contact-item strong,
.cams-portal-contact-item a {
    color: #101936;
    font-size: 1rem;
    text-decoration: none;
}

.cams-portal-contact-item a:hover {
    color: #b0111f;
}

.cams-portal-contact-section {
    margin: 0 0 42px;
}

.cams-portal-contact-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr) auto;
    gap: 18px;
    align-items: start;
    padding: 26px 28px;
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(255, 247, 247, 0.92) 0%, rgba(255, 255, 255, 0.88) 65%);
    border: 1px solid rgba(255, 255, 255, 0.32);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.cams-portal-contact-copy h2 {
    margin: 0 0 10px;
    font-size: 1.8rem;
    font-weight: 800;
    color: #09142e;
}

.cams-portal-contact-copy p {
    margin: 0;
    color: #000000;
}

.cams-portal-contact-shell .cams-portal-contact-list {
    margin-top: 0;
}

.cams-portal-contact-action {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.cams-portal-partners-section {
    margin-top: 0;
}

.cams-portal-partner-rows {
    display: grid;
    gap: 18px;
}

.cams-portal-partner-row {
    display: grid;
    gap: 16px;
    align-items: stretch;
}

.cams-portal-partner-row-count-1 {
    grid-template-columns: minmax(0, 1fr);
    max-width: 420px;
    margin: 0 auto;
}

.cams-portal-partner-row-count-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cams-portal-partner-row-count-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cams-portal-partner-item {
    min-height: 124px;
    padding: 20px 24px;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(248, 250, 254, 0.98) 0%, rgba(239, 244, 251, 0.94) 100%);
    border: 1px solid rgba(17, 24, 39, 0.08);
    box-shadow: 0 16px 32px rgba(8, 19, 46, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
}

.cams-portal-partner-item img {
    display: block;
    max-width: 100%;
    max-height: 76px;
    width: auto;
    height: auto;
    object-fit: contain;
}

.cams-portal-newsletters {
    margin-bottom: 34px;
    padding: 30px;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.34);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.cams-portal-newsletters-header {
    margin-bottom: 22px;
}

.cams-portal-newsletters-header h2 {
    margin: 0 0 10px;
    font-size: 1.9rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #09142e;
}

.cams-portal-newsletters-header p {
    margin: 0;
    max-width: 58ch;
    color: #000000;
}

.cams-portal-newsletters-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
}

.cams-portal-newsletter-card {
    min-height: 100%;
    padding: 24px 22px;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(248, 250, 254, 0.98) 0%, rgba(239, 244, 251, 0.94) 100%);
    border: 1px solid rgba(17, 24, 39, 0.08);
    box-shadow: 0 16px 32px rgba(8, 19, 46, 0.08);
}

.cams-portal-newsletter-meta {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    margin-bottom: 12px;
}

.cams-portal-newsletter-date {
    color: #b0111f;
    font-size: 0.82rem;
    font-weight: 700;
}

.cams-portal-newsletter-card h3 {
    margin: 0 0 12px;
    font-size: 1.24rem;
    font-weight: 800;
    color: #09142e;
}

.cams-portal-newsletter-text {
    color: #000000;
    line-height: 1.65;
}

.cams-portal-calendar {
    margin-bottom: 42px;
    padding: 30px;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.34);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

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

.cams-portal-calendar-header h2 {
    margin: 0 0 8px;
    font-size: 2rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #09142e;
}

.cams-portal-calendar-header p {
    margin: 0;
    max-width: 52ch;
    color: #000000;
}

.cams-portal-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 24px;
}

.cams-portal-tab {
    appearance: none;
    border: none;
    border-radius: 20px;
    padding: 14px 18px;
    min-width: 220px;
    background: linear-gradient(180deg, rgba(240, 244, 250, 0.96) 0%, rgba(229, 236, 246, 0.92) 100%);
    color: #10204a;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    cursor: pointer;
    text-decoration: none;
    transition: transform 0.15s ease-out, box-shadow 0.15s ease-out, background-color 0.15s ease-out, color 0.15s ease-out;
}

.cams-portal-tab:hover {
    transform: translateY(-1px);
    box-shadow: 0 14px 26px rgba(16, 32, 74, 0.08);
}

.cams-portal-tab span {
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.cams-portal-tab strong {
    font-size: 1.15rem;
    line-height: 1;
}

.cams-portal-tab.is-active,
.cams-portal-tab[aria-selected="true"] {
    background: linear-gradient(135deg, #132858 0%, #b0111f 100%);
    color: #ffffff;
    box-shadow: 0 18px 32px rgba(176, 17, 31, 0.18);
}

.cams-portal-panel[hidden] {
    display: none !important;
}

.cams-portal-panel-intro {
    margin: 0 0 18px;
    max-width: 64ch;
    color: #000000;
}

.cams-portal-filters {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

.cams-portal-filter-group {
    padding: 18px 20px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(244, 246, 251, 0.90) 0%, rgba(237, 241, 248, 0.78) 100%);
}

.cams-portal-filter-title {
    display: block;
    margin-bottom: 10px;
    color: #000000;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.16em;
}

.cams-portal-calendar #myBtnContainer1,
.cams-portal-calendar #myBtnContainer2 {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.cams-portal-calendar .btnFilter1,
.cams-portal-calendar .btnFilter2 {
    margin: 0;
    border: none;
    border-radius: 999px;
    padding: 10px 16px;
    background: #dce3f1;
    color: #10204a;
    font-weight: 700;
    transition: background-color 0.15s ease-out, color 0.15s ease-out, transform 0.15s ease-out;
}

.cams-portal-calendar .btnFilter1:hover,
.cams-portal-calendar .btnFilter2:hover,
.cams-portal-calendar .activeFilter1,
.cams-portal-calendar .activeFilter2 {
    background: #b0111f;
    color: #ffffff;
    transform: translateY(-1px);
}

.cams-portal-calendar .race-actions .my-btn-zluta,
.cams-portal-calendar .race-actions a.my-btn-zluta {
    min-height: 46px;
    padding: 12px 14px;
    border-radius: 16px;
    background: linear-gradient(135deg, #d61c2c 0%, #f04b36 100%);
    color: #ffffff;
    font-weight: 800;
    box-shadow: 0 12px 24px rgba(176, 17, 31, 0.18);
    text-decoration: none;
    transition: transform 0.15s ease-out, box-shadow 0.15s ease-out, filter 0.15s ease-out;
}

.cams-portal-calendar .race-actions .my-btn-zluta:hover,
.cams-portal-calendar .race-actions a.my-btn-zluta:hover {
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 16px 28px rgba(176, 17, 31, 0.22);
    filter: brightness(1.03);
}

.cams-portal-calendar .race-actions .my-sedy-v-tabulce,
.cams-portal-calendar .race-actions span {
    min-height: 46px;
    padding: 12px 14px;
    border-radius: 16px;
    background: #eef2f9;
    color: #000000;
    font-weight: 700;
}

.cams-portal-calendar .my-table {
    width: 100%;
    margin-bottom: 0;
    table-layout: fixed;
    border-collapse: separate;
    border-spacing: 0 10px;
}

.cams-portal-calendar .cams-calendar-col-date {
    width: 150px;
}

.cams-portal-calendar .cams-calendar-col-actions {
    width: 300px;
}

.cams-portal-calendar .cams-calendar-th-date,
.cams-portal-calendar .cams-calendar-date-cell {
    white-space: nowrap;
}

.cams-portal-calendar .cams-calendar-title-cell {
    width: auto;
}

.cams-portal-calendar .cams-calendar-race-title {
    font-size: 1.12rem;
    font-weight: 800;
    line-height: 1.28;
    color: #000000;
}

.cams-portal-calendar .cams-calendar-race-series {
    display: inline-block;
    margin-top: 8px;
}

.cams-portal-calendar .cams-calendar-actions-cell {
    width: 300px;
}

.cams-portal-calendar .cams-results-table .cams-calendar-col-actions,
.cams-portal-calendar .cams-results-table .cams-calendar-actions-cell {
    width: 220px;
}

.cams-portal-calendar .race-actions {
    grid-template-columns: 1fr;
    gap: 10px;
}

.cams-portal-calendar .my-table thead th {
    border: none;
    color: #000000;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.cams-portal-calendar .my-table thead th:nth-child(2),
.cams-portal-calendar .my-table tbody td:nth-child(2) {
    padding-left: 18px;
    padding-right: 18px;
}

.cams-portal-calendar .my-table tbody tr {
    background: rgba(248, 249, 252, 0.88);
}

.cams-portal-calendar .my-table tbody td {
    padding: 18px 14px;
    vertical-align: middle;
    border-top: none;
}

.cams-portal-calendar .my-table tbody td:first-child {
    border-radius: 18px 0 0 18px;
}

.cams-portal-calendar .my-table tbody td:last-child {
    border-radius: 0 18px 18px 0;
}

.cams-profile-photo-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 18px;
    margin-bottom: 14px;
    padding: 16px 18px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(245, 248, 252, 0.92) 0%, rgba(237, 242, 249, 0.82) 100%);
    border: 1px solid rgba(17, 24, 39, 0.08);
}

.cams-profile-photo-preview {
    display: inline-flex;
    width: 132px;
    height: 132px;
    border-radius: 50%;
    overflow: hidden;
    border: 4px solid rgba(255, 255, 255, 0.92);
    box-shadow: 0 16px 30px rgba(15, 23, 42, 0.12);
    background: #dfe6f2;
    flex: 0 0 auto;
}

.cams-profile-photo-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

.cams-profile-photo-copy {
    flex: 1 1 260px;
    min-width: 220px;
}

.cams-profile-photo-copy strong {
    display: block;
    margin-bottom: 6px;
    color: #09142e;
    font-size: 1rem;
    font-weight: 800;
}

.cams-profile-photo-copy p {
    margin: 0;
    color: #000000;
}

@media (prefers-reduced-data: reduce) {
    body.portal-cams.is-homepage {
        background-image: linear-gradient(135deg, rgba(7, 14, 35, 0.96) 0%, rgba(15, 30, 74, 0.90) 44%, rgba(125, 16, 31, 0.82) 100%);
        background-attachment: scroll;
    }

    .cams-portal-home {
        background: linear-gradient(135deg, rgba(8, 18, 44, 0.96) 0%, rgba(18, 39, 92, 0.94) 55%, rgba(125, 16, 31, 0.86) 100%);
    }

    .cams-portal-home,
    .cams-portal-stat,
    .cams-portal-card,
    .cams-portal-contact-shell,
    .cams-portal-newsletters,
    .cams-portal-calendar {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        box-shadow: 0 16px 34px rgba(9, 20, 46, 0.12);
    }

    .cams-portal-stat {
        background: rgba(255, 255, 255, 0.16);
    }

    .cams-portal-card,
    .cams-portal-contact-shell,
    .cams-portal-newsletters,
    .cams-portal-calendar {
        background: rgba(255, 255, 255, 0.96);
    }
}

@media (max-width: 1100px) {
    .cams-portal-stats,
    .cams-portal-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .cams-portal-contact-shell {
        grid-template-columns: 1fr;
    }

    .cams-portal-contact-action {
        justify-content: flex-start;
    }
}

@media (max-width: 991px) {
    .cams-portal-copy h1 {
        max-width: none;
    }

    .cams-portal-filters {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    body.portal-cams.is-homepage {
        background-attachment: scroll;
    }

    body.portal-cams.is-homepage .my-pozadi-hlavicka {
        margin-bottom: 20px;
    }

    body.portal-cams.is-homepage {
        background-position: center top;
        background-attachment: scroll;
    }

    .cams-portal-home,
    .cams-portal-newsletters,
    .cams-portal-calendar {
        padding: 20px 18px;
        border-radius: 24px;
    }

    .cams-portal-actions,
    .cams-portal-stats,
    .cams-portal-grid {
        grid-template-columns: 1fr;
    }

    .cams-portal-actions {
        display: grid;
    }

    .cams-portal-actions-split {
        grid-template-columns: 1fr;
    }

    .cams-portal-btn {
        width: 100%;
    }

    .cams-portal-calendar-header {
        flex-direction: column;
        align-items: stretch;
    }

    .cams-portal-newsletters-grid {
        grid-template-columns: 1fr;
    }

    .cams-portal-newsletter-meta {
        align-items: flex-start;
        flex-direction: column;
    }

    .cams-portal-partner-row,
    .cams-portal-partner-row-count-1,
    .cams-portal-partner-row-count-2,
    .cams-portal-partner-row-count-3 {
        grid-template-columns: 1fr;
        max-width: none;
    }

    .cams-portal-tabs {
        flex-direction: column;
    }

    .cams-portal-tab {
        width: 100%;
        min-width: 0;
    }

    .cams-portal-calendar .my-table {
        display: block;
        width: 100%;
        border-spacing: 0;
        table-layout: auto;
    }

    .cams-portal-calendar .my-table colgroup {
        display: none;
    }

    .cams-portal-calendar .my-table tbody {
        display: block;
        width: 100%;
    }

    .cams-portal-calendar .cams-calendar-col-date,
    .cams-portal-calendar .cams-calendar-col-actions {
        width: auto;
    }

    .cams-portal-calendar .my-table thead {
        display: none;
    }

    .cams-portal-calendar .my-table tbody tr {
        display: block;
        width: 100%;
        box-sizing: border-box;
        margin-bottom: 14px;
        padding: 16px 14px;
        border-radius: 18px;
    }

    .cams-portal-calendar .my-table tbody td {
        display: block;
        width: 100% !important;
        box-sizing: border-box;
        padding: 6px 0;
    }

    .cams-portal-calendar .cams-calendar-actions-cell {
        width: auto;
    }

    .cams-portal-calendar .cams-calendar-date-cell,
    .cams-portal-calendar .cams-calendar-title-cell,
    .cams-portal-calendar .cams-calendar-actions-cell {
        white-space: normal;
    }

    .cams-portal-calendar .my-table tbody td:nth-child(2) {
        padding-left: 0;
        padding-right: 0;
    }

    .cams-portal-calendar .race-actions {
        width: 100%;
    }

    .cams-portal-calendar .my-table tbody td:first-child,
    .cams-portal-calendar .my-table tbody td:last-child {
        border-radius: 0;
    }

    .cams-profile-photo-row {
        padding: 16px;
    }

    .cams-profile-photo-preview {
        width: 112px;
        height: 112px;
    }
}
