* {
    font-family: "Lexend", Sans-serif;
}

.plavci-input-with-suffix {
    display: flex;
    align-items: center;
    gap: 8px;
}

.plavci-input-with-suffix input {
    flex: 1;
}

.plavci-sidebar-header-link {
    text-decoration: none !important;
}

.plavci-help {
        background-color: #e6f4ff;
    font-size: 14px;
    padding: 16px;
    margin-top: 8px;
    border-radius: 4px;
}

.plavci-input-suffix {
    font-size: 14px;
    color: #6b7280;
    white-space: nowrap;
}

/* Formuláre – registrácia, login, plavby */

.plavci-register-form,
.plavci-login-form {
    max-width: 480px;
    margin: 0px auto;
    padding: 40px;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.10);
    box-sizing: border-box;
}

/* Formuláre v rámci profilu – na plnú šírku, bez card boxu */
.plavci-account-content .plavci-register-form,
.plavci-account-content .plavci-login-form,
.plavci-account-content .plavci-swim-form {
    max-width: 100%;
    margin: 0 0 24px;
    padding: 0;
    background: transparent;
    box-shadow: none;
    border-radius: 0;
}

@media (max-width: 600px) {
    .plavci-register-form,
    .plavci-login-form {
        padding: 20px;
        margin: 24px auto;
    }
}

.plavci-row {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 20px;
}

.plavci-col-6 {
    flex: 1 1 0;
    min-width: 0;
}

.plavci-field {
    margin-bottom: 24px;
}

.plavci-field label {
    display: block;
    margin-bottom: 6px;
    font-weight: 500;
    font-size: 14px;
}

.plavci-field input[type="text"],
.plavci-field input[type="email"],
.plavci-field input[type="password"],
.plavci-field input[type="number"],
.plavci-field input[type="date"],
.plavci-field input[type="time"],
.plavci-field select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #dde1ec;
    border-radius: 8px;
    font-size: 15px;
    box-sizing: border-box;
    background: #f9fafb;
}

.plavci-account-content input, .plavci-account-content select {
    max-width: 340px;
}

.plavci-field input[type="text"]:focus,
.plavci-field input[type="email"]:focus,
.plavci-field input[type="password"]:focus,
.plavci-field input[type="number"]:focus,
.plavci-field input[type="date"]:focus,
.plavci-field input[type="time"]:focus,
.plavci-field select:focus {
    outline: none;
    border-color: #3b82f6;
    background: #ffffff;
    box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.18);
}

/* Heslo + oko */

.plavci-password-wrapper {
    position: relative;
    display: block;
}

.plavci-password-wrapper input {
    width: 100%;
    padding-right: 40px;
}

.plavci-toggle-password {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    border: none !important;
    background: transparent;
    cursor: pointer;
    font-size: 16px;
    line-height: 1;
    height: auto;
    width: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 0.7;
    padding: 0 !important;
}

.plavci-toggle-password:hover {
    opacity: 1;
}

/* Súhlas */

.plavci-consent label {
    align-items: flex-start;
    gap: 8px;
    font-size: 14px;
    line-height: 1.6;
}

.plavci-consent input[type="checkbox"] {
    margin-top: 3px;
}

.plavci-consent a {
    text-decoration: underline;
}

.plavci-consent a:hover {
    text-decoration: none;
}

/* Tlačidlá – hlavné CTA */

.plavci-btn-register,
.plavci-btn-login {
    display: inline-block;
    width: 100%;
    padding: 12px 18px !important;
    border-radius: 5px;
    background-color: #071d52 !important;
    border: 1px solid #071d52 !important;
    font-family: "Lexend", Sans-serif;
    font-size: 15px !important;
    font-weight: 500;
    line-height: 1em;
    letter-spacing: -0.2px;
    text-decoration: none;
    text-align: center;
    color: #fff !important;
    cursor: pointer;
    transition: background-color 0.1s ease, color 0.1s ease, box-shadow 0.1s ease, transform 0.1s ease;
    margin-top: 16px;
}

.plavci-btn-register:hover,
.plavci-btn-login:hover {
    background-color: #071d52;
    color: #2DC3FD;
    border-color: #071d52;
    box-shadow: 0 6px 16px rgba(7, 29, 82, 0.25);
    transform: translateY(-1px);
}

.plavci-btn-register:active,
.plavci-btn-login:active {
    transform: translateY(0);
    box-shadow: none;
}

/* CTA v zozname plavieb - nech nie je full width */

.plavci-swim-add {
    width: auto;
    color: #071d52 !important;
    border: 1px solid #071d52 !important;
    padding: 8px 12px;
    text-decoration: none !important;
    border-radius: 4px;
    transition: 0.3s all ease;
    background-color: inherit !important;
}
.plavci-swim-add:hover {
    width: auto;
    color: #e6f4ff !important;
    border: 1px solid #071d52 !important;
    padding: 6px 12px;
    text-decoration: none !important;
    border-radius: 4px;
    background-color: #071d52 !important;
}
/* Hlásenia */

.plavci-message.plavci-errors,
.plavci-message.plavci-success {
    margin-bottom: 18px;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 14px;
}
.plavci-message p {
    margin-bottom: 0px;
}

.plavci-message.plavci-errors {
    background: #ffeaea;
    border: 1px solid #f5b5b5;
    color: #9b1c1c;
}

.plavci-message.plavci-errors ul {
    margin: 0;
    padding-left: 18px;
}

.plavci-message.plavci-success {
    background: #e7f7eb;
    border: 1px solid #a7d7b5;
    color: #22663a;
}

/* Zabudnuté heslo */

.plavci-lost-password {
    margin-top: 10px;
    text-align: right;
    font-size: 13px;
}

.plavci-lost-password a {
    text-decoration: underline;
}

.plavci-lost-password a:hover {
    text-decoration: none;
}

/* Account layout – 2 stĺpce */

.plavci-account {
    margin: 20px auto 40px;
}

.plavci-account-layout {
    margin: 16px auto 40px;
    display: flex;
    gap: 32px;
}

/* Sidebar */

.plavci-account-sidebar {
    width: 340px;
    flex-shrink: 0;
    border-radius: 0px;
    padding: 0px;
    box-sizing: border-box;
        border-right: 1px solid #d6e6f2;
        padding-right: 32px;
}

.plavci-account-user {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
}

.plavci-account-avatar img,
.plavci-account-thumb {
    width: 60px !important;
    height: 60px !important;
    border-radius: 999px !important;
    object-fit: cover;
    display: block;
}

.plavci-account-user-text {
    flex: 1;
}

.plavci-account-username {
    font-size: 12px;
    color: #6b7280;
    margin-bottom: 0px;
}

.plavci-account-name {
    font-size: 18px;
    font-weight: 600;
}

/* Krátke O mne v sidebare */

.plavci-account-about-short {
    font-size: 14px;
    color: #071d52;
    margin-bottom: 12px;
}

.plavci-account-about-short p {
    margin: 0 0 8px;
}

.plavci-account-club {
    font-size: 14px;
    color: #071d52;
    margin-bottom: 0px;
}

/* Menu v sidebare */

.plavci-account-menu {
    display: flex;
    flex-direction: column;
    gap: 8px;
    position: relative;
}

.plavci-account-menu-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 4px;
    text-decoration: none !important;
    font-size: 14px;
    color: #111827;
    border: 1px solid transparent;
    background: transparent;
    transition: background-color 0.1s ease, border-color 0.1s ease, color 0.1s ease, transform 0.1s ease;
}

.plavci-account-menu-item:hover {
    background: inherit;
    border-color: #2DC3FD;
    transform: translateY(-1px);
}

.plavci-account-menu-item.is-active {
    background: #e6f4ff;
    border-color: #2DC3FD;
    color: #071d52;
}

.plavci-account-menu-item.is-active .plavci-account-menu-label {
    font-weight: 500;
}

.plavci-account-menu-icon img {
    width: 16px;
    height: 16px;
    display: block;
}

.plavci-account-menu-logout {
    margin-top: 16px;
    opacity: 0.6;
}

/* Pravý obsah účtu */

.plavci-account-content {
    width: 100%;
}

.plavci-account-content h2 {
    font-size: 28px;
    margin-bottom: 16px;
    color: #071d52;
    font-weight: 700;
}

/* Malý náhľad aktuálnej fotky v edit forme */

.plavci-account-current-photo {
    margin-bottom: 8px;
}

.plavci-account-current-photo img.plavci-account-thumb-small {
    width: 56px;
    height: 56px;
    border-radius: 999px;
    object-fit: cover;
}

/* Nadpis a sekčné labely v edit forme */

.plavci-account-form-title {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
}

.plavci-section-label {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #6b7280;
    margin-bottom: 4px;
}

/* Sekcia O mne (ak ju neskôr použijeme mimo sidebaru) */

.plavci-account-about {
    margin-top: 16px;
}

.plavci-account-about h3 {
    font-size: 18px;
    margin-bottom: 8px;
}

.plavci-account-about p {
    margin: 0 0 8px;
    line-height: 1.6;
}

/* Zoznam plavieb */

.plavci-swim-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

.plavci-swim-table thead {
    background: #f5f5f7;
}

.plavci-swim-table th,
.plavci-swim-table td {
    padding: 10px 12px;
    border-bottom: 1px solid #e5e7eb;
    text-align: left;
}

.plavci-swim-table th {
    font-weight: 600;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #6b7280;
}

/* Link v tabuľke detailu plavby */

.plavci-account-link.plavci-swim-detail {
    display: inline-block;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 13px;
    text-decoration: none;
    border: 1px solid #dde1ec;
    background: #f9fafb;
    color: #111827;
    transition: background-color 0.1s ease, border-color 0.1s ease, transform 0.1s ease;
}

.plavci-account-link.plavci-swim-detail:hover {
    background: #e5f5ff;
    border-color: #2DC3FD;
    transform: translateY(-1px);
}

/* Upload box pre foto plavby */

.plavci-photos-upload-box input[type="file"] {
    display: block;
    margin-top: 6px;
}

/* Header riadok v sekcii Moje plavby */

.plavci-account-header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

/* Detail plavby */

.plavci-swim-title {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 6px;
    color: #071d52;
}

.plavci-swim-meta {
    font-size: 14px;
    color: #071d52;
    margin-bottom: 12px;
}

.plavci-swim-meta-item + .plavci-swim-meta-item {
    margin-left: 6px;
}

.plavci-swim-single-photo {
    margin: 16px 0 20px;
}

.plavci-swim-single-photo img {
    width: 100%;
    height: auto;
    border-radius: 16px;
}

/* Info grid (vzdialenosť, čas, štýl…) */

.plavci-swim-single-info {
    margin-bottom: 20px;
}

.plavci-swim-info-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 32px;
}

.plavci-swim-info-item {
    padding: 10px 12px;
    border-radius: 12px;
    background: #f9fafb;
}

.plavci-swim-info-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #6b7280;
    margin-bottom: 4px;
}

.plavci-swim-info-value {
    font-size: 15px;
    font-weight: 500;
    color: #111827;
}

/* Popis plavby */

.plavci-swim-description {
    margin-top: 16px;
}

.plavci-swim-description h3 {
    font-size: 18px;
    margin-bottom: 8px;
}

/* Mapa */

.plavci-swim-map-wrapper {
    margin-top: 24px;
}

.plavci-swim-map-title {
    font-size: 18px;
    margin-bottom: 8px;
}

.plavci-swim-map {
    width: 100%;
    height: 400px;
    border-radius: 12px;
    overflow: hidden;
}

.plavci-sidebar-header {
    padding: 24px;
    border-radius: 10px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.10);
    margin-bottom: 32px;
}


/* RESPONSIVE – tablet/mobil */

@media (max-width: 768px) {
    .plavci-account-layout {
        flex-direction: column;
        gap: 20px;
        margin: 16px auto 32px;
    }

    .plavci-account-sidebar {
        width: 100%;
        padding: 0px;
        margin-bottom: 4px;
    }

    .plavci-account-menu {
        flex-direction: row;
        overflow-x: auto;
        overflow-y: hidden;
        padding-bottom: 6px;
        margin: 0 -4px;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }

    .plavci-account-menu-item {
        flex: 0 0 auto;
        margin: 0 4px;
        white-space: nowrap;
        scroll-snap-align: start;

    }

     .plavci-account-menu {
        position: relative;
    }

    .plavci-account-menu::after {
        content: 'Potiahni →';
        position: sticky;
        right: 0;
        bottom: 0;
        align-self: flex-end;
        font-size: 11px;
        color: #6b7280;
        padding: 2px 10px 4px 24px;
        background: linear-gradient(to left, #ffffff 70%, rgba(255,255,255,0));
        pointer-events: none;
        z-index: 2;
    }

    .plavci-account-header-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .plavci-account-header-row .plavci-swim-add {
        width: 100%;
        text-align: center;
    }

    .plavci-swim-info-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .plavci-swim-map {
        height: 260px;
    }
}

/* Extra úzke mobily */

@media (max-width: 480px) {
    .plavci-swim-info-grid {
        grid-template-columns: 1fr;
    }
}




.plavci-swim-row {
    display: grid;
    grid-template-columns: 120px minmax(0, 2fr) 130px 130px 100px;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    box-sizing: border-box;
}

.plavci-swim-row-head {
    background: #E6F4FF;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #6b7280;
}

.plavci-swim-row-body {
    text-decoration: none;
    color: #111827;
    transition: background-color 0.12s ease, box-shadow 0.12s ease, transform 0.12s ease;
    cursor: pointer;
    text-decoration: none !important;
}

.plavci-swim-row-body:hover {
    background: #f5fbff;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
    transform: translateY(-1px);
}

.plavci-swim-cell {
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.plavci-swim-cell-date {
    font-variant-numeric: tabular-nums;
}

.plavci-swim-cell-location {
    font-weight: 500;
    color: #071d52;
}

.plavci-swim-cell-water-temp,
.plavci-swim-cell-distance {
    font-size: 13px;
    color: #4b5563;
}

.plavci-swim-cell-detail {
    text-align: right;
}

.plavci-swim-detail-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: 4px;
    border: 1px solid #dde1ec;
    background: #f9fafb;
    font-size: 12px;
    font-weight: 500;
    color: #111827;
    text-decoration: none;
    transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease, transform 0.12s ease;
}

.plavci-swim-row-body:hover .plavci-swim-detail-btn {

}

/* Mobilné zobrazenie */

@media (max-width: 768px) {
    .plavci-swim-list {
        border-radius: 10px;
    }

    .plavci-swim-row-head {
        display: none;
    }

    .plavci-swim-row-body {
        grid-template-columns: minmax(0, 1fr) auto;
        grid-template-rows: auto auto auto;
        gap: 4px 8px;
        padding: 10px 12px;
    }

    .plavci-swim-cell-location {
        grid-column: 1 / 2;
        grid-row: 1 / 2;
        font-size: 15px;
    }

    .plavci-swim-cell-date {
        grid-column: 1 / 2;
        grid-row: 2 / 3;
        font-size: 13px;
        color: #6b7280;
    }

    .plavci-swim-cell-water-temp,
    .plavci-swim-cell-distance {
        grid-row: 3 / 4;
        font-size: 12px;
        white-space: nowrap;
    }

    .plavci-swim-cell-water-temp {
        grid-column: 1 / 2;
    }

    .plavci-swim-cell-distance {
        grid-column: 1 / 2;
        margin-left: 0;
    }

    .plavci-swim-cell-detail {
        grid-column: 2 / 3;
        grid-row: 1 / 4;
        align-self: center;
    }
}


.plavci-share-box {
    margin-top: 24px;
    padding: 12px 16px;
    border-radius: 10px;
    background: #E6F4FF;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.plavci-share-label {
    font-size: 14px;
    font-weight: 500;
    color: #071d52;
}

.plavci-share-buttons {
    display: flex;
    gap: 8px;
}

.plavci-share-btn {
    border-radius: 999px !important;
    border: none !important;
    padding: 6px !important;
    background: #ffffff !important;
    cursor: pointer;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background-color .15s ease, border-color .15s ease, transform .1s ease !important;
    position: relative;
}

.plavci-share-copied::after {
    content: 'Link skopírovaný';
    position: absolute;
    left: 50%;
    bottom: 20%;
    transform: translateX(-50%);
    font-size: 11px;
    background: #071d52;
    color: #e6f4ff;
    padding: 3px 8px;
    border-radius: 999px;
    white-space: nowrap;
    box-shadow: 0 4px 10px rgba(15, 23, 42, 0.3);
    z-index: 5;
}


.plavci-share-btn:hover {
    background: #e5f5ff;
    border-color: #2DC3FD;
    transform: translateY(-1px);
}

.plavci-share-btn svg {
    width: 18px;
    height: 18px;
}

.plavci-share-copied::after {
    content: 'Skopírované';
    position: absolute;
    font-size: 11px;
    background: #071d52;
    color: #e6f4ff;
    padding: 2px 6px;
    border-radius: 999px;
    transform: translateY(-140%);
}


.plavci-swimmers-list {
    margin-top: 16px;
}

.plavci-swimmers-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.plavci-swimmer-card {
    flex: 1 1 calc(25% - 15px);
    min-width: 220px;
    max-width: calc(25% - 15px);
    box-sizing: border-box;
    background: #ffffff;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    padding: 16px;
    text-decoration: none;
    color: #111827;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: background-color 0.12s ease, box-shadow 0.12s ease, transform 0.12s ease, border-color 0.12s ease;
}

.plavci-swimmer-card-main {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.plavci-swimmer-card-footer {
    margin-top: 6px;
}

.plavci-swimmer-card-button {
    display: inline-block;
    padding: 6px 12px;
    border-radius: 4px;
    border: 1px solid #dde1ec;
    background: #f9fafb;
    font-size: 13px;
    font-weight: 500;
    color: #071d52;
}

.plavci-swimmer-card:hover {
    background: #f9fafb;
    border-color: #2DC3FD;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
    transform: translateY(-2px);
}

.plavci-swimmer-card:hover .plavci-swimmer-card-button {
    background: #071d52;
    color: #e6f4ff;
    border-color: #071d52;
}

@media (max-width: 1024px) {
    .plavci-swimmers-grid {
        gap: 16px;
    }

    .plavci-swimmer-card {
        flex: 1 1 calc(33.333% - 12px);
        max-width: calc(33.333% - 12px);
    }
}

@media (max-width: 768px) {
    .plavci-swimmer-card {
        flex: 1 1 calc(50% - 10px);
        max-width: calc(50% - 10px);
    }
}

@media (max-width: 480px) {
    .plavci-swimmer-card {
        flex: 1 1 100%;
        max-width: 100%;
    }
}

/* Všetky plavby – „div tabuľka“ */

.plavci-swim-list {
    margin-top: 16px;
    border-radius: 8px;
    background: #ffffff;
    overflow: hidden;
    font-size: 14px;
}

.plavci-swim-row-link {
    display: block;
    text-decoration: none !important;
    color: inherit;
}

.plavci-swim-row {
    display: grid;
    grid-template-columns: 110px minmax(0, 1.4fr) 120px 120px 140px;
    column-gap: 12px;
    align-items: center;
    padding: 10px 12px;
    transition: background-color 0.12s ease, transform 0.12s ease;
}

.plavci-swim-row-link:hover .plavci-swim-row {
    background: #e6f4ff;
    transform: translateY(-1px);
}
.plavci-swim-list-head, .plavci-swim-list-body .plavci-swim-row  {
    grid-template-columns: 110px minmax(0, 1.4fr) 120px 120px 140px 90px;
}
.plavci-swim-list-head {
    background: #E6F4FF;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #6b7280;
    font-weight: 600;
    border: none !important;
}

.plavci-swim-list-head .plavci-swim-row {
    transform: none;
}

.plavci-swim-cell {
    min-width: 0;
}


.plavci-swim-cell-date,
.plavci-swim-cell-location,
.plavci-swim-cell-temp,
.plavci-swim-cell-distance,
.plavci-swim-cell-swimmer {
    font-weight: 500;
    color: #4b5563;
    font-size: 13px;
}

.plavci-swim-cell-action {
    text-align: right;
}

.plavci-swim-detail-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: 4px;
    border: 1px solid #dde1ec;
    background: #f9fafb;
    font-size: 12px;
    font-weight: 500;
    color: #111827;
    white-space: nowrap;
    transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease;
}

.plavci-swim-row-link:hover .plavci-swim-detail-pill {
    background: #071d52;
    color: #e6f4ff;
}

.plavci-swim-pagination {
    margin-top: 16px;
    text-align: center;
    font-size: 14px;
}

.plavci-swim-pagination .page-numbers {
    display: inline-flex;
    gap: 6px;
    padding-left: 0;
    list-style: none;
    margin: 0;
}

.plavci-swim-pagination .page-numbers li {
    display: inline-block;
}

.plavci-swim-pagination .page-numbers a,
.plavci-swim-pagination .page-numbers span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 8px;
    border-radius: 999px;
    border: 1px solid transparent;
    text-decoration: none;
    color: #111827;
    background: #f9fafb;
    font-size: 13px;
}

.plavci-swim-pagination .page-numbers a:hover {
    border-color: #2DC3FD;
    background: #e5f5ff;
}

.plavci-swim-pagination .page-numbers .current {
    border-color: #071d52;
    background: #071d52;
    color: #e6f4ff;
}

/* Mobilné zobrazenie – plavby ako karty */

@media (max-width: 768px) {
    .plavci-swim-list {
        border: none;
        background: transparent;
    }

    .plavci-swim-list-head {
        display: none;
    }

    .plavci-swim-row-link {
        margin-bottom: 10px;
    }

    .plavci-swim-row {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
        padding: 10px 12px;
        border-radius: 8px;
        background: #ffffff;
    }

    .plavci-swim-row-link:hover .plavci-swim-row {
        transform: translateY(-1px);
    }

    .plavci-swim-cell {
        width: 100%;
        font-size: 13px;
    }

    .plavci-swim-cell-date {
        font-size: 14px;
        font-weight: 600;
        color: #071d52;
    }

    .plavci-swim-cell-location {
        font-weight: 500;
    }

    .plavci-swim-cell-action {
        align-self: flex-end;
        margin-top: 4px;
    }
}


@media (max-width: 768px) {
    .plavci-account-content .plavci-swim-list {
        margin-top: 12px;
        border-radius: 8px;
        background: transparent;
    }

    .plavci-account-content .plavci-swim-row-head {
        display: none;
    }

    .plavci-account-content .plavci-swim-list > .plavci-swim-row {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        gap: 4px 8px;
        padding: 10px 12px;
        margin-bottom: 10px;
        border-radius: 8px;
        background: #ffffff;
        box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
    }

    .plavci-account-content .plavci-swim-list > .plavci-swim-row:hover {
        background: #f5fbff;
        transform: translateY(-1px);
    }

    .plavci-account-content .plavci-swim-col {
        min-width: 0;
    }

    .plavci-account-content .plavci-swim-col-location {
        order: 1;
        width: 100%;
        font-size: 15px;
        font-weight: 600;
        color: #071d52;
    }

    .plavci-account-content .plavci-swim-col-date {
        order: 2;
        width: 100%;
        font-size: 13px;
        color: #6b7280;
    }

    .plavci-account-content .plavci-swim-col-water,
    .plavci-account-content .plavci-swim-col-distance {
        order: 3;
        font-size: 12px;
        color: #4b5563;
        margin-right: 12px;
        white-space: nowrap;
    }

    .plavci-account-content .plavci-swim-col-action {
        order: 4;
        width: 100%;
        text-align: right;
        margin-top: 4px;
    }

    .plavci-account-content .plavci-swim-detail-pill {
        font-size: 12px;
    }
}

.plavci-swim-col-action {
    text-align: right;
}


.plavci-all-swims {
    margin-top: 16px;
}

.plavci-all-swims-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.plavci-all-swim-card {
    flex: 1 1 calc(25% - 15px);
    min-width: 240px;
    max-width: calc(25% - 15px);
    box-sizing: border-box;
    background: #ffffff;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    padding: 16px;
    text-decoration: none !important;
    color: #111827;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: background-color 0.12s ease, box-shadow 0.12s ease, transform 0.12s ease, border-color 0.12s ease;
}

.plavci-all-swim-card:hover {
    background: #f9fafb;
    border-color: #2DC3FD;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
    transform: translateY(-2px);
}

.plavci-all-swim-card-top {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.plavci-all-swim-user {
    min-width: 0;
    flex: 1;
}

.plavci-all-swim-meta {
    font-size: 12px;
    color: #6b7280;
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.plavci-all-swim-meta span:first-child {
    margin-right: 4px;
}

.plavci-all-swim-stats {
    display: grid;
    gap: 8px;
    margin-top: 8px;
    margin-bottom: 14px;
}

.plavci-all-swim-stat {
    display: grid;
    grid-template-columns: 18px 1fr auto;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 10px;
    background: #f9fafb;
}

.plavci-all-swim-ico svg {
    width: 16px;
    height: 16px;
    display: block;
}

.plavci-all-swim-label {
    font-size: 12px;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: .06em;
    font-weight: 600;
}

.plavci-all-swim-value {
    font-size: 13px;
    font-weight: 600;
    color: #071d52;
    white-space: nowrap;
}

.plavci-all-swim-card-footer {
    margin-top: auto;
}

.plavci-all-swim-card:hover .plavci-swimmer-card-button {
    background: #071d52;
    color: #e6f4ff;
    border-color: #071d52;
}

/* Responsive */
@media (max-width: 1024px) {
    .plavci-all-swim-card {
        flex: 1 1 calc(33.333% - 12px);
        max-width: calc(33.333% - 12px);
    }
}

@media (max-width: 768px) {
    .plavci-all-swim-card {
        flex: 1 1 calc(50% - 10px);
        max-width: calc(50% - 10px);
    }
}

@media (max-width: 560px) {
    .plavci-all-swim-card {
        flex: 1 1 100%;
        max-width: 100%;
    }
}
