@import url('https://fonts.googleapis.com/css2?family=Ephesis&display=swap');

:root {
    /* základní barvy značky */
    --tp-blue-dark: #04101a;      /* tmavě modrá (text / akcent) */
    --tp-blue-light: #0fa5eb;     /* světle modrá (akcent) */
    --tp-orange: #FF8503;
    --tp-blue: #0fa5eb;
    --tp-neon-cyan: #22d3ee;
    --tp-neon-teal: #5eead4;
    --tp-bg-deep: #02030b;
    --tp-bg-elevated: #050818;
    --tp-dashboard-card-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9);

    /* textové barvy (zarovnané s „běžným“ vzhledem) */
    --tp-color-text-main: #212529;
    --tp-color-accent: #0fa5eb;

    /* výška navbaru pro výpočty v hero */
    --tp-navbar-height: 72px;
}

[data-theme-style="dark"] {
    /* základní barvy značky – zůstávají stejné */
    --tp-blue-dark: #04101a;
    --tp-blue-light: #0fa5eb;
    --tp-orange: #FF8503;
    --tp-neon-cyan: #22d3ee;
    --tp-neon-teal: #5eead4;

    /* pozadí */
    --tp-bg-deep: #02030b;
    --tp-bg-elevated: #050818;

    /* textové barvy (dark) */
    --tp-color-text-main: rgba(255, 255, 255, 0.92);
    --tp-color-text-muted: rgba(220, 230, 255, 0.72);
    --tp-color-text-subtle: rgba(220, 230, 255, 0.55);
    --tp-dashboard-card-shadow: 0 3px 8px rgb(0 0 0 / 28%), inset 0 1px 0 rgba(255, 255, 255, .08);

    /* akcenty */
    --tp-color-accent: #22d3ee;
    --tp-color-accent-soft: rgba(34, 211, 238, 0.18);

    /* linky / bordery */
    --tp-border-soft: rgba(255, 255, 255, 0.10);
    --tp-border-strong: rgba(255, 255, 255, 0.18);
}

h2:has(.text-primary){
  font-weight: 850;
  letter-spacing: -0.02em;
}


/* Globálně – system fonty */
body {
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text",
                 "SF Pro Display", system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* šířka stránky a žádný horizontální scroll */
html, body {
    max-width: 100%;
    overflow-x: hidden;
}

/* default: nic */
#transfer-branding-en,
#transfer-branding-cs { display: none !important; }

/* čeština (cs / cs-cz / cz) */
html[lang^="cs"] #transfer-branding-cs,
html[lang^="cz"] #transfer-branding-cs { display: block !important; }

/* ostatní jazyky = EN */
html:not([lang^="cs"]):not([lang^="cz"]) #transfer-branding-en { display: block !important; }

.announcement-wrapper {
    margin: 0rem;
    opacity: 0;
    transition: opacity .1s ease-in;
    animation: ac-fade-in-down .0s ease-in .0s forwards;
    border-radius: 0rem;
}

.accordion > .card{
  margin-bottom: 5px;
}

.navbar-logo-mini {
    max-height: 1.12rem;
    height: 1.12rem;
}

.alert-info {
    color: hsl(221, 39%, 11%);
    background-color: #deecf7;
}

.text-info {
    color: hsl(221, 39%, 11%) !important;
}

.alert {
    padding: 1rem 1.25rem;
    margin-bottom: 2rem;
    border: 0 solid rgba(0, 0, 0, 0);
    border-radius: 0.8rem;
}

.table-responsive, .card:not(#upload_main_dropzone):not(.tp-feature-section .card):not(.tp-trust-block .card):not(.tp-features .card):not(.tp-ctahome .card):not(.tp-testimonials .card):not(.tp-dashboard-summary-card):not(.tp-dashboard-conversion-card) {
    border-radius: 18px;
    box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9);
    background: #ffffff;
}

[data-theme-style="dark"] .table-responsive, [data-theme-style="dark"] .card:not(#upload_main_dropzone):not(.tp-feature-section .card):not(.tp-trust-block .card):not(.tp-features .card):not(.tp-ctahome .card):not(.tp-testimonials .card):not(.tp-dashboard-summary-card):not(.tp-dashboard-conversion-card) {
    border-radius: 18px;
    background: linear-gradient(180deg, #161a23 0%, #101319 100%);
    box-shadow:0 5px 16px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
 
.table-custom {
    background: transparent;
}

.table.table-custom tbody tr:nth-child(even) {
    background: #ecf8ff61;
}

[data-theme-style="dark"] .table.table-custom tbody tr:nth-child(even) {
    background: rgba(95, 170, 227, 0.08);
}

/* Statistiky přenosu/stahování: menší a čistší text ve sloupcích "Odkud přišli" + "Vytvořeno" */
.tp-stats-split-layout .tp-split-content .table-responsive.table-custom-container .table.table-custom tbody td:nth-child(4),
.tp-stats-split-layout .tp-split-content .table-responsive.table-custom-container .table.table-custom tbody td:nth-child(5) {
    font-size: .92rem !important;
    line-height: 1.25 !important;
}

.tp-stats-split-layout .tp-split-content .table-responsive.table-custom-container .table.table-custom tbody td:nth-child(4) > span,
.tp-stats-split-layout .tp-split-content .table-responsive.table-custom-container .table.table-custom tbody td:nth-child(4) > a:not(.text-muted),
.tp-stats-split-layout .tp-split-content .table-responsive.table-custom-container .table.table-custom tbody td:nth-child(5) > span.text-muted[data-toggle="tooltip"] {
    font-size: .92rem !important;
    line-height: 1.25 !important;
}

/* Dlouhé referrer odkazy: zkrácený text, ale plný href/title zůstává */
.tp-stats-split-layout .tp-split-content .table-responsive.table-custom-container .table.table-custom tbody td:nth-child(4) > a:not(.text-muted) {
    display: inline-block;
    max-width: min(16rem, 20vw);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: middle;
}

/* Detail přenosu (Přehled): tabulky "Nejnovější záznamy" a "Stažení souborů" */
.tp-transfer-latest-entries-table .table.table-custom tbody td:nth-child(4),
.tp-transfer-latest-entries-table .table.table-custom tbody td:nth-child(5),
.tp-transfer-latest-downloads-table .table.table-custom tbody td:nth-child(4),
.tp-transfer-latest-downloads-table .table.table-custom tbody td:nth-child(5) {
    font-size: .84rem !important;
    line-height: 1.2 !important;
}

.tp-transfer-latest-entries-table .table.table-custom tbody td:nth-child(4) > span,
.tp-transfer-latest-entries-table .table.table-custom tbody td:nth-child(4) > a:not(.text-muted),
.tp-transfer-latest-entries-table .table.table-custom tbody td:nth-child(5) > span.text-muted[data-toggle="tooltip"],
.tp-transfer-latest-downloads-table .table.table-custom tbody td:nth-child(4) > span,
.tp-transfer-latest-downloads-table .table.table-custom tbody td:nth-child(4) > a:not(.text-muted),
.tp-transfer-latest-downloads-table .table.table-custom tbody td:nth-child(5) > span.text-muted[data-toggle="tooltip"] {
    font-size: .84rem !important;
    line-height: 1.2 !important;
}

.tp-transfer-latest-entries-table .table.table-custom tbody td:nth-child(4) > a:not(.text-muted),
.tp-transfer-latest-downloads-table .table.table-custom tbody td:nth-child(4) > a:not(.text-muted) {
    display: inline-block;
    max-width: min(12rem, 14vw);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: middle;
}

.tp-stats-split-layout .tp-split-content .table-responsive.table-custom-container .table.table-custom tbody td:nth-child(4) > a:not(.text-muted),
.tp-transfer-latest-entries-table .table.table-custom tbody td:nth-child(4) > a:not(.text-muted),
.tp-transfer-latest-downloads-table .table.table-custom tbody td:nth-child(4) > a:not(.text-muted) {
    max-width: min(11rem, 16vw);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: middle;
}

/* Statistiky přenosu/stahování: export button (starý dropdown-toggle-simple) -> nový utility styl */
.tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple {
    min-width: 42px;
    width: 42px;
    height: 42px;
    padding: .35rem !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: .85rem !important;
    border: 1px solid rgba(15, 165, 235, .22) !important;
    background: #ffffff !important;
    color: #10253f !important;
    box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
    transition: background .16s ease, border-color .16s ease, color .16s ease, box-shadow .16s ease !important;
}

.tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple:hover,
.tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple:focus-visible {
    background: linear-gradient(180deg, rgba(239, 248, 255, .98), rgba(222, 241, 255, .96)) !important;
    border-color: rgba(15, 165, 235, .28) !important;
    color: #12347C !important;
    box-shadow: 0 4px 10px rgba(6, 16, 34, .08), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
    transform: none !important;
}

.tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple::after {
    display: none !important;
}

.tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple i,
.tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple svg {
    color: inherit !important;
}

.tp-stats-split-layout .tp-split-content .dropdown .dropdown-menu {
    margin-top: .55rem !important;
    border-radius: 14px !important;
    border: 1px solid rgba(15, 165, 235, .16) !important;
    background: #ffffff !important;
    box-shadow: 0 12px 26px rgba(6, 16, 34, .12), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
    overflow: hidden;
    z-index: 1040;
}

/* Statistiky (kontinenty/země/města/referrer/zařízení/OS/prohlížeče/jazyky/UTM/hodiny):
   zarovnání pravé hodnoty bez zbytečně velké mezery */
.tp-stats-split-layout .tp-split-content .mt-4 > .d-flex.justify-content-between.mb-1 > div:last-child {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    column-gap: .36rem !important;
}

.tp-stats-split-layout .tp-split-content .mt-4 > .d-flex.justify-content-between.mb-1 > div:last-child > span.ml-3 {
    margin-left: .18rem !important;
}

/* Fallback: některé statistiky mají lehce odlišný markup, drž stejné rozestupy */
.tp-stats-split-layout .tp-split-content .mt-4 .d-flex.justify-content-between > div:last-child {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: .36rem !important;
}

.tp-stats-split-layout .tp-split-content .mt-4 .d-flex.justify-content-between > div:last-child .ml-3 {
    margin-left: .18rem !important;
}

/* Hard override for bootstrap spacing in transfer stats right-side values */
.tp-stats-split-layout .ml-3 {
    margin-left: .18rem !important;
}

[data-theme-style="dark"] .tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple {
    border-color: rgba(90, 177, 237, .34) !important;
    background: linear-gradient(180deg, rgba(13, 19, 30, .96), rgba(9, 14, 24, .94)) !important;
    color: rgba(237, 245, 255, .92) !important;
    box-shadow: 0 8px 18px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 255, 255, .08) !important;
}

[data-theme-style="dark"] .tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple:hover,
[data-theme-style="dark"] .tp-stats-split-layout .tp-split-content .dropdown > .btn.dropdown-toggle-simple:focus-visible {
    background: linear-gradient(180deg, rgba(22, 94, 160, .78), rgba(18, 52, 124, .72)) !important;
    border-color: rgba(110, 193, 249, .42) !important;
    color: #ffffff !important;
    transform: none !important;
}

[data-theme-style="dark"] .tp-stats-split-layout .tp-split-content .dropdown .dropdown-menu {
    border-color: rgba(255, 255, 255, .08) !important;
    background: linear-gradient(180deg, #161a23 0%, #101319 100%) !important;
    box-shadow: 0 12px 26px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255, 255, 255, .06) !important;
}

/* Apple-like hero nadpis + podnadpis – specificky jen v hero */
.tp-hero .index-header {
    font-size: 3.8rem;
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: #04101a;  
    text-shadow: 0 0 10px #07121c4a;
}

[data-theme-style="dark"] .tp-hero .index-header {
    color: #ffffffeb;  
    text-shadow: 0 0 10px #07121c4a;
}

.tp-hero .index-subheader {
    margin-top: 1rem;
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
    font-size: 1.30rem;
    line-height: 1.4;
    color: #04101aba;
}
[data-theme-style="dark"] .tp-hero .index-subheader {
    color: #dce6ff;
}
/* Globální headline/podheadline (pro jiné stránky) */
.index-header {
    font-weight: 700;
    letter-spacing: 0.03em;
    color: var(--tp-color-accent);
}

.index-subheader {
    font-weight: 400;
    color:#6c757d;
}

/* Texty v kartách / nastaveních */
.card,
.form-control,
label {
    color: var(--tp-color-text-main);
}


.tp-hero {
    position: relative;
    width: 100%;
    overflow: visible;              /* kvůli stínu pod hero */

    /* vytáhneme sekci nahoru pod menu */
    margin-top: calc(-1.3 * var(--tp-navbar-height));

    /* obsah vrátíme dolů, aby seděl pod navbar */
    padding-top: calc(var(--tp-navbar-height) + .9rem);
    padding-bottom: 1.2rem;
    z-index: 0;                     /* pod navbar, nad pozadím */
    --tp-hero-collapsed-min-height: 100svh;
    height: var(--tp-hero-collapsed-min-height);
    min-height: var(--tp-hero-collapsed-min-height);
    transition: min-height .34s ease, height .34s ease, padding-bottom .34s ease;
  }

.tp-hero.tp-hero-expanded {
    height: auto;
    min-height: auto;
    padding-bottom: 2.4rem;
}

@media (min-width: 769px) {
    .tp-hero .container.mt-5 {
        min-height: calc(100svh - var(--tp-navbar-height) - .5rem);
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .tp-hero #upload_main_dropzone {
        min-height: clamp(500px, 66svh, 760px);
        display: flex;
        transform: translateY(clamp(-58px, -5svh, -26px));
    }

    .tp-hero #upload_main_dropzone > .card-body {
        width: 100%;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .tp-hero.tp-hero-expanded .container.mt-5 {
        min-height: auto;
        justify-content: flex-start;
        padding-top: .9rem !important;
    }

    .tp-hero.tp-hero-expanded #upload_main_dropzone {
        min-height: auto;
        transform: none;
    }

    .tp-hero.tp-hero-expanded #upload_main_dropzone > .card-body {
        justify-content: flex-start;
    }
}

@media (max-width: 768px) {
    .tp-hero {
        padding-bottom: 4rem;
        --tp-hero-collapsed-min-height: 100vh;
        height: var(--tp-hero-collapsed-min-height);
        min-height: var(--tp-hero-collapsed-min-height);
    }

    @supports (height: 100svh) {
        .tp-hero {
            --tp-hero-collapsed-min-height: 100svh;
        }
    }

    @supports (height: 100dvh) {
        .tp-hero {
            --tp-hero-collapsed-min-height: 100dvh;
        }
    }

    .tp-hero .container.mt-5 {
        margin-top: 0 !important;
        padding-top: 0 !important;
        min-height: calc(var(--tp-hero-collapsed-min-height) - var(--tp-navbar-height));
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .tp-hero #upload_main_dropzone {
        padding-bottom: 0rem !important;
        padding-top: 2rem !important;
        min-height: clamp(360px, 58svh, 640px);
        display: flex;
    }

    .tp-hero #upload_main_dropzone > .card-body {
        width: 100%;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .tp-hero.tp-hero-expanded {
        margin-top: 0;
        padding-top: calc(var(--tp-navbar-height) + .25rem);
        height: auto;
        min-height: auto;
    }

    /* Keep uploader content below navbar, but pull only background up to remove top gap. */
    .tp-hero.tp-hero-expanded::before,
    .tp-hero.tp-hero-expanded::after {
        top: calc(-1.3 * var(--tp-navbar-height));
        bottom: 0;
    }

    .tp-hero.tp-hero-expanded .container.mt-5 {
        min-height: auto;
        justify-content: flex-start;
    }

    .tp-hero.tp-hero-expanded #upload_main_dropzone {
        min-height: auto;
        padding-top: .85rem !important;
    }

    .tp-hero.tp-hero-expanded #upload_main_dropzone > .card-body {
        justify-content: flex-start;
    }

    .tp-hero .index-header {
        font-size: 2.4rem;
        line-height: 1.05;
    }
}

/* Obrázek v pozadí hero */
.tp-hero {
    --tp-hero-bg-image: url(https://transferplus.s3.eu-central-1.amazonaws.com/assets/images/bg/tp-hero-wave-l.webp?v=20260415-1);
    --tp-hero-bg-fallback: #ffffff;
    --tp-hero-crossfade-ms: 1200ms;
    --tp-hero-bg-pos-current: center top;
    --tp-hero-bg-pos-next: center top;
    --tp-hero-bg-pos-current-end: center top;
    --tp-hero-bg-pos-next-end: center top;
    --tp-hero-bg-scale-current: 1.02;
    --tp-hero-bg-scale-next: 1.03;
    --tp-hero-bg-scale-current-end: 1.006;
    --tp-hero-bg-scale-next-end: 1.01;
    background-color: var(--tp-hero-bg-fallback);
    transition: background-color var(--tp-hero-crossfade-ms) cubic-bezier(.22, .61, .36, 1);
}

.tp-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--tp-hero-bg-image);
    background-size: 100% auto;
    background-position: var(--tp-hero-bg-pos-current);
    background-repeat: no-repeat;
    background-color: var(--tp-hero-bg-fallback);
    overflow: hidden;

    z-index: -2;
    pointer-events: none;
    opacity: 0;
    transform: scale(var(--tp-hero-bg-scale-current)) translateZ(0);
    transition:
        opacity var(--tp-hero-crossfade-ms) cubic-bezier(.22, .61, .36, 1),
        transform var(--tp-hero-crossfade-ms) cubic-bezier(.22, .61, .36, 1),
        background-position var(--tp-hero-crossfade-ms) cubic-bezier(.22, .61, .36, 1);
    will-change: opacity, transform;
}
.tp-hero.tp-hero-bg-visible::before {
    opacity: 1;
}
.tp-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--tp-hero-bg-next-image, none);
    background-size: 100% auto;
    background-position: var(--tp-hero-bg-pos-next);
    background-repeat: no-repeat;
    background-color: var(--tp-hero-bg-next-fallback, transparent);
    opacity: 0;
    transform: scale(var(--tp-hero-bg-scale-next)) translateZ(0);
    transition:
        opacity var(--tp-hero-crossfade-ms) cubic-bezier(.22, .61, .36, 1),
        transform var(--tp-hero-crossfade-ms) cubic-bezier(.22, .61, .36, 1),
        background-position var(--tp-hero-crossfade-ms) cubic-bezier(.22, .61, .36, 1);
    will-change: opacity, transform;
    z-index: -1;
    pointer-events: none;
}
.tp-hero.tp-hero-bg-transitioning::after {
    opacity: 1;
    transform: scale(var(--tp-hero-bg-scale-next-end)) translateZ(0);
    background-position: var(--tp-hero-bg-pos-next-end);
}
.tp-hero.tp-hero-bg-transitioning::before {
    transform: scale(var(--tp-hero-bg-scale-current-end)) translateZ(0);
    background-position: var(--tp-hero-bg-pos-current-end);
}
.tp-hero:not(.tp-hero-bg-transitioning)::after {
    opacity: 0;
}

/* Safari desktop: stabilnější wallpaper přechody bez mikro-skoku */
.tp-hero.tp-hero-safari-stable::before,
.tp-hero.tp-hero-safari-stable::after {
    transform: none !important;
    background-position: center top !important;
    will-change: opacity !important;
    transition:
        opacity var(--tp-hero-crossfade-ms) cubic-bezier(.22, .61, .36, 1) !important;
}

.tp-hero.tp-hero-safari-stable.tp-hero-bg-transitioning::before,
.tp-hero.tp-hero-safari-stable.tp-hero-bg-transitioning::after {
    transform: none !important;
    background-position: center top !important;
}

@media (max-width: 768px) {
    .tp-hero {
        --tp-hero-crossfade-ms: 1650ms;
    }

    .tp-hero::before,
    .tp-hero::after {
        background-size: 240% auto;
        background-position: left -180px top;
    }
}

[data-theme-style="dark"] .tp-hero {
    --tp-hero-bg-image: url(https://transferplus.s3.eu-central-1.amazonaws.com/assets/images/bg/tp-hero-wave-d.webp?v=20260415-1);
    --tp-hero-bg-fallback: #030820;
}



/* Oprava bílé mezery nahoře v hero containeru */
.tp-hero .container.mt-4 {
    margin-top: 0 !important;
    padding-top: 1.5rem !important;
}


/* ============================================
   SECONDARY ACTION – Vybrat celou složku
   ============================================ */

#upload_select_folders{
  display: inline-flex;
  align-items: center;

  font-size: .95rem !important;
  font-weight: 500;

  color: rgba(4,16,26,.78) !important;
  opacity: .9;

  transition:
    color .22s ease,
    opacity .22s ease,
    transform .22s ease;
}

[data-theme-style="dark"] #upload_select_folders{
  color: #dce6ff;
}

/* ikonka */
#upload_select_folders svg{
  font-size: 1.05rem !important;
  margin-right: .45rem !important;
  color: rgba(4,16,26,.72) ;

  transition:
    color .22s ease,
    transform .22s ease;
}

[data-theme-style="dark"] #upload_select_folders svg{
  color: #dce6ff;
}

/* hover – jemný „lift“, žádný cirkus */
#upload_select_folders:hover{
  opacity: 1;
  color: var(--tp-blue-light) !important;
}

#upload_select_folders:hover svg{
  color: var(--tp-blue-light) !important;
}

/* uploader override: button also has .text-muted, keep text hover in sync with icon */
#upload_form #upload_select_folders:hover{
  color: var(--tp-blue-light) !important;
}

[data-theme-style="dark"] #upload_form #upload_select_folders:hover{
  color: var(--tp-blue-light) !important;
}

/* active – pocit kliknutí */
#upload_select_folders:active{
  transform: translateY(0);
}


/* ============================================
   NAVBAR – FIXED, CLEAN, UPDATE-SAFE
   Works when the "pill" is:
   A) <nav class="navbar ... bg-white rounded">
   B) <nav class="navbar ..."><div class="bg-white rounded">...</div></nav>
   ============================================ */

/* Base navbar wrapper (outer <nav>) */
nav.navbar{
  position: relative;
  z-index: 50;
  padding-top: .6rem !important;
  padding-bottom: .6rem !important;

  background: transparent !important;
  border-radius: 0 !important;
  overflow: visible !important;

  /* subtle outer shadow (keeps header readable) */
  box-shadow:
    0 18px 42px rgba(15, 23, 42, 0.08),
    0 8px 18px rgba(15, 23, 42, 0.06),
    0 2px 5px rgba(15, 23, 42, 0.055),
    0 0 0 1px rgba(15, 23, 42, 0.035),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

/* -----------------------------
   PILL BAR (LIGHT)
   Target both structures:
   - nav.navbar.bg-white.rounded
   - nav.navbar .bg-white.rounded
   ----------------------------- */
nav.navbar.bg-white.rounded,
nav.navbar .bg-white.rounded{
  position: relative;
  overflow: visible !important;

  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.98),
    rgba(236, 244, 255, 0.96)
  ) !important;

  border-radius: 4rem !important;
  border: 1px solid rgba(255, 255, 255, 0.90) !important;

}

/* inner highlight for pill */
nav.navbar.bg-white.rounded::before,
nav.navbar .bg-white.rounded::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;

  /* keep it behind contents but within pill */
  z-index: 0;

  background:
    radial-gradient(circle at 15% 0%,
      rgba(255, 255, 255, 1),
      rgba(255, 255, 255, 0.35) 32%,
      rgba(255, 255, 255, 0.0) 70%),
    linear-gradient(
      to bottom,
      rgba(255, 255, 255, 0.45),
      rgba(255, 255, 255, 0.0) 60%
    );
}

/* ensure navbar content stays above ::before */
nav.navbar.bg-white.rounded > *,
nav.navbar .bg-white.rounded > *{
  position: relative;
  z-index: 1;
}

/* container inside navbar */
nav.navbar .container{
  position: relative;
  z-index: 2;
}

/* logo */
nav.navbar .navbar-brand img.navbar-logo{
  max-height: 34px;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.25));
}

/* nav link (light) – readable, no weird glow */
nav.navbar.navbar-light .nav-link{
  color: rgba(15, 23, 42, 0.82) !important;
  text-shadow: none !important;
}
nav.navbar.navbar-light .nav-link:hover{
  color: #029cf6 !important;
    text-shadow: none !important;

}

/* do not "stick" active shine */
nav.navbar .nav-link:active,
nav.navbar .nav-link:focus,
nav.navbar .nav-link.show,
nav.navbar .nav-item.show > .nav-link,
nav.navbar .nav-link.active{
  color: rgba(15, 23, 42, 0.90) !important;
  background-color: transparent !important;
  text-shadow: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Dropdown wrapper */
nav.navbar .dropdown{ position: relative; }

/* ============================================
   MOBILE COLLAPSE PANEL (overlay, no hero shift)
   ============================================ */
@media (max-width: 991.98px){

  /* when collapse opens, it should float under pill */
  #main_navbar.navbar-collapse{
    position: absolute !important;
    left: 0;
    right: 0;
    top: calc(100% + 10px);
    z-index: 9999;

    background: linear-gradient(
      to bottom,
      rgba(255,255,255,0.995),
      rgba(236,244,255,0.985)
    ) !important;

    border: 1px solid rgba(215, 226, 245, 0.92) !important;
    border-radius: 1.1rem !important;

    box-shadow:
      0 18px 44px rgba(0,0,0,.18),
      0 6px 14px rgba(0,0,0,.10) !important;

    padding: 1rem 1.4rem !important;

    overflow: auto !important;
    -webkit-overflow-scrolling: touch;

    /* important: avoid "milk blur" glitches on mobile */
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;

    opacity: 1 !important;
  }

  #main_navbar .navbar-nav{ margin: 0 !important; }
}

/* ============================================
   DROPDOWN MENU (LIGHT) – single source of truth
   ============================================ */
nav.navbar .dropdown-menu{
  margin-top: 0.35rem !important;
  margin-left: -0.25rem !important;
  z-index: 60;

  padding: .65rem .65rem !important;
  border-radius: 1.25rem !important;

  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0.995),
    rgba(245,249,255,0.985)
  ) !important;

  border: 1px solid rgba(120, 200, 255, 0.32) !important;

  box-shadow:
    0 14px 32px rgba(0,0,0,0.18),
    0 0 0 1px rgba(255,255,255,0.70) inset,
    0 0 10px rgba(15,165,235,0.12) !important;

  backdrop-filter: blur(8px) saturate(1.08);
  -webkit-backdrop-filter: blur(8px) saturate(1.08);
}

nav.navbar .dropdown-menu .dropdown-item{
  border-radius: .7rem;
  padding: .55rem .7rem !important;

  color: rgba(15, 23, 42, 0.92) !important;
  background: transparent !important;
  margin-bottom: 0.3rem;
  transition: background .15s ease, box-shadow .15s ease, transform .15s ease;
}

nav.navbar .dropdown-menu .dropdown-item svg{
  color: rgba(15, 23, 42, 0.70) !important;
  transition: color .15s ease, filter .15s ease;
}

nav.navbar .dropdown-menu .dropdown-item:hover,
nav.navbar .dropdown-menu .dropdown-item:focus{
  background: rgba(15,165,235,0.08) !important;
  box-shadow: 0 0 0 1px rgba(15,165,235,0.18) inset !important;
}

nav.navbar .dropdown-menu .dropdown-item:hover svg,
nav.navbar .dropdown-menu .dropdown-item:focus svg{
  color: #0fa5eb !important;
  filter: drop-shadow(0 0 4px rgba(15,165,235,0.22));
}

nav.navbar .dropdown-menu .dropdown-item.active,
nav.navbar .dropdown-menu .dropdown-item:active{
  background: rgba(15,165,235,0.10) !important;
  box-shadow: 0 0 0 1px rgba(15,165,235,0.22) inset !important;
}

nav.navbar .dropdown-menu .dropdown-divider{
  border-top: 1px solid rgba(15, 23, 42, 0.08) !important;
  opacity: 1 !important;
}

/* ============================================
   NAVBAR – CTA "Vytvořit účet" (REGISTER) – orange pill
   Only affects /register link
   ============================================ */

nav.navbar.navbar-light .navbar-nav a[href*="/register"]{
  display: inline-flex;
  align-items: center;

  padding: .75rem 1.4rem !important;
  border-radius: 999px !important;

  /* oranžová pill (Transfer+ orange) */
  background: linear-gradient(180deg,
    rgba(255, 166, 70, 1) 0%,
    rgba(255, 133, 3, 1) 55%,
    rgba(235, 120, 0, 1) 100%
  ) !important;

  color: rgba(255,255,255,.96) !important;
  font-weight: 700 !important;
  margin-left: 16px;
  text-shadow: none !important;
}

@media (max-width: 991.98px){
 nav.navbar.navbar-light .navbar-nav a[href*="/register"]{
  margin-top: 5px;
  margin-left: 0px;
}
}


/* Ikona v CTA */
nav.navbar.navbar-light .navbar-nav a[href*="/register"] svg{
  color: rgba(255,255,255,.96) !important;
  filter: none !important;
}

nav.navbar.navbar-light .navbar-nav a[href*="/register"]:hover{
  color: rgba(255,255,255,.98) !important;

  background: linear-gradient(180deg,
    rgba(255, 183, 105, 1) 0%,
    rgba(255, 143, 25, 1) 55%,
    rgba(240, 125, 10, 1) 100%
  ) !important;

}

/* Active / focus – aby vám to nezůstávalo "modré" */
nav.navbar.navbar-light .navbar-nav a[href*="/register"]:active,
nav.navbar.navbar-light .navbar-nav a[href*="/register"]:focus{
  transform: translateY(0);
  outline: none !important;

}

/* ============================================
   NOTIFICATIONS DROPDOWN (LIGHT) – scoped override
   ============================================ */
nav.navbar #internal_notifications_content.dropdown-menu{
  padding: 1.40rem !important;
}

nav.navbar #internal_notifications_content .bg-gray-100{
  background: #ffffff !important;
  border: 1px solid rgba(15,165,235,0.14) !important;
  border-radius: 1.15rem !important;

  box-shadow: 0 5px 8px rgb(0 0 0 / 5%), 0 0 0 1px rgba(255, 255, 255, 0.65) inset !important;
}

nav.navbar #internal_notifications_content .bg-gray-50{
  background: linear-gradient(
    to bottom,
    rgba(3, 28, 45, 0.06),
    rgba(15,165,235,0.06)
  ) !important;

  border: 1px solid rgba(15,165,235,0.18) !important;
  border-radius: 1.05rem !important;
  box-shadow: 0 0 12px rgba(15,165,235,0.18) !important;
}

nav.navbar #internal_notifications_content svg{
  color: #0fa5eb !important;
  filter: drop-shadow(0 0 6px rgba(15,165,235,0.22));
}

nav.navbar #internal_notifications_content .text-body{
  color: rgba(15, 23, 42, 0.92) !important;
}
nav.navbar #internal_notifications_content .text-muted{
  color: rgba(15, 23, 42, 0.62) !important;
}

nav.navbar #internal_notifications_content .btn.btn-light{
  background: rgba(15,165,235,0.10) !important;
  border: 1px solid rgba(15,165,235,0.22) !important;
  color: rgba(15, 23, 42, 0.90) !important;
  border-radius: 1.0rem !important;
  font-weight: 500;
  box-shadow:0 5px 8px rgb(0 0 0 / 4%), 0 0 12px rgba(15, 165, 235, 0.12) !important;
}

nav.navbar #internal_notifications_content .btn.btn-light:hover,
nav.navbar #internal_notifications_content .btn.btn-light:focus{
  background: rgba(15,165,235,0.16) !important;
  box-shadow:
    0 12px 22px rgba(0,0,0,0.14),
    0 0 16px rgba(15,165,235,0.18) !important;
}

/* ============================================
   DARK MODE – navbar + dropdowns
   ============================================ */
[data-theme-style="dark"] nav.navbar{
  background: transparent !important;
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.70),
    0 8px 18px rgba(0, 0, 0, 0.45),
    0 2px 6px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(255,255,255,0.06),
    inset 0 1px 0 rgba(255,255,255,0.04) !important;
}

/* Dark pill */
[data-theme-style="dark"] nav.navbar.bg-white.rounded,
[data-theme-style="dark"] nav.navbar .bg-white.rounded{
  background: linear-gradient(
    to bottom,
    rgba(20, 26, 34, 0.92),
    rgba(12, 16, 22, 0.90)
  ) !important;

  border: 1px solid rgba(255,255,255,0.10) !important;
}

[data-theme-style="dark"] nav.navbar.bg-white.rounded::before,
[data-theme-style="dark"] nav.navbar .bg-white.rounded::before{
  background:
    radial-gradient(circle at 15% 0%,
      rgba(255,255,255,0.16),
      rgba(255,255,255,0.05) 32%,
      rgba(255,255,255,0.0) 70%),
    linear-gradient(
      to bottom,
      rgba(255,255,255,0.10),
      rgba(255,255,255,0.0) 60%
    );
}

/* Dark links */
[data-theme-style="dark"] nav.navbar .nav-link{
  color: rgba(235, 240, 245, 0.86) !important;
}
[data-theme-style="dark"] nav.navbar .nav-link:hover{
  color: #3bbcff !important;
}
[data-theme-style="dark"] nav.navbar .nav-link:active,
[data-theme-style="dark"] nav.navbar .nav-link:focus,
[data-theme-style="dark"] nav.navbar .nav-link.show,
[data-theme-style="dark"] nav.navbar .nav-item.show > .nav-link,
[data-theme-style="dark"] nav.navbar .nav-link.active{
  color: rgba(245, 248, 252, 0.94) !important;
}

/* Dark mobile panel */
@media (max-width: 991.98px){
  [data-theme-style="dark"] #main_navbar.navbar-collapse{
    background: linear-gradient(
      to bottom,
      rgba(18, 22, 30, 0.96),
      rgba(12, 15, 21, 0.96)
    ) !important;

    border: 1px solid rgba(255,255,255,0.10) !important;

    box-shadow:
      0 18px 44px rgba(0,0,0,.70),
      0 6px 14px rgba(0,0,0,.45) !important;

    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    opacity: 1 !important;
  }
}

/* Dark dropdown */
[data-theme-style="dark"] nav.navbar .dropdown-menu{
  background: linear-gradient(
    to bottom,
    rgba(22, 28, 36, 0.98),
    rgba(14, 18, 24, 0.98)
  ) !important;

  border: 1px solid rgba(255,255,255,0.10) !important;

  box-shadow:
    0 18px 44px rgba(0,0,0,0.72),
    0 0 0 1px rgba(255,255,255,0.05) inset,
    0 0 12px rgba(40,160,255,0.12) !important;
}

[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item{
  color: rgba(235, 240, 245, 0.90) !important;
}
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item svg{
  color: rgba(235, 240, 245, 0.62) !important;
}
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:hover,
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:focus{
  background: rgba(60,180,255,0.12) !important;
  box-shadow: 0 0 0 1px rgba(60,180,255,0.18) inset !important;
}
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:hover svg,
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:focus svg{
  color: #3cb4ff !important;
  filter: drop-shadow(0 0 5px rgba(60,180,255,0.20));
}
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-divider{
  border-top: 1px solid rgba(255,255,255,0.10) !important;
}

/* Dark notifications dropdown */
[data-theme-style="dark"] nav.navbar #internal_notifications_content.dropdown-menu{
  background: linear-gradient(
    to bottom,
    rgba(22, 28, 36, 0.98),
    rgba(14, 18, 24, 0.98)
  ) !important;

  border: 1px solid rgba(255,255,255,0.10) !important;

  box-shadow:
    0 18px 44px rgba(0,0,0,0.72),
    0 0 0 1px rgba(255,255,255,0.05) inset,
    0 0 14px rgba(60,180,255,0.12) !important;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .bg-gray-100{
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(60,180,255,0.16) !important;

  box-shadow:
    0 10px 22px rgba(0,0,0,0.55),
    0 0 0 1px rgba(255,255,255,0.04) inset !important;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .bg-gray-50{
  background: rgba(60,180,255,0.08) !important;
  border: 1px solid rgba(60,180,255,0.18) !important;
  box-shadow: 0 0 14px rgba(60,180,255,0.16) !important;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .text-body{
  color: rgba(235, 240, 245, 0.92) !important;
}
[data-theme-style="dark"] nav.navbar #internal_notifications_content .text-muted{
  color: rgba(235, 240, 245, 0.62) !important;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .btn.btn-light{
  background: rgba(60,180,255,0.14) !important;
  border: 1px solid rgba(60,180,255,0.22) !important;
  color: rgba(235, 240, 245, 0.92) !important;

  box-shadow:
    0 12px 26px rgba(0,0,0,0.55),
    0 0 14px rgba(60,180,255,0.14) !important;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .btn.btn-light:hover,
[data-theme-style="dark"] nav.navbar #internal_notifications_content .btn.btn-light:focus{
  background: rgba(60,180,255,0.20) !important;
  box-shadow:
    0 14px 30px rgba(0,0,0,0.62),
    0 0 18px rgba(60,180,255,0.20) !important;
}


/* ============================================
   DROPZONA
   ============================================ */

/* hranice dropzóny */
.tp-hero .upload-drag-over-inactive {
    border: 2px dashed #106eb4;
}

.tp-hero #upload_main_dropzone {
    background-color: #ffffff82;
    border-radius: 2.4rem;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 6px 30px rgb(0 0 0 / 32%);
    transition: background-color .34s ease, box-shadow .34s ease;

    animation: tp-fade-up 0.65s ease-out 0.1s both;
}

.tp-hero #upload_main_dropzone.tp-upload-has-files {
    background-color: #e9f6fe;
}

/* ============================================
   DROPZONA  DARK
   ============================================ */

/* hranice dropzóny */
[data-theme-style="dark"] .tp-hero .upload-drag-over-inactive {
    border: 2px dashed #252a38;
}

[data-theme-style="dark"] .tp-hero #upload_main_dropzone {
    background-color: #0b111980;
    box-shadow: 0 12px 20px rgb(0 0 0 / 13%);
    transition: background-color .34s ease, box-shadow .34s ease;

    animation: tp-fade-up 0.65s ease-out 0.1s both;
}

[data-theme-style="dark"] .tp-hero #upload_main_dropzone.tp-upload-has-files {
    background-color: #0b1119;
}

/* ============================================
   DROPZONE – DEFAULT (dashboard / všude)
   ============================================ */
#upload_main_dropzone{
  background-color: #e9f6fe;
  border-radius: 1.4rem;
  box-shadow: 0 0px 15px rgb(0 0 0 / 7%);
}

[data-theme-style="dark"] #upload_main_dropzone{
  background-color: #041e30;
  box-shadow: 0 0px 15px rgb(0 0 0 / 7%);
}

/* Dashboard: adding files to an existing transfer reuses the uploader engine,
   but it must stay compact and must not inherit the homepage uploader layout. */
.tp-transfer-add-files #upload_main_dropzone {
  min-height: auto !important;
  padding: 1rem !important;
  background: rgba(235, 248, 255, .86) !important;
  border: 1px dashed rgba(16, 110, 180, .42) !important;
  border-radius: 1.1rem !important;
  box-shadow: 0 14px 34px rgba(16, 110, 180, .10) !important;
}

[data-theme-style="dark"] .tp-transfer-add-files #upload_main_dropzone {
  background: rgba(8, 23, 36, .82) !important;
  border-color: rgba(62, 190, 255, .36) !important;
  box-shadow: 0 16px 38px rgba(0, 0, 0, .28) !important;
}

.tp-transfer-add-files #upload_main_dropzone > .card-body {
  padding: 1rem !important;
}

.tp-transfer-add-files .upload-hint-wrapper,
.tp-transfer-add-files .upload-hint-badge {
  display: none !important;
}

.tp-transfer-add-files #upload_form > .row:first-of-type {
  align-items: center;
}

.tp-transfer-add-files #upload_select_files {
  min-height: 3.2rem !important;
  box-shadow: none !important;
}

.tp-transfer-add-files #upload_previews_wrapper {
  margin-top: 1rem !important;
}

.tp-transfer-add-files #upload_previews_wrapper > .row {
  display: block !important;
}

.tp-transfer-add-files #upload_previews_settings {
  display: none !important;
}

.tp-transfer-add-files #upload_previews_files {
  flex: 0 0 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  min-height: 0 !important;
}

.tp-transfer-add-files #upload_previews_files > .row:first-child {
  margin-left: 0;
  margin-right: 0;
  padding: .75rem 1rem !important;
  border: 1px solid rgba(16, 110, 180, .16);
  background: rgba(255, 255, 255, .7) !important;
}

[data-theme-style="dark"] .tp-transfer-add-files #upload_previews_files > .row:first-child {
  border-color: rgba(62, 190, 255, .18);
  background: rgba(255, 255, 255, .05) !important;
}

.tp-transfer-add-files #upload_previews {
  max-height: 18rem;
  overflow: auto;
}

.tp-transfer-add-files #upload_submit {
  max-width: 30rem;
  margin: 0 auto !important;
}

/* dashed border default */
.upload-drag-over-inactive{
  border: 2px dashed #106eb4;
}
.upload-drag-over-active{
  box-shadow:
    0 26px 70px rgba(0,0,0,.55),
    0 0 0 1px rgba(255,255,255,.10) inset;
}

/* =========================================================
   TP UPLOAD BUTTONS – aligned to your :root tokens
   Scope: #upload_select_files, .index-button, #upload_submit
   ========================================================= */

/* Stable sizing to avoid jitter when label/spinner changes */
:root{
  --tp-btn-radius: 999px;
  --tp-btn-minh: 56px;
}

/* =========================================================
   PRIMARY CTA (Select files) + .index-button
   ========================================================= */

#upload_select_files,
.index-button{
  position: relative;
  z-index: 1;
  overflow: hidden;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;

  min-height: var(--tp-btn-minh);
  padding: 1.1rem 2.8rem;

  border-radius: var(--tp-btn-radius);
  border: 1px solid #106eb4 !important;

  font-size: 1.3rem;
  font-weight: 650;
  letter-spacing: 0.012em;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;

  /* keep your “blue CTA” feel */
  background: linear-gradient(180deg, rgb(18 137 207) 0%, rgb(18 52 124) 55%, rgb(18 52 124) 100%);

  color: rgba(255,255,255,0.94);
  text-shadow: none;
  transform: translateY(0);

  box-shadow:
    0 14px 30px rgba(6,16,34,0.18),
    0 6px 12px rgba(6,16,34,0.12),
    inset 0 1px 0 rgba(255,255,255,0.95);

  transition:
    transform 0.16s ease,
    box-shadow 0.16s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    filter 0.18s ease;
}

/* soft carpet under button */
#upload_select_files::before,
.index-button::before{
  content:'';
  position:absolute;
  left: 12%;
  right: 12%;
  top: 68%;
  bottom: -22px;

  border-radius: 999px;
  z-index: -1;
  pointer-events:none;

  background: radial-gradient(circle at 50% 35%,
    rgba(15,165,235,0.18),
    rgba(255,133,3,0.10),
    transparent 72%
  );

  opacity: .38;
  filter: blur(16px);
  transform: translateY(0);

  transition: opacity 0.16s ease, transform 0.16s ease, filter 0.16s ease;
}

/* sheen */
#upload_select_files::after,
.index-button::after{
  content:'';
  position:absolute;
  inset: 2px;
  border-radius: inherit;
  pointer-events:none;
  z-index: 0;

  background: linear-gradient(
    115deg,
    transparent 0%,
    rgba(255,255,255,0.00) 34%,
    rgba(255,255,255,0.48) 48%,
    rgba(255,255,255,0.00) 62%,
    transparent 100%
  );

  opacity: .22;
  transform: translateX(-70%);
  animation: tpBtnSheen 4.2s ease-in-out infinite;
}

/* content above sheen */
#upload_select_files > *,
.index-button > *{
  position: relative;
  z-index: 1;
}

/* hover = lift + orange accent */
#upload_select_files:hover,
.index-button:hover{
  transform: translateY(-2px);

  background: linear-gradient(
    180deg,
    rgba(255,133,3,0.30) 0%,
    rgba(255,133,3,0.98) 58%,
    rgba(255,133,3,0.92) 100%
  );

  border-color: rgba(255,133,3,0.55) !important;

  box-shadow:
    0 18px 40px rgba(6,16,34,0.22),
    0 10px 20px rgba(6,16,34,0.14),
    inset 0 1px 0 rgba(255,255,255,0.95);
}

#upload_select_files:hover::before,
.index-button:hover::before{
  opacity: .70;
  filter: blur(18px);
  transform: translateY(2px);
}

#upload_select_files:hover::after,
.index-button:hover::after{
  opacity: .42;
}

/* active = press */
#upload_select_files:active,
.index-button:active{
  transform: translateY(1px);

  box-shadow:
    0 10px 22px rgba(6,16,34,0.18),
    0 4px 10px rgba(6,16,34,0.10),
    inset 0 4px 10px rgba(0,0,0,0.18);
}

#upload_select_files:active::before,
.index-button:active::before{
  opacity: .42;
  filter: blur(14px);
  transform: translateY(4px);
}

@keyframes tpBtnSheen{
  0%,100%{ transform: translateX(-70%); }
  50%{ transform: translateX(70%); }
}

/* =========================================================
   UPLOAD SUBMIT BUTTON (#upload_submit)
   ========================================================= */

#upload_submit{
  position: relative;
  overflow: hidden;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;

  min-height: var(--tp-btn-minh);
  padding: 1.15rem 2.8rem;

  border-radius: var(--tp-btn-radius) !important;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;

  font-weight: 750;
  letter-spacing: .01em;
  line-height: 1.15;

  /* idle: slightly calmer than CTA, still brand blue */
  border: 1px solid rgba(15,165,235,.92) !important;
  background: linear-gradient(
    180deg,
    rgba(15,165,235,0.16) 0%,
    rgba(15,165,235,0.70) 52%,
    rgba(34,211,238,0.55) 100%
  ) !important;

  /* text stays readable in both themes */
  color: rgba(6,16,28,.96) !important;
  transform: translateY(0);

  box-shadow:
    0 14px 30px rgba(6,16,34,0.18),
    0 6px 12px rgba(6,16,34,0.12),
    inset 0 1px 0 rgba(255,255,255,0.85);

  transition:
    transform .16s ease,
    box-shadow .16s ease,
    border-color .16s ease,
    background .18s ease,
    filter .18s ease;
}

#upload_submit svg{
  color: rgba(11,18,32,.82) !important;
}

/* scan overlay (off by default) */
#upload_submit::before{
  content:"";
  position:absolute;
  inset: 4px;
  border-radius: inherit;
  pointer-events:none;

  background: linear-gradient(
    90deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.42) 50%,
    rgba(255,255,255,0) 100%
  );

  opacity: 0;
  transform: translateX(-60%) scaleX(.55);
  filter: blur(10px);

  transition: opacity .16s ease, transform .16s ease, filter .16s ease, background .16s ease;
}

/* hover = lift + orange (your accent) */
#upload_submit:not([disabled]):not(.is-uploading):hover{
  transform: translateY(-2px);
  border-color: rgba(255,133,3,0.60) !important;

  background: linear-gradient(
    180deg,
    rgba(255,133,3,0.22) 0%,
    rgba(255,133,3,0.90) 55%,
    rgba(255,133,3,0.96) 100%
  ) !important;

  box-shadow:
    0 18px 40px rgba(6,16,34,0.22),
    0 10px 20px rgba(6,16,34,0.14),
    inset 0 1px 0 rgba(255,255,255,0.90);

  filter: saturate(1.03);
}

#upload_submit:not([disabled]):not(.is-uploading):hover::before{
  opacity: .60;

  background: linear-gradient(
    90deg,
    rgba(255,133,3,0) 0%,
    rgba(255,133,3,.55) 50%,
    rgba(255,133,3,0) 100%
  );

  transform: translateX(0) scaleX(.9);
  filter: blur(11px);
}

/* active = press */
#upload_submit:not([disabled]):not(.is-uploading):active{
  transform: translateY(1px);
  box-shadow:
    0 10px 22px rgba(6,16,34,0.18),
    0 4px 10px rgba(6,16,34,0.10),
    inset 0 4px 10px rgba(0,0,0,0.16);
}

#upload_submit:not([disabled]):not(.is-uploading):active::before{
  opacity: .40;
  transform: translateX(0) scaleX(.8);
}

/* =========================================================
   UPLOADING / DISABLED – unified, NOT pale, NOT jitter
   Uses your dark-accent family: --tp-neon-teal (teal) + stable shadows
   ========================================================= */

#upload_submit[disabled],
#upload_submit.is-uploading{
  cursor: default;

  /* absolutely no motion affecting perceived size */
  animation: none !important;
  transform: translateY(0) !important;
  filter: none !important;

  border-color: rgba(94,234,212,0.85) !important; /* --tp-neon-teal */

  background: linear-gradient(
    180deg,
    rgba(94,234,212,0.20) 0%,
    rgba(94,234,212,0.52) 55%,
    rgba(34,211,238,0.50) 100%  /* --tp-neon-cyan */
  ) !important;

  color: rgba(6,16,28,.96) !important;

  box-shadow:
    0 14px 30px rgba(6,16,34,0.20),
    0 6px 12px rgba(6,16,34,0.12),
    inset 0 1px 0 rgba(255,255,255,0.92);
}

/* no hover/active while uploading */
#upload_submit[disabled]:hover,
#upload_submit.is-uploading:hover,
#upload_submit[disabled]:active,
#upload_submit.is-uploading:active{
  transform: translateY(0) !important;
  box-shadow:
    0 14px 30px rgba(6,16,34,0.20),
    0 6px 12px rgba(6,16,34,0.12),
    inset 0 1px 0 rgba(255,255,255,0.92) !important;
}

/* scan runs ONLY while uploading, constant scale (no “pulsing”) */
#upload_submit[disabled]::before,
#upload_submit.is-uploading::before{
  opacity: .85;

  background: linear-gradient(
    90deg,
    rgba(94,234,212,0) 0%,
    rgba(94,234,212,0.85) 50%,
    rgba(94,234,212,0) 100%
  );

  filter: blur(10px);
  animation: tpUploadScan 1.25s linear infinite;
}

@keyframes tpUploadScan{
  0%   { transform: translateX(-60%) scaleX(.55); }
  100% { transform: translateX(60%)  scaleX(.55); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  #upload_select_files::after,
  .index-button::after{ animation: none !important; transform:none; opacity:.18; }

  #upload_submit[disabled]::before,
  #upload_submit.is-uploading::before{ animation: none !important; opacity:.55; transform:none; }
}

/* =========================================================
   Dark theme tweaks (only readability)
   ========================================================= */
[data-theme-style="dark"] #upload_submit{
  color: rgba(255,255,255,0.92) !important;
  border-color: rgba(34,211,238,0.55) !important; /* --tp-neon-cyan */
  box-shadow:
    0 18px 48px rgba(0,0,0,0.60),
    0 8px 18px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.10);
}

[data-theme-style="dark"] #upload_submit svg{
  color: rgba(255,255,255,0.82) !important;
}

[data-theme-style="dark"] #upload_submit[disabled],
[data-theme-style="dark"] #upload_submit.is-uploading{
  color: rgba(255,255,255,0.92) !important;
  box-shadow:
    0 22px 60px rgba(0,0,0,0.70),
    0 10px 22px rgba(0,0,0,0.48),
    inset 0 1px 0 rgba(255,255,255,0.10);
}

[data-theme-style="dark"] #upload_submit{
  background: linear-gradient(
    180deg,
    rgba(34,211,238,0.14) 0%,
    rgba(15,165,235,0.45) 55%,
    rgba(15,165,235,0.55) 100%
  ) !important;

  /* odstranit světlý vnitřní lem */
  box-shadow:
    0 18px 44px rgba(0,0,0,0.65),
    0 8px 18px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.04);
}

/* kobereček – méně světla, víc hloubky */
[data-theme-style="dark"] #upload_select_files::before,
[data-theme-style="dark"] .index-button::before,
[data-theme-style="dark"] #upload_submit::before{
  opacity: .22;
  filter: blur(18px);
}

/* sheen / scan = utlumený, ne svítící */
[data-theme-style="dark"] #upload_select_files::after,
[data-theme-style="dark"] .index-button::after{
  opacity: .14;
}

/* UPLOADING state – žádná světelná zelená */
[data-theme-style="dark"] #upload_submit.is-uploading,
[data-theme-style="dark"] #upload_submit[disabled]{
  background: linear-gradient(
    180deg,
    rgba(34,211,238,0.18) 0%,
    rgba(34,211,238,0.38) 55%,
    rgba(15,165,235,0.42) 100%
  ) !important;

  box-shadow:
    0 20px 52px rgba(0,0,0,0.75),
    0 10px 22px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

/* scan pás při uploadu – ztišený */
[data-theme-style="dark"] #upload_submit.is-uploading::before,
[data-theme-style="dark"] #upload_submit[disabled]::before{
  opacity: .55;
  filter: blur(12px);
}




/* ============================================
   NAVBAR – DARK MODE (override přes data-theme-style)
   Pouze barvy / pozadí / stíny / texty
   ============================================ */

[data-theme-style="dark"] nav.navbar {
    background: transparent !important;
    box-shadow:
        0 18px 42px rgba(0, 0, 0, 0.70),
        0 8px 18px rgba(0, 0, 0, 0.45),
        0 2px 6px rgba(0, 0, 0, 0.55),
        0 0 0 1px rgba(255,255,255,0.06),
        inset 0 1px 0 rgba(255,255,255,0.04) !important;
}

/* Hlavní pill lišta */
[data-theme-style="dark"] nav.navbar.navbar-expand-lg.navbar-light.bg-white.rounded {
    background: linear-gradient(
        to bottom,
        rgba(20, 26, 34, 0.92),
        rgba(12, 16, 22, 0.90)
    ) !important;

    border: 1px solid rgba(255,255,255,0.10) !important;
}

/* horní highlight v pill (jen tónování) */
[data-theme-style="dark"] nav.navbar.navbar-expand-lg.navbar-light.bg-white.rounded::before {
    background:
        radial-gradient(circle at 15% 0%,
            rgba(255,255,255,0.16),
            rgba(255,255,255,0.05) 32%,
            rgba(255,255,255,0.0) 70%)
        ,
        linear-gradient(
            to bottom,
            rgba(255,255,255,0.10),
            rgba(255,255,255,0.0) 60%
        );
}

/* nav odkazy */
[data-theme-style="dark"] nav.navbar .nav-link {
    color: rgba(235, 240, 245, 0.86) !important;
}

[data-theme-style="dark"] nav.navbar .nav-link:hover {
    color: #0fa5eb !important;
}

/* active/focus (bez “svícení”, jen čitelnější) */
[data-theme-style="dark"] nav.navbar .nav-link:active,
[data-theme-style="dark"] nav.navbar .nav-link:focus,
[data-theme-style="dark"] nav.navbar .nav-link.show,
[data-theme-style="dark"] nav.navbar .nav-item.show > .nav-link,
[data-theme-style="dark"] nav.navbar .nav-link.active {
    color: rgba(245, 248, 252, 0.94) !important;
}

/* ============================================
   MOBILE COLLAPSE PANEL – DARK
   ============================================ */
@media (max-width: 991.98px) {
    [data-theme-style="dark"] #main_navbar.navbar-collapse {
        background: linear-gradient(
            to bottom,
            rgba(18, 22, 30, 0.96),
            rgba(12, 15, 21, 0.96)
        ) !important;

        border: 1px solid rgba(255,255,255,0.10) !important;

        box-shadow:
          0 18px 44px rgba(0,0,0,.70),
          0 6px 14px rgba(0,0,0,.45) !important;

        /* zachováme tvůj fix – v mobilu bez blur “mléka” */
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        opacity: 1 !important;
    }
}

/* ============================================
   DROPDOWN (submenu) – DARK
   ============================================ */

[data-theme-style="dark"] nav.navbar .dropdown-menu {
    background: linear-gradient(
        to bottom,
        rgba(22, 28, 36, 0.98),
        rgba(14, 18, 24, 0.98)
    ) !important;

    border: 1px solid rgba(255,255,255,0.10) !important;

    /* stažený stín, aby “druhé submenu” nesvítilo */
    box-shadow:
      0 14px 32px rgba(0,0,0,0.68),
      0 0 0 1px rgba(255,255,255,0.05) inset,
      0 0 10px rgba(40,160,255,0.10) !important;
}

/* položky */
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item {
    color: rgba(235, 240, 245, 0.88) !important;
    background: transparent !important;
}

[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item svg {
    color: rgba(200, 210, 220, 0.65) !important;
}

/* hover */
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:hover,
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:focus {
    background: rgba(60, 180, 255, 0.14) !important;
    box-shadow: 0 0 0 1px rgba(60,180,255,0.22) inset !important;
}

[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:hover svg,
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:focus svg {
    color: #0fa5eb !important;
    filter: drop-shadow(0 0 6px rgba(60,180,255,0.30));
}
 
/* active */
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item.active,
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-item:active {
    background: rgba(60, 180, 255, 0.20) !important;
    box-shadow: 0 0 0 1px rgba(60,180,255,0.28) inset !important;
}

/* divider */
[data-theme-style="dark"] nav.navbar .dropdown-menu .dropdown-divider {
    border-top: 1px solid rgba(255,255,255,0.10) !important;
    opacity: 1 !important;
}


/* =========================================================
   TRANSFER+ – UPLOADER UI (WHITE SaaS TRON)
   Scope: #upload_form (safe, bez zásahů do zbytku webu)
   Obsahuje LIGHT + DARK verzi.
   ========================================================= */

/* ---------------------------------------------------------
   0) Layout / wrapper
   --------------------------------------------------------- */
#upload_form #upload_previews_wrapper{
  margin-top: 2.4rem;
  padding-left: 6px !important;
  padding-right: 6px !important;
}

/* malý gap mezi panely na desktopu */
@media (min-width: 992px){
  #upload_form #upload_previews_wrapper > .row{
    align-items: stretch;
  }

  #upload_form #upload_previews_settings{ margin-right: .8rem; }
  #upload_form #upload_previews_files{ margin-left: .8rem; }

  /* oba panely drží stejnou výšku, i když se vlevo rozbalí další nastavení */
  #upload_form #upload_previews_settings,
  #upload_form #upload_previews_files{
    display: flex;
    flex-direction: column;
  }
}

/* ---------------------------------------------------------
   1) PANELY (levý + pravý) – sjednocený „glass/clay“ povrch
   --------------------------------------------------------- */
#upload_form #upload_previews_files{
  position: relative;
  border-radius: 1.125rem;
  padding: 1.9rem 2.0rem 2.05rem;

  /* vypouklý efekt: tmavší směrem do středu, jemná spodní stopa */
  box-shadow:
    -16px 0 28px -16px rgba(6,16,34,.29),
    0 3px 8px -7px rgba(6,16,34,.09);
}


@media (min-width: 992px){
  #upload_form #upload_previews_settings,
  #upload_form #upload_previews_files{ min-height: 420px; }
}


/* obsah nad glow */
#upload_form #upload_previews_settings > *,
#upload_form #upload_previews_files > *{
  position: relative;
  z-index: 1;
}

/* MOBILE */
@media (max-width: 768px) {
  #upload_form #upload_previews_files {
    position: relative !important;
    border-radius: 1.125rem !important;
    padding: 3rem 1rem 1.35rem !important;
    box-shadow: 0px -14px 10px -14px rgba(6, 16, 34, .24), 0 3px 8px -7px rgba(6, 16, 34, .09) !important;
  }

  #upload_form #upload_previews_settings {
            position: relative !important;
        border-radius: 1.125rem !important;
        padding: 1.25rem 1rem 1.35rem !important;
        box-shadow: 0px 14px 10px -14px rgba(6, 16, 34, .24), 0 3px 8px -7px rgba(6, 16, 34, .09) !important;
  }
}

/* ---------------------------------------------------------
   2) LABELS / TEXTY
   --------------------------------------------------------- */
#upload_form .col-form-label-sm,
#upload_form label{
  color: rgba(11,22,32,.70) !important;
  font-size: .86rem;
  font-weight: 700;
  letter-spacing: -.02em;
  align-content: center;
}

/* ---------------------------------------------------------
   3) INPUTS (text/email) + input-group
   --------------------------------------------------------- */
#upload_form .form-control.form-control-sm,
#upload_form .form-control{
  background: rgba(255,255,255,0.86) !important;
  border-radius: 1rem;
  border: 1px solid rgba(16,24,40,.14) !important;

  color: rgba(11,22,32,.92) !important;
  font-size: .92rem;
  padding: .58rem .85rem;
  min-height: 2.6rem;
  line-height: 1.3;

  /* stín menší než panel, ať to působí čistě */
  box-shadow:
    0 10px 20px rgba(16,24,40,.08),
    inset 0 1px 0 rgba(255,255,255,.65);

  transition:
    border-color .18s ease,
    box-shadow .18s ease,
    background .18s ease;
}

#upload_form .form-control:focus{
  background: #fff !important;
  border-color: rgba(15,165,235,.55) !important;

  box-shadow:
    0 0 0 4px rgba(15,165,235,.14),
    0 16px 28px rgba(16,24,40,.12),
    inset 0 1px 0 rgba(255,255,255,.75);

  color: rgba(11,22,32,.96) !important;
}

#upload_form .form-control::placeholder{
  color: rgba(11,22,32,.45) !important;
}

/* input-group "transfer.plus/" */
#upload_form .input-group-text{
  background: rgba(255,255,255,0.88) !important;
  border: 1px solid rgba(16,24,40,.14) !important;
  border-right: 0 !important;

  color: rgba(11,22,32,.62) !important;
  font-weight: 700;

  border-radius: 1rem 0 0 1rem !important;

  box-shadow:
    0 10px 20px rgba(16,24,40,.08),
    inset 0 1px 0 rgba(255,255,255,.65);
}

#upload_form .input-group .form-control{
  border-left: 0 !important;
  border-radius: 0 1rem 1rem 0 !important;
}

/* =========================================================
   SELECT – DOMÉNA (LIGHT) – FIXED SVG
   ========================================================= */

#upload_form select.custom-select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;

  /* Šipka (URL-encoded SVG) */
  background-image:
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(236,246,255,0.86)),
    url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20width%3D%2714%27%20height%3D%2714%27%20viewBox%3D%270%200%2024%2024%27%20fill%3D%27none%27%20stroke%3D%27%230fa5eb%27%20stroke-width%3D%272%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27%3E%3Cpolyline%20points%3D%276%209%2012%2015%2018%209%27/%3E%3C/svg%3E");

  background-repeat: no-repeat, no-repeat;
  background-position: 0 0, right .75rem center;
  background-size: auto, 14px;

  border-radius: 1rem;
  border: 1px solid rgba(16,24,40,.14);
  color: rgba(11,22,32,.88);

  padding: .45rem 2.1rem .45rem .85rem;
  min-height: 2.6rem;
  font-size: .92rem;
  font-weight: 600;

  box-shadow:
    0 10px 22px rgba(16,24,40,.08),
    inset 0 1px 0 rgba(255,255,255,.85);

  transition: border-color .18s ease, box-shadow .18s ease;
}

#upload_form select.custom-select:hover{
  border-color: rgba(15,165,235,.32);
}

#upload_form select.custom-select:focus{
  outline: none;
  border-color: rgba(15,165,235,.55);
  box-shadow:
    0 0 0 4px rgba(15,165,235,.14),
    0 14px 28px rgba(16,24,40,.12),
    inset 0 1px 0 rgba(255,255,255,.9);
}

#upload_form select.custom-select option{
  color: #0b1620;
  font-weight: 600;
}

/* =========================================================
   UPLOADER – SELECT „Doména“ (custom-select) + šipka (light/dark)
   Scope: #upload_form only
   Cíl: stejný tvar šipky v obou režimech, v light viditelná, v dark neřve.
   ========================================================= */

#upload_form .custom-select.custom-select-sm{
  /* reset nativní šipky */
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;

  /* zachovat tvůj input look */
  background-color: rgba(255,255,255,0.85) !important;
  border: 1px solid rgba(16,24,40,.14) !important;
  border-radius: 1rem !important;
  color: rgba(11,22,32,.92) !important;

  min-height: 2.6rem;
  padding: .58rem 2.7rem .58rem .85rem !important; /* místo na šipku */

  box-shadow: 0 10px 22px rgba(16,24,40,.08);

  /* jednotná šipka – SVG data URI (bez „coder“ chyb) */
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M4.2 6.2a1 1 0 0 1 1.4 0L8 8.6l2.4-2.4a1 1 0 1 1 1.4 1.4l-3.1 3.1a1.1 1.1 0 0 1-1.6 0L4.2 7.6a1 1 0 0 1 0-1.4z' fill='%230b1620' fill-opacity='.55'/%3E%3C/svg%3E"),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(236,246,255,.86));
  background-repeat: no-repeat, no-repeat;
  background-size: 18px 18px, 100% 100%;
  background-position: calc(100% - 14px) 50%, 0 0;
}

#upload_form .custom-select.custom-select-sm:hover{
  border-color: rgba(15,165,235,.22) !important;
  box-shadow: 0 14px 28px rgba(16,24,40,.10);
}

#upload_form .custom-select.custom-select-sm:focus{
  outline: 0;
  background-color: #fff !important;
  border-color: rgba(2,156,246,.55) !important;
  box-shadow:
    0 0 0 4px rgba(2,156,246,.14),
    0 14px 28px rgba(16,24,40,.12);
}

/* sjednocení šipky i pro .custom-select bez -sm (kdybys použil jinde) */
#upload_form .custom-select:not(.custom-select-sm){
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding-right: 2.7rem !important;
  background-repeat: no-repeat;
  background-size: 18px 18px;
  background-position: calc(100% - 14px) 50%;
}

/* =========================================================
   DARK – stejná šipka, jen jiná opacity (ne „jiný objekt“)
   ========================================================= */

[data-theme-style="dark"] #upload_form .custom-select.custom-select-sm{
  background-color: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  color: rgba(220,230,255,0.86) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .30), inset 0 1px 0 rgba(255, 255, 255, .06) !important;

  /* stejný SVG tvar, jen světlá výplň s nízkou opacity */
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M4.2 6.2a1 1 0 0 1 1.4 0L8 8.6l2.4-2.4a1 1 0 1 1 1.4 1.4l-3.1 3.1a1.1 1.1 0 0 1-1.6 0L4.2 7.6a1 1 0 0 1 0-1.4z' fill='%23dce6ff' fill-opacity='.52'/%3E%3C/svg%3E"),
    linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04));
  background-repeat: no-repeat, no-repeat;
  background-size: 18px 18px, 100% 100%;
  background-position: calc(100% - 14px) 50%, 0 0;
}

[data-theme-style="dark"] #upload_form .custom-select.custom-select-sm:hover{
  border-color: rgba(15,165,235,0.28) !important;
}

[data-theme-style="dark"] #upload_form .custom-select.custom-select-sm:focus{
  background-color: rgba(255,255,255,0.07) !important;
  border-color: rgba(15,165,235,0.45) !important;
  box-shadow:
    0 0 0 4px rgba(15,165,235,0.12),
    0 18px 34px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.08);
}

/* pokud ti systém tlačí extra caret přes ::after u wrapperů,
   tohle ho bezpečně vypne jen v uploaderu */
#upload_form .custom-select::after{ content: none !important; }

/* ---------------------------------------------------------
   4) TYP PŘENOSU – ODKAZ / E-MAIL (ikona nad textem)
   --------------------------------------------------------- */
#upload_form #upload_previews_settings .btn-group-toggle .btn{
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(236,246,255,0.86)) !important;
  border: 1px solid rgba(15,165,235,0.22) !important;
  border-radius: 1.05rem !important;

  color: rgba(11,18,32,0.82) !important;
  font-weight: 650;

  min-height: 4.4rem;
  padding: .72rem .82rem .62rem;
  font-size: .95rem;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;

  box-shadow:
    0 4px 10px rgba(2,6,23,0.09),
    inset 0 1px 0 rgba(255,255,255,0.75);

  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease,
    filter .18s ease;
}

#upload_form #upload_previews_settings .btn-group-toggle .btn svg{
  color: rgba(11,18,32,0.72) !important;
  font-size: 1.45rem;
  filter: drop-shadow(0 2px 5px rgba(15,165,235,0.12));
  transition: color .18s ease, filter .18s ease;
}

#upload_form #upload_previews_settings .btn-group-toggle .btn:hover{
  transform: none;
  filter: saturate(1.03);

  box-shadow:
    0 6px 14px rgba(2,6,23,0.11),
    inset 0 1px 0 rgba(255,255,255,0.78);

  border-color: rgba(15,165,235,0.30) !important;
}

/* ACTIVE */
#upload_form #upload_previews_settings .btn-group-toggle .btn.active{
  background: linear-gradient(180deg, rgba(232,248,255,0.98), rgba(205,238,255,0.90)) !important;
  border-color: rgba(15,165,235,0.55) !important;

  color: rgba(11,18,32,0.92) !important;

  box-shadow:
    0 6px 14px rgba(2,6,23,0.11),
    inset 0 1px 0 rgba(255,255,255,0.80),
    0 0 0 2px rgba(15,165,235,0.11) !important;

  transform: none;
}

#upload_form #upload_previews_settings .btn-group-toggle .btn.active svg{
  color: var(--tp-blue-light) !important;
  filter: drop-shadow(0 3px 8px rgba(15,165,235,0.16));
}

/* klik = jemný „press“ */
#upload_form #upload_previews_settings .btn-group-toggle .btn:active{
  transform: translateY(0);
  box-shadow:
    0 12px 28px rgba(2,6,23,0.12),
    0 6px 12px rgba(2,6,23,0.08),
    inset 0 2px 6px rgba(0,0,0,0.10);
}

/* víc prostoru pod přepínačem typu přenosu */
#upload_form #upload_previews_settings .form-group:first-child{
  margin-bottom: 2.2rem !important;
  margin-top: 0.6rem !important;
}

/* ---------------------------------------------------------
   5) NAV-PILLS (platnost / lock / advanced / bell)
   --------------------------------------------------------- */
#upload_form #upload_previews_settings .nav.nav-pills{ gap: 8px; margin-bottom: 2rem !important; }

#upload_form #upload_previews_settings .nav.nav-pills .nav-link{
  background: rgba(255,255,255,0.74) !important;
  border: 1px solid rgba(16,24,40,.12) !important;
  border-radius: 14px !important;

  color: rgba(11,22,32,.62) !important;
  padding: .55rem .6rem !important;

  box-shadow:
    0 3px 8px rgba(16,24,40,.08),
    inset 0 1px 0 rgba(255,255,255,.65);

  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}

#upload_form #upload_previews_settings .nav.nav-pills .nav-link:hover{
  transform: none;
  box-shadow:
    0 5px 11px rgba(16,24,40,.10),
    inset 0 1px 0 rgba(255,255,255,.70);

  border-color: rgba(15,165,235,.22) !important;
}

#upload_form #upload_previews_settings .nav.nav-pills .nav-link.active{
  background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(232,245,255,0.92)) !important;
  border-color: rgba(15,165,235,.55) !important;
  color: rgba(11,22,32,.92) !important;

  box-shadow:
    0 5px 12px rgba(16,24,40,.11),
    inset 0 1px 0 rgba(255,255,255,.74),
    0 0 0 2px rgba(15,165,235,0.10);
}

#upload_form #upload_previews_settings .nav.nav-pills .nav-link svg{
  color: hsl(207deg 12.05% 32.55%) !important;
}
#upload_form #upload_previews_settings .nav.nav-pills .nav-link.active svg{
  color: rgba(15,165,235,.95) !important;
}

/* ---------------------------------------------------------
   6) SWITCHES (label vedle toggle)
   --------------------------------------------------------- */
#upload_form #upload_previews_settings .custom-control-label{
  font-weight: 850;
}

/* ---------------------------------------------------------
   7) Malé „light“ buttony uvnitř uploadu
   --------------------------------------------------------- */
#upload_form .btn.btn-sm.btn-light,
#upload_form .btn.btn-light{
  background: rgba(255,255,255,0.74) !important;
  border: 1px solid rgba(16,24,40,.12) !important;
  border-radius: 14px !important;

  box-shadow:
    0 3px 8px rgba(16,24,40,.08),
    inset 0 1px 0 rgba(255,255,255,.65);

  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease, filter .14s ease;
}

#upload_form .btn.btn-sm.btn-light:hover,
#upload_form .btn.btn-light:hover{
  transform: none;
  filter: saturate(1.02);

  box-shadow:
    0 5px 11px rgba(16,24,40,.10),
    inset 0 1px 0 rgba(255,255,255,.70);

  border-color: rgba(15,165,235,.20) !important;
}

/* ---------------------------------------------------------
   8) PRAVÝ PANEL – HLAVIČKA STATISTIK
   --------------------------------------------------------- */
#upload_form #upload_previews_files .bg-gray-100{
  background: transparent !important;
  height: 60px;
}

#upload_form #upload_previews_files .bg-gray-100 .text-muted{
  color: rgba(11,18,32,0.72) !important;
}

/* „Smazat vše“ */
#upload_form #upload_remove_all{
  color: #dc2626 !important;
  border-radius: .9rem;
  transition: background .14s ease, color .14s ease;
}
#upload_form #upload_remove_all:hover{
  color: #b91c1c !important;
  background: rgba(220,38,38,0.14) !important;
}

/* ---------------------------------------------------------
   9) SEZNAM SOUBORŮ – scroll + řádky
   --------------------------------------------------------- */
#upload_form .upload-previews{
  margin-top: 1.05rem;

  max-height: 350px;
  overflow-y: auto;
  overflow-x: clip;

  padding: .4rem .35rem .4rem .2rem;

  background: transparent;

  width: calc(100% + 8px) !important;
  margin-right: -8px !important;

  scrollbar-width: thin !important;
  scrollbar-color: rgba(160,190,220,.6) transparent !important;
}

#upload_form .upload-previews::-webkit-scrollbar{ width: 6px !important; }
#upload_form .upload-previews::-webkit-scrollbar-track{ background: transparent !important; }
#upload_form .upload-previews::-webkit-scrollbar-thumb{
  background: rgba(160,190,220,.55) !important;
  border-radius: 999px !important;
}
#upload_form .upload-previews::-webkit-scrollbar-thumb:hover{
  background: rgba(130,170,210,.85) !important;
}

/* ŘÁDKY souborů */
#upload_form .upload-previews .row{
  margin: .32rem .2rem;
  padding: .56rem .76rem;
  border-radius: 1rem;
  background:linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(236, 246, 255, 0.86));

  border: 1px solid rgba(15,165,235,.12);
  box-shadow: 0 4px 10px #06102217, inset 0 1px 0 rgba(255, 255, 255, .80);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

#upload_form .upload-previews .row:hover{
  transform: translateY(-1px);
  border-color: rgba(15,165,235,.18);

  box-shadow:0 4px 6px rgba(6,16,34,.08),
    inset 0 1px 0 rgba(255,255,255,.80);
}

/* Texty v řádcích */
#upload_form .upload-previews span,
#upload_form .upload-previews .text-muted{
  color: rgba(11,18,32,.72) !important;
}

/* progress */
#upload_form .upload-previews .progress{
  height: .65rem !important;
  background: rgba(15,165,235,.12);
  border-radius: 999px;
  overflow: hidden;
}

#upload_form .upload-previews .progress-bar{
  background: linear-gradient(90deg, rgba(159,215,255,1), var(--tp-blue-light));
  box-shadow: inset 0 -1px 0 rgba(0,0,0,.15);
}

/* ---------------------------------------------------------
   9.1) MODERN UPLOAD STATUS + FILE CARDS
   --------------------------------------------------------- */
#upload_form .tp-transfer-settings-title{
  margin: .45rem 0 .55rem;
  font-size: .84rem;
  font-weight: 700;
  color: rgba(11,18,32,.72);
}

#upload_form .tp-upload-status-strip{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .46rem;
  margin: .1rem 0 .85rem;
}

#upload_form .tp-upload-status-step{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  min-height: 34px;
  padding: .48rem .45rem;
  border-radius: .85rem;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .02em;
  color: rgba(11,18,32,.55);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(238,246,255,.82));
  border: 1px solid rgba(15,165,235,.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
  transition: all .18s ease;
}

#upload_form .tp-upload-status-step::before{
  content: "";
  width: .42rem;
  height: .42rem;
  border-radius: 50%;
  background: rgba(11,18,32,.22);
  transition: all .18s ease;
}

#upload_form .tp-upload-status-step.is-completed{
  color: #0a4d72;
  border-color: rgba(15,165,235,.24);
  background: linear-gradient(180deg, rgba(231,247,255,.95), rgba(220,242,255,.9));
}

#upload_form .tp-upload-status-step.is-completed::before{
  background: #0fa5eb;
}

#upload_form .tp-upload-status-step.is-active{
  color: #04101a;
  border-color: rgba(15,165,235,.45);
  background: linear-gradient(180deg, rgba(209,238,255,.98), rgba(177,225,252,.92));
  box-shadow: 0 8px 20px rgba(15,165,235,.18), inset 0 1px 0 rgba(255,255,255,.88);
}

#upload_form .tp-upload-status-step.is-active::before{
  background: linear-gradient(180deg, #2bc8ff, #0fa5eb);
  box-shadow: 0 0 0 4px rgba(15,165,235,.16);
}

#upload_form .tp-upload-summary-files{
  min-width: 0;
  display: flex;
  align-items: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.05;
}

#upload_form .tp-upload-summary-size{
  min-width: max-content;
  white-space: nowrap;
  font-weight: 700;
  line-height: 1.05;
}

#upload_form .tp-upload-summary-actions{
  min-width: max-content;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
}

#upload_form .tp-upload-empty-hint{
  margin-top: .85rem;
  padding: .95rem 1rem;
  border-radius: .95rem;
  border: 1px dashed rgba(15,165,235,.28);
  background: linear-gradient(180deg, rgba(15,165,235,.045), rgba(15,165,235,.02));
}

#upload_form .tp-upload-empty-hint-title{
  font-size: .92rem;
  font-weight: 700;
  color: #0b3551;
}

#upload_form .tp-upload-empty-hint-text{
  margin-top: .15rem;
  font-size: .82rem;
  color: rgba(11,18,32,.66);
}

#upload_form .tp-upload-file-card{
  position: relative;
  margin: .42rem .2rem !important;
  padding: .72rem .78rem;
  border-radius: 1rem;
  border: 1px solid rgba(15,165,235,.15);
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(236,246,255,.88));
  box-shadow: 0 4px 10px rgba(6,16,34,.08), inset 0 1px 0 rgba(255,255,255,.84);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

#upload_form .tp-upload-file-card:hover{
  transform: none;
  border-color: rgba(15,165,235,.24);
}

#upload_form .tp-upload-file-card-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .6rem;
}

#upload_form .tp-upload-file-card-title{
  display: inline-flex;
  align-items: center;
  min-width: 0;
  flex: 1 1 auto;
  font-weight: 700;
  color: rgba(11,18,32,.86);
}

#upload_form .tp-upload-file-card-size{
  flex: 0 0 auto;
  font-size: .79rem;
  color: rgba(11,18,32,.6);
}

#upload_form .tp-upload-file-card-meta{
  margin-top: .34rem;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  white-space: nowrap;
  overflow: hidden;
  gap: .22rem;
  font-size: .76rem;
  color: rgba(11,18,32,.63);
}

#upload_form .tp-upload-file-card-meta [data-altum-speed],
#upload_form .tp-upload-file-card-meta [data-altum-remaining]{
  overflow: hidden;
  text-overflow: ellipsis;
}

#upload_form .tp-upload-file-card-status{
  font-weight: 700;
  color: #0a4d72;
  flex: 0 0 auto;
}

#upload_form .tp-upload-file-card-dot{
  color: rgba(11,18,32,.4);
}

#upload_form .tp-upload-file-card-actions{
  margin-top: .46rem;
  display: flex;
  align-items: center;
  gap: .42rem;
}

#upload_form .tp-upload-file-card-actions .btn{
  min-width: 72px;
}

#upload_form .tp-upload-action-btn{
  border: 1px solid rgba(15,165,235,.2) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(244,250,255,.9)) !important;
  box-shadow: 0 1px 4px rgba(11,18,32,.055), inset 0 1px 0 rgba(255,255,255,.74) !important;
}

#upload_form .tp-upload-action-btn:hover,
#upload_form .tp-upload-action-btn:focus{
  border-color: rgba(15,165,235,.35) !important;
  box-shadow: 0 2px 7px rgba(11,18,32,.075), inset 0 1px 0 rgba(255,255,255,.82) !important;
}

#upload_form .tp-upload-summary-actions .tp-upload-remove-btn{
  min-width: 30px !important;
  width: 30px;
  height: 30px;
  border-radius: .55rem !important;
  border-color: rgba(15,165,235,.18) !important;
  color: rgba(71,85,105,.88) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(241,247,255,.9)) !important;
  box-shadow: 0 1px 4px rgba(11,18,32,.08), inset 0 1px 0 rgba(255,255,255,.84) !important;
}

#upload_form .tp-upload-summary-actions .tp-upload-remove-btn:hover,
#upload_form .tp-upload-summary-actions .tp-upload-remove-btn:focus{
  border-color: rgba(239,68,68,.45) !important;
  color: #dc2626 !important;
  background: linear-gradient(180deg, rgba(255,241,242,.98), rgba(254,226,226,.96)) !important;
  box-shadow: 0 4px 12px rgba(220,38,38,.22), inset 0 1px 0 rgba(255,255,255,.9) !important;
}

#upload_form .tp-upload-file-card-progress{
  margin-top: .48rem;
}

#upload_form .tp-upload-file-card-progress .progress{
  height: .52rem !important;
}

#upload_form .tp-upload-file-card-progress [data-altum-upload-progress]{
  transition: width .2s linear;
}

#upload_form .tp-upload-file-card[data-upload-state="uploading"]{
  border-color: rgba(15,165,235,.34);
  box-shadow: 0 8px 18px rgba(15,165,235,.13), inset 0 1px 0 rgba(255,255,255,.86);
  animation: tp-upload-card-pulse 1.6s ease-in-out infinite;
}

#upload_form .tp-upload-file-card[data-upload-state="paused"]{
  border-color: rgba(255,133,3,.35);
  background: linear-gradient(180deg, rgba(255,246,235,.96), rgba(255,240,220,.92));
}

#upload_form .tp-upload-file-card[data-upload-state="error"]{
  border-color: rgba(239,68,68,.42);
  background: linear-gradient(180deg, rgba(255,244,244,.96), rgba(255,232,232,.92));
}

#upload_form .tp-upload-file-card[data-upload-state="finalizing"]{
  border-color: rgba(34,211,238,.4);
  background: linear-gradient(180deg, rgba(239,252,255,.96), rgba(224,247,251,.9));
}

#upload_form .tp-upload-file-card[data-upload-state="done"]{
  border-color: rgba(34,197,94,.36);
  background: linear-gradient(180deg, rgba(240,253,244,.96), rgba(220,252,231,.88));
  box-shadow: 0 10px 24px rgba(34,197,94,.12), inset 0 1px 0 rgba(255,255,255,.88);
}

#upload_form .tp-upload-file-card[data-upload-state="done"] .tp-upload-file-card-status{
  color: #187a44;
}

#upload_form .tp-upload-file-card[data-upload-state="error"] .tp-upload-file-card-status{
  color: #b42318;
}

#upload_form .tp-upload-file-card[data-upload-state="paused"] .tp-upload-file-card-status{
  color: #b45309;
}

#upload_form .tp-upload-file-card[data-upload-state="finalizing"] .tp-upload-file-card-status{
  color: #0e7490;
}

@keyframes tp-upload-card-pulse {
  0%, 100% {
    box-shadow: 0 8px 18px rgba(15,165,235,.12), inset 0 1px 0 rgba(255,255,255,.86);
  }
  50% {
    box-shadow: 0 10px 22px rgba(15,165,235,.2), inset 0 1px 0 rgba(255,255,255,.9);
  }
}

@media (max-width: 991.98px){
  #upload_form .tp-upload-status-strip{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .4rem;
  }
}

@media (max-width: 575.98px){
  #upload_form .tp-upload-status-strip{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .32rem;
  }

  #upload_form .tp-upload-status-step{
    min-height: 32px;
    padding: .42rem .32rem;
    font-size: .72rem;
    border-radius: .75rem;
  }

  #upload_form .tp-upload-summary{
    padding: .48rem .5rem !important;
    gap: .35rem;
  }

  #upload_form .tp-upload-summary-files{
    font-size: .8rem;
  }

  #upload_form .tp-upload-summary-size{
    font-size: .8rem;
  }
}

@media (max-width: 420px){
  #upload_form .tp-upload-status-step{
    font-size: 0;
    padding: .36rem .2rem;
    min-height: 30px;
  }

  #upload_form .tp-upload-status-step span{
    display: none;
  }

  #upload_form .tp-upload-status-step::before{
    width: .5rem;
    height: .5rem;
  }
}

/* disable „disabled šednutí“ */
#upload_form .btn.disabled,
#upload_form .btn:disabled{
  opacity: 1;
}

/* =========================================================
   DARK THEME – UPLOADER (Transfer+ blue/orange gradients)
   Scope: only [data-theme-style="dark"] #upload_form ...
   ========================================================= */

[data-theme-style="dark"] #upload_form{
  /* helper proměnné pro konzistenci v rámci uploaderu */
  --tp-u-bg1: rgba(5, 8, 24, 0.92);
  --tp-u-bg2: rgba(2, 3, 11, 0.96);

  --tp-u-surface1: rgba(255,255,255,0.070);
  --tp-u-surface2: rgba(255,255,255,0.040);

  --tp-u-border: rgba(255,255,255,0.10);
  --tp-u-border-strong: rgba(255,255,255,0.14);

  --tp-u-text: rgba(255,255,255,0.90);
  --tp-u-muted: #dce6ffed;
  --tp-u-subtle: rgba(220,230,255,0.48);

  --tp-u-shadow-lg: 0 26px 70px rgba(0,0,0,0.72), 0 10px 26px rgba(0,0,0,0.46);
  --tp-u-shadow-md: 0 18px 44px rgba(0,0,0,0.66), 0 8px 18px rgba(0,0,0,0.40);
  --tp-u-inset: inset 0 1px 0 rgba(255,255,255,0.06);
}

/* ---------------------------------------------------------
   1) PANELS
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form #upload_previews_settings,
[data-theme-style="dark"] #upload_form #upload_previews_files{
  position: relative;
  overflow: hidden;
}

/* obsah panelu nad podkladem */
[data-theme-style="dark"] #upload_form #upload_previews_settings > *,
[data-theme-style="dark"] #upload_form #upload_previews_files > *{
  position: relative;
  z-index: 1;
}


/* MOBILE */
@media (max-width: 768px) {
[data-theme-style="dark"] #upload_form #upload_previews_settings,
[data-theme-style="dark"] #upload_form #upload_previews_files{
  position: relative;
  overflow: hidden;

  background: none !important;
  border: none !important;
  box-shadow: none !important;
}

}
/* ---------------------------------------------------------
   2) TYPO
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form .col-form-label-sm,
[data-theme-style="dark"] #upload_form label{
  color: var(--tp-u-muted) !important;
  font-weight: 750;
}

/* ---------------------------------------------------------
   3) INPUTS + PREFIX
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form .form-control.form-control-sm,
[data-theme-style="dark"] #upload_form .form-control{
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  color: var(--tp-u-text) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .30), inset 0 1px 0 rgba(255, 255, 255, .06) !important;
}

[data-theme-style="dark"] #upload_form .form-control::placeholder{
  color: rgba(220,230,255,0.40) !important;
}

[data-theme-style="dark"] #upload_form .form-control:focus{
  background: rgba(255,255,255,0.07) !important;
  border-color: rgba(15,165,235,0.48) !important;

  box-shadow:
    0 0 0 4px rgba(15,165,235,0.12),
    0 18px 40px rgba(0,0,0,0.64),
    inset 0 1px 0 rgba(255,255,255,0.08) !important;
}

/* input-group prefix "transfer.plus/" */
[data-theme-style="dark"] #upload_form .input-group-text{
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-right: 0 !important;

  color: rgba(220,230,255,0.58) !important;

  box-shadow: var(--tp-u-shadow-md), var(--tp-u-inset) !important;
}

/* ---------------------------------------------------------
   4) TRANSFER TYPE BUTTONS (Odkaz / E-mail)
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form #upload_previews_settings .btn-group-toggle .btn{
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04)) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  color: rgba(255,255,255,0.84) !important;

  box-shadow: 0 4px 10px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.06) !important;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, filter .18s ease;
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .btn-group-toggle .btn svg{
  color: rgba(220,230,255,0.74) !important;
  filter: drop-shadow(0 3px 8px rgba(15,165,235,0.14));
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .btn-group-toggle .btn:hover{
  transform: none;
  border-color: rgba(15,165,235,0.20) !important;

  box-shadow:
    0 6px 14px rgba(0,0,0,0.44),
    inset 0 1px 0 rgba(255,255,255,0.07) !important;
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .btn-group-toggle .btn.active{
  border-color: rgba(15,165,235,0.46) !important;

  background:
    radial-gradient(900px 220px at 50% 0%,
      rgba(15,165,235,0.18),
      rgba(15,165,235,0.00) 60%),
    linear-gradient(180deg,
      rgba(255,255,255,0.08),
      rgba(255,255,255,0.04)) !important;

  box-shadow:
    0 6px 14px rgba(0,0,0,0.46),
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 0 0 2px rgba(15,165,235,0.10) !important;
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .btn-group-toggle .btn.active svg{
  color: var(--tp-blue-light) !important;
  filter: drop-shadow(0 4px 10px rgba(15,165,235,0.16));
}

/* ---------------------------------------------------------
   5) NAV PILLS (platnost / lock / advanced / bell)
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form #upload_previews_settings .nav.nav-pills .nav-link{
  background: rgba(255,255,255,0.055) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  color: rgba(220,230,255,0.62) !important;

  box-shadow: 0 3px 8px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.06) !important;
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .nav.nav-pills .nav-link:hover{
  border-color: rgba(15,165,235,0.18) !important;
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .nav.nav-pills .nav-link.active{
  border-color: rgba(15,165,235,0.42) !important;
  color: rgba(255,255,255,0.90) !important;

  background:
    radial-gradient(700px 200px at 50% 0%,
      rgba(15,165,235,0.14),
      rgba(15,165,235,0.00) 60%),
    linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.04)) !important;

  box-shadow:
    0 5px 12px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 0 0 2px rgba(15,165,235,0.08) !important;
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .nav.nav-pills .nav-link svg{
  color: rgba(220,230,255,0.55) !important;
}
[data-theme-style="dark"] #upload_form #upload_previews_settings .nav.nav-pills .nav-link.active svg{
  color: var(--tp-blue-light) !important;
}

/* ---------------------------------------------------------
   6) SMALL LIGHT BUTTONS
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form .btn.btn-sm.btn-light,
[data-theme-style="dark"] #upload_form .btn.btn-light{
  background: rgba(255,255,255,0.055) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  color: rgba(220,230,255,0.74) !important;

  box-shadow: 0 3px 8px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.06) !important;
}

/* ---------------------------------------------------------
   7) FILES HEADER (bg-gray-100)
   --------------------------------------------------------- */

[data-theme-style="dark"] #upload_form #upload_previews_files .bg-gray-100 .text-muted{
  color: #dce6ffed !important;
}

/* remove all */
[data-theme-style="dark"] #upload_form #upload_remove_all{
  color: #f87171 !important;
}
[data-theme-style="dark"] #upload_form #upload_remove_all:hover{
  color: #fecaca !important;
  background: rgba(239,68,68,0.2) !important;
}

/* ---------------------------------------------------------
   8) FILE ROWS
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form .upload-previews{
  scrollbar-color: rgba(120,140,175,.55) transparent !important;
}
[data-theme-style="dark"] #upload_form .upload-previews::-webkit-scrollbar-thumb{
  background: rgba(120,140,175,.55) !important;
}
[data-theme-style="dark"] #upload_form .upload-previews::-webkit-scrollbar-thumb:hover{
  background: rgba(120,140,175,.82) !important;
}

[data-theme-style="dark"] #upload_form .upload-previews .row{
  background:
    radial-gradient(900px 260px at 20% -10%,
      rgba(15,165,235,0.10),
      rgba(15,165,235,0.00) 60%),
    linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.04)) !important;

  border: 1px solid rgba(255,255,255,0.10) !important;

  box-shadow:0 5px 12px rgb(0 0 0 / 28%), inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;

  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

[data-theme-style="dark"] #upload_form .upload-previews .row:hover{
  transform: translateY(-1px);
  border-color: rgba(15,165,235,0.16) !important;

}

[data-theme-style="dark"] #upload_form .upload-previews span,
[data-theme-style="dark"] #upload_form .upload-previews .text-muted{
  color: rgba(220,230,255,0.66) !important;
}

/* ---------------------------------------------------------
   9) PROGRESS
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form .upload-previews .progress{
  background: rgba(15,165,235,0.12) !important;
}
[data-theme-style="dark"] #upload_form .upload-previews .progress-bar{
  background: linear-gradient(
    90deg,
    rgba(15,165,235,0.55),
    rgba(15,165,235,0.95)
  ) !important;
  box-shadow: inset 0 -1px 0 rgba(0,0,0,0.22);
}

/* DARK: upload status + cards */
[data-theme-style="dark"] #upload_form .tp-transfer-settings-title{
  color: rgba(226,232,240,.78);
}

[data-theme-style="dark"] #upload_form .tp-upload-status-step{
  color: rgba(220,230,255,.62);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));
  border-color: rgba(255,255,255,.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

[data-theme-style="dark"] #upload_form .tp-upload-status-step::before{
  background: rgba(220,230,255,.24);
}

[data-theme-style="dark"] #upload_form .tp-upload-status-step.is-completed{
  color: #c5ebff;
  border-color: rgba(15,165,235,.32);
  background: linear-gradient(180deg, rgba(15,165,235,.16), rgba(15,165,235,.09));
}

[data-theme-style="dark"] #upload_form .tp-upload-status-step.is-active{
  color: #f4fbff;
  border-color: rgba(34,211,238,.44);
  background: linear-gradient(180deg, rgba(34,211,238,.24), rgba(14,165,233,.13));
  box-shadow: 0 10px 20px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.09);
}

[data-theme-style="dark"] #upload_form .tp-upload-summary{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
}

[data-theme-style="dark"] #upload_form .tp-upload-summary-actions .tp-upload-remove-btn{
  border-color: rgba(255,255,255,.16) !important;
  color: rgba(226,232,240,.9) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04)) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-summary-actions .tp-upload-remove-btn:hover,
[data-theme-style="dark"] #upload_form .tp-upload-summary-actions .tp-upload-remove-btn:focus{
  border-color: rgba(248,113,113,.5) !important;
  color: #fecaca !important;
  background: linear-gradient(180deg, rgba(248,113,113,.2), rgba(239,68,68,.15)) !important;
}

.tp-transfer-kpi-panel{
  margin-top: 1rem;
  padding: .68rem;
  position: relative;
  z-index: 0;
  overflow: visible !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  --tp-kpi-shell-from: #f8fcff;
  --tp-kpi-shell-mid: #f3f9ff;
  --tp-kpi-shell-to: #ecf5ff;
  --tp-kpi-shell-border: rgba(15, 165, 235, .18);
  --tp-kpi-shell-shadow: 0 10px 24px rgba(6, 16, 34, .08), inset 0 1px 0 rgba(255, 255, 255, .85);
  --tp-kpi-card-bg-1: rgba(255, 255, 255, .85);
  --tp-kpi-card-bg-2: rgba(249, 253, 255, .72);
  --tp-kpi-card-border: rgba(15, 165, 235, .16);
  --tp-kpi-card-shadow: 0 4px 12px rgba(10, 53, 90, .08), inset 0 1px 0 rgba(255,255,255,.72);
  --tp-kpi-card-hover-border: rgba(15, 165, 235, .26);
  --tp-kpi-card-hover-shadow: 0 8px 16px rgba(10, 53, 90, .12), inset 0 1px 0 rgba(255,255,255,.78);
  --tp-kpi-text: rgba(16, 37, 63, .9);
  --tp-kpi-value: #10253f;
  --tp-kpi-icon-bg-1: rgba(15, 165, 235, .12);
  --tp-kpi-icon-bg-2: rgba(15, 165, 235, .06);
  --tp-kpi-icon-border: rgba(15, 165, 235, .2);
  --tp-kpi-icon-color: #0a88cf;
}

.tp-transfer-kpi-panel::before{
  content: "";
  position: absolute;
  inset: 0;
  left: 0;
  transform: none;
  width: auto;
  max-width: none;
  border-radius: 22px;
  background: linear-gradient(145deg, var(--tp-kpi-shell-from) 0%, var(--tp-kpi-shell-mid) 48%, var(--tp-kpi-shell-to) 100%);
  border: 1px solid var(--tp-kpi-shell-border);
  box-shadow: var(--tp-kpi-shell-shadow);
  z-index: -1;
}

.tp-transfer-kpi-panel::after{
  content: none;
}

.tp-transfer-kpi-panel > .row{
  margin-left: 0;
  margin-right: 0;
  margin-bottom: 0;
  overflow: visible !important;
}

.tp-transfer-kpi-panel > .row > [class*="col-"]{
  padding: .52rem .52rem !important;
  overflow: visible !important;
}

.tp-transfer-kpi-panel .card{
  border-radius: 14px;
  border: 1px solid var(--tp-kpi-card-border) !important;
  background: linear-gradient(168deg, var(--tp-kpi-card-bg-1), var(--tp-kpi-card-bg-2)) !important;
  box-shadow: var(--tp-kpi-card-shadow) !important;
  overflow: visible !important;
  color: var(--tp-kpi-text);
  transition: border-color .16s ease, box-shadow .16s ease;
  backdrop-filter: blur(1px);
}

.tp-transfer-kpi-panel .card:hover{
  border-color: var(--tp-kpi-card-hover-border) !important;
  box-shadow: var(--tp-kpi-card-hover-shadow) !important;
}

.tp-transfer-kpi-panel .card.overflow-hidden{
  overflow: visible !important;
}

.tp-transfer-kpi-panel .card > .pl-3{
  padding-left: .95rem !important;
}

.tp-transfer-kpi-panel .card-body{
  display: flex;
  align-items: center;
  padding: .95rem 1rem !important;
  font-size: .94rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--tp-kpi-text);
}

.tp-transfer-kpi-panel .card-body .h6{
  margin-bottom: 0;
  font-size: inherit;
  font-weight: 900;
  letter-spacing: 0;
  color: var(--tp-kpi-value);
}

.tp-transfer-kpi-panel .card a.text-reset{
  color: inherit !important;
}

.tp-transfer-kpi-panel .card a.text-reset:hover,
.tp-transfer-kpi-panel .card a.text-reset:focus{
  color: #0a88cf !important;
}

.tp-transfer-kpi-panel .text-danger{
  color: #b91c1c !important;
}

.tp-transfer-kpi-panel .index-widget-icon{
  width: 2rem;
  height: 2rem;
  border-radius: .75rem !important;
  border: 1px solid var(--tp-kpi-icon-border);
  background: linear-gradient(180deg, var(--tp-kpi-icon-bg-1), var(--tp-kpi-icon-bg-2)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5);
}

.tp-transfer-kpi-panel .index-widget-icon i,
.tp-transfer-kpi-panel .index-widget-icon .text-primary{
  color: var(--tp-kpi-icon-color) !important;
}


.tp-footer .footer.card.my-5 {
  margin-bottom: 1.5rem !important;
}

[data-theme-style="dark"] .tp-transfer-kpi-panel{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  --tp-kpi-shell-from: rgba(14, 25, 40, .92);
  --tp-kpi-shell-mid: rgba(18, 34, 53, .92);
  --tp-kpi-shell-to: rgba(21, 43, 68, .9);
  --tp-kpi-shell-border: rgba(95, 170, 227, .24);
  --tp-kpi-shell-shadow: 0 12px 26px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, .06);
  --tp-kpi-card-bg-1: rgba(21, 43, 67, .72);
  --tp-kpi-card-bg-2: rgba(15, 31, 50, .72);
  --tp-kpi-card-border: rgba(142, 206, 255, .22);
  --tp-kpi-card-shadow: 0 6px 14px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255,255,255,.06);
  --tp-kpi-card-hover-border: rgba(175, 225, 255, .36);
  --tp-kpi-card-hover-shadow: 0 9px 18px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255,255,255,.1);
  --tp-kpi-text: rgba(224, 238, 252, .92);
  --tp-kpi-value: #f2f8ff;
  --tp-kpi-icon-bg-1: rgba(124, 204, 255, .18);
  --tp-kpi-icon-bg-2: rgba(124, 204, 255, .1);
  --tp-kpi-icon-border: rgba(160, 221, 255, .3);
  --tp-kpi-icon-color: #9edfff;
}

[data-theme-style="dark"] .tp-transfer-kpi-panel::before{
  box-shadow: var(--tp-kpi-shell-shadow);
}

[data-theme-style="dark"] .tp-transfer-kpi-panel .card{
  backdrop-filter: blur(1.2px);
}

[data-theme-style="dark"] .tp-transfer-kpi-panel .text-danger{
  color: #fecdd3 !important;
}

@media (max-width: 991.98px){
  .tp-transfer-kpi-panel{
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    max-width: 100vw;
    margin-left: 0;
    margin-right: 0;
    border-radius: 0 !important;
    padding: .6rem .55rem .72rem;
  }

  .tp-transfer-kpi-panel::before{
    border-radius: 0 !important;
  }

  .tp-transfer-kpi-panel > .row > [class*="col-"]{
    padding: .42rem .42rem !important;
  }

  .tp-transfer-kpi-panel .card{
    min-height: 64px;
  }

  .tp-transfer-kpi-panel .card-body{
    font-size: .9rem;
  }
}

@media (max-width: 575.98px){
  .tp-transfer-kpi-panel .card{
    border-radius: 12px;
  }

  .tp-transfer-kpi-panel .card > .pl-3{
    padding-left: .7rem !important;
  }

  .tp-transfer-kpi-panel .index-widget-icon{
    width: 2rem;
    height: 2rem;
  }
}


.tp-transfer-detail-headbar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: .75rem 1rem;
  margin-bottom: 2rem !important;
}

.tp-transfer-detail-heading {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  min-width: 0;
  flex: 1 1 auto;
}

.tp-transfer-detail-heading .h4 {
  color: #8b9099;
  padding-left: 1.5rem;
}

.tp-transfer-detail-link-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: .3rem;
  min-width: 0;
  flex: 0 1 auto;
  max-width: 100%;
}

.tp-transfer-detail-link-icon {
  flex: 0 0 auto;
  line-height: 1;
}

.tp-transfer-detail-link {
  min-width: 0;
  flex: 0 1 auto;
  max-width: min(100%, 32rem);
}

.tp-transfer-detail-link a,
.tp-transfer-detail-link span {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tp-transfer-detail-link-actions {
  flex: 0 0 auto;
  gap: .05rem;
}

.tp-transfer-detail-link-actions .btn {
  padding: .2rem .35rem;
  border-radius: .5rem;
}

.tp-transfer-detail-link-actions #daterangepicker {
  margin-left: .2rem;
  border-radius: .6rem;
}

.tp-transfer-detail-link-actions .btn:hover,
.tp-transfer-detail-link-actions .btn:focus {
  background: rgba(15, 165, 235, .10);
  color: #0c223b !important;
  text-decoration: none;
}

[data-theme-style="dark"] .tp-transfer-detail-link-actions .btn:hover,
[data-theme-style="dark"] .tp-transfer-detail-link-actions .btn:focus {
  background: rgba(63, 185, 240, .14);
  color: rgba(238, 246, 255, .96) !important;
}

[data-theme-style="dark"] .tp-transfer-detail-heading .h4 {
  color: rgba(228, 238, 252, .86);
}

[data-theme-style="dark"] .tp-transfer-detail-link-actions #daterangepicker {
  background: linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.025)) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  color: rgba(237,245,255,.92) !important;
}

@media (min-width: 992px) {
  .tp-transfer-detail-link-row {
    gap: .45rem;
  }

  .tp-transfer-detail-link-icon {
    font-size: 1.02rem;
    color: #0f4f86 !important;
  }

  .tp-transfer-detail-link a,
  .tp-transfer-detail-link span {
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1.2;
  }

  .tp-transfer-detail-link-actions {
    gap: .16rem;
  }

  .tp-transfer-detail-link-actions .btn {
    padding: .36rem .5rem;
    border-radius: .62rem;
  }

  .tp-transfer-detail-link-actions .btn i {
    font-size: 1rem;
  }
}

@media (max-width: 767.98px) {
  .tp-footer .footer.card {
    padding: 0 1rem;
  }

  .tp-footer-modern-links {
    margin: 0 0 0.8rem 0;
  }

  .tp-footer-modern-divider {
    margin-top: 1rem;
  }

  .custom-breadcrumbs {
    display: flex !important;
    align-items: center;
    flex-wrap: nowrap !important;
    gap: 0;
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none !important;
    -ms-overflow-style: none;
    white-space: nowrap;
    min-width: 0;
    margin-bottom: .95rem;
    padding: .15rem .25rem .55rem 0;
  }

  .custom-breadcrumbs::-webkit-scrollbar {
    width: 0 !important;
    height: 0 !important;
    display: none !important;
    background: transparent !important;
  }

  .custom-breadcrumbs::-webkit-scrollbar-track,
  .custom-breadcrumbs::-webkit-scrollbar-thumb {
    background: transparent !important;
    border: 0 !important;
  }

  .custom-breadcrumbs li {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    flex: 0 0 auto;
  }

  .custom-breadcrumbs li i {
    flex: 0 0 auto;
  }

  .custom-breadcrumbs > * {
    flex-shrink: 0;
  }

  .custom-breadcrumbs li a,
  .custom-breadcrumbs li span,
  .custom-breadcrumbs li.active {
    white-space: nowrap;
  }

  .tp-transfer-detail-headbar {
    align-items: flex-start;
    flex-direction: column;
    gap: .4rem;
  }

  .tp-transfer-detail-heading {
    width: 100%;
    max-width: 100%;
  }

  .tp-transfer-detail-link-row {
    gap: .2rem;
    width: 100%;
    flex-wrap: nowrap;
  }

  .tp-transfer-detail-link {
    max-width: none;
    flex: 1 1 auto;
    min-width: 0;
  }

  .tp-transfer-detail-link-actions {
    width: auto;
    margin-left: auto;
    gap: .15rem;
    flex-wrap: nowrap;
  }

  .tp-transfer-detail-heading .h4,
  .tp-transfer-detail-heading .h4.text-truncate {
    position: relative;
    display: block !important;
    padding-right: 0;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none !important;
    -ms-overflow-style: none;
    white-space: nowrap !important;
    text-overflow: unset !important;
    padding-bottom: .2rem;
  }

  .tp-transfer-detail-heading .h4::-webkit-scrollbar,
  .tp-transfer-detail-heading .h4.text-truncate::-webkit-scrollbar {
    width: 0 !important;
    height: 0 !important;
    display: none !important;
    background: transparent !important;
  }

  .tp-transfer-detail-heading .h4::-webkit-scrollbar-track,
  .tp-transfer-detail-heading .h4::-webkit-scrollbar-thumb,
  .tp-transfer-detail-heading .h4.text-truncate::-webkit-scrollbar-track,
  .tp-transfer-detail-heading .h4.text-truncate::-webkit-scrollbar-thumb {
    background: transparent !important;
    border: 0 !important;
  }

  .tp-transfer-detail-heading .h4::after,
  .tp-transfer-detail-heading .h4.text-truncate::after {
    content: none !important;
    display: none !important;
  }
}

[data-theme-style="dark"] #upload_form .tp-upload-empty-hint{
  border-color: rgba(34,211,238,.28);
  background: linear-gradient(180deg, rgba(34,211,238,.1), rgba(34,211,238,.04));
}

[data-theme-style="dark"] #upload_form .tp-upload-empty-hint-title{
  color: #daf4ff;
}

[data-theme-style="dark"] #upload_form .tp-upload-empty-hint-text{
  color: rgba(220,230,255,.72);
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.035)) !important;
  border-color: rgba(255,255,255,.12) !important;
  box-shadow: 0 6px 14px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.07) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card-title{
  color: rgba(239,246,255,.9);
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card-size{
  color: rgba(220,230,255,.62);
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card-meta{
  color: rgba(220,230,255,.66);
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card-status{
  color: #90dcff;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card-dot{
  color: rgba(220,230,255,.4);
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="uploading"]{
  border-color: rgba(34,211,238,.36) !important;
  box-shadow: 0 12px 26px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.09) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="paused"]{
  border-color: rgba(255,133,3,.46) !important;
  background: linear-gradient(180deg, rgba(255,133,3,.18), rgba(255,133,3,.08)) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="error"]{
  border-color: rgba(248,113,113,.5) !important;
  background: linear-gradient(180deg, rgba(248,113,113,.17), rgba(248,113,113,.08)) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="finalizing"]{
  border-color: rgba(34,211,238,.46) !important;
  background: linear-gradient(180deg, rgba(34,211,238,.16), rgba(34,211,238,.08)) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="done"]{
  border-color: rgba(74,222,128,.46) !important;
  background: linear-gradient(180deg, rgba(74,222,128,.16), rgba(74,222,128,.08)) !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.1) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="done"] .tp-upload-file-card-status{
  color: #8cf4b7;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="error"] .tp-upload-file-card-status{
  color: #ffb4b4;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="paused"] .tp-upload-file-card-status{
  color: #ffd08c;
}

[data-theme-style="dark"] #upload_form .tp-upload-file-card[data-upload-state="finalizing"] .tp-upload-file-card-status{
  color: #9be8ff;
}

/* ---------------------------------------------------------
   10) “DISABLED” – držíme vzhled (bez šednutí)
   --------------------------------------------------------- */
[data-theme-style="dark"] #upload_form .btn.disabled,
[data-theme-style="dark"] #upload_form .btn:disabled{
  opacity: 1 !important;
}

/* =========================================================
   TP FEATURE SECTION – 3 reasons to start
   ========================================================= */

.tp-feature-section{
  padding: 30px 0 100px;
  background: transparent;
  position: relative;
  z-index: 2;
  --tp-feature-bleed: clamp(4rem, 10vw, 12rem);
  --tp-feature-edge-padding: clamp(1rem, 2.8vw, 2.4rem);
}

.tp-feature-section .text-truncate{
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: normal !important;
}

.tp-feature-section .row{
  align-items: stretch;
  justify-content: center;
}

.tp-feature-section .tp-feature-section-panel{
  position: relative;
  padding: .55rem 0;
  z-index: 0;
}

.tp-feature-section .tp-feature-section-panel::before{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  width: 100vw;
  max-width: 100vw;
  border-radius: 0;
  background: linear-gradient(180deg, rgba(214, 237, 252, .92), rgba(201, 231, 249, .86));
  border: 1px solid rgba(15, 165, 235, .14);
  box-shadow: var(--tp-dashboard-card-shadow);
  z-index: -1;
  opacity: 0;
  transition: opacity .7s ease-out, transform .7s ease-out;
}

.tp-feature-section .tp-feature-section-panel.tp-inview::before{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.tp-feature-section .col-12.col-lg{
  display: flex;
}

.tp-feature-section .tp-feature-step{
  display: flex;
  align-items: flex-start;
  gap: 0;
  position: relative;
  overflow: hidden;
  border-radius: 22px !important;
  border: 1px solid rgb(18 52 124) !important;
  background: linear-gradient(180deg, #106db4, rgb(18 52 124)) !important;
  box-shadow: var(--tp-dashboard-card-shadow) !important;
  padding: 5.5rem 1.6rem 1.15rem;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.tp-feature-section .row > .col-12.col-lg:nth-child(1) .tp-feature-step{
  border-color: rgb(35 136 219) !important;
  background: linear-gradient(180deg, #34b5ef, rgb(35 136 219)) !important;
}

.tp-feature-section .row > .col-12.col-lg:nth-child(2) .tp-feature-step{
  border-color: rgb(22 97 184) !important;
  background: linear-gradient(180deg, #2095da, rgb(22 97 184)) !important;
}

.tp-feature-section .row > .col-12.col-lg:nth-child(3) .tp-feature-step{
  border-color: rgb(18 52 124) !important;
  background: linear-gradient(180deg, #106db4, rgb(18 52 124)) !important;
}

.tp-feature-section .row > .col-12.col-lg:nth-child(1) .tp-feature-step-number{
  background: linear-gradient(180deg, rgb(224 247 255 / 55%) 0%, rgba(224, 247, 255, 0) 82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

.tp-feature-section .row > .col-12.col-lg:nth-child(2) .tp-feature-step-number{
  background: linear-gradient(180deg, rgb(190 236 255 / 54%) 0%, rgba(190, 236, 255, 0) 82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

.tp-feature-section .row > .col-12.col-lg:nth-child(3) .tp-feature-step-number{
  background: linear-gradient(180deg, rgb(135 214 255 / 48%) 0%, rgba(135, 214, 255, 0) 82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

.tp-feature-section .tp-feature-step-number{
  flex: 0 0 auto;
  min-width: 3rem;
  font-size: 9.5rem;
  line-height: .9;
  font-weight: 900;
  letter-spacing: -.03em;
  position: absolute;
    top: 2px;
    right: 14px;
  z-index: 1;
  pointer-events: none;
  user-select: none;
  background: linear-gradient(180deg, rgb(12 165 235 / 71%) 0%, rgba(15, 165, 235, 0) 80%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

.tp-feature-section .tp-feature-step-content{
  min-width: 0;
  position: relative;
  z-index: 5;
}

.tp-feature-section .tp-feature-step-content .h6{
  display: block;
  margin: 0 0 .5rem 0;
  font-weight: 850;
  font-size: 1.18rem;
  line-height: 1.18;
  color: rgb(255 255 255 / 94%) !important;
}

.tp-feature-section .tp-feature-step-content .small.text-muted{
  margin: 0;
  color: rgb(255 255 255 / 75%) !important;
  font-size: 1rem;
  line-height: 1.55;
  display: block;
}

@media (max-width: 991.98px){
  .tp-feature-section{
    padding: 40px 0 0;
    --tp-feature-bleed: 0rem;
  }
  .tp-feature-section .tp-feature-section-panel{
    padding: .55rem 0;
    border-radius: 20px;
  }
  .tp-feature-section .tp-feature-section-panel::before{
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    max-width: 100vw;
    border-radius: 0;
  }
  .tp-feature-section .tp-feature-step{
    min-height: 146px;
    padding: 3.25rem 1rem .95rem;
  }
  .tp-feature-section .tp-feature-step-number{
    min-width: 0;
    font-size: 6.4rem;
    right: .7rem;
    top: -.2rem;
  }
}

@media (prefers-reduced-motion: reduce){
  .tp-feature-section .tp-feature-section-panel::before{
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    transition: none;
  }
}

[data-theme-style="dark"] .tp-feature-section .tp-feature-step{
  background: linear-gradient(180deg, #0d3961, #0a2139) !important;
  border: 1px solid rgba(106, 204, 255, .20) !important;
  box-shadow: 0 14px 28px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255,255,255,.06) !important;
}

[data-theme-style="dark"] .tp-feature-section .tp-feature-section-panel::before{
  background: linear-gradient(180deg, rgba(8, 30, 52, .84), rgba(6, 20, 36, .92));
  border-color: rgba(123, 212, 255, .10);
  box-shadow: 0 12px 26px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255, 255, 255, .03);
}

@media (min-width: 1400px) {
  .tp-feature-section {
    --tp-feature-bleed: clamp(14rem, 21vw, 32rem);
    --tp-feature-edge-padding: clamp(.12rem, .35vw, .35rem);
  }
}

[data-theme-style="dark"] .tp-feature-section .tp-feature-step-number{
  background: linear-gradient(180deg, rgba(126,219,255,.28) 0%, rgba(126,219,255,0) 82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  text-shadow: none;
}

[data-theme-style="dark"] .tp-feature-section .row > .col-12.col-lg:nth-child(1) .tp-feature-step{
  background: linear-gradient(180deg, #1b7fc2, #11456f) !important;
  border-color: rgba(133, 223, 255, .26) !important;
}

[data-theme-style="dark"] .tp-feature-section .row > .col-12.col-lg:nth-child(2) .tp-feature-step{
  background: linear-gradient(180deg, #1569a8, #103a61) !important;
  border-color: rgba(119, 209, 255, .24) !important;
}

[data-theme-style="dark"] .tp-feature-section .row > .col-12.col-lg:nth-child(3) .tp-feature-step{
  background: linear-gradient(180deg, #0f4f86, #0b2744) !important;
  border-color: rgba(102, 190, 255, .22) !important;
}

[data-theme-style="dark"] .tp-feature-section .row > .col-12.col-lg:nth-child(1) .tp-feature-step-number{
  background: linear-gradient(180deg, rgba(225, 247, 255, .34) 0%, rgba(225, 247, 255, 0) 82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

[data-theme-style="dark"] .tp-feature-section .row > .col-12.col-lg:nth-child(2) .tp-feature-step-number{
  background: linear-gradient(180deg, rgba(190, 236, 255, .31) 0%, rgba(190, 236, 255, 0) 82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

[data-theme-style="dark"] .tp-feature-section .row > .col-12.col-lg:nth-child(3) .tp-feature-step-number{
  background: linear-gradient(180deg, rgba(154, 217, 255, .28) 0%, rgba(154, 217, 255, 0) 82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

[data-theme-style="dark"] .tp-feature-section .tp-feature-step-content .h6{
  color: #ffffff !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.65);
}

[data-theme-style="dark"] .tp-feature-section .tp-feature-step-content .small.text-muted{
  color: rgba(226, 238, 252, .80) !important;
}

/* =========================================================
   TP TRUST / STATS BLOCK – MINIMAL ORANGE GLASS (no animation)
   Scope: only .tp-trust-block
   ========================================================= */

.tp-trust-block{
  z-index: 2;
  position: relative;
}

.tp-trust-block .card{
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  border: 10px solid rgb(246 248 249);
}

[data-theme-style="dark"] .tp-trust-block .card{
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  border: 10px solid #040506;
}


.tp-trust-block .card-body{
  position: relative;
  padding: 3.0rem 3.2rem !important;
}

.tp-trust-block .h3{
  font-size: 2.0rem;
  line-height: 1.2;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: rgba(8,18,32,.95);
}

[data-theme-style="dark"] .tp-trust-block .h3{
  color: #dae8f2;
}


/* responsive */
@media (max-width: 991px){
  .tp-trust-block{ padding: 70px 0; }
  .tp-trust-block .card-body{ padding: 2.2rem 1.6rem 2.1rem; }
  .tp-trust-block .h3{ font-size: 1.6rem; }
}


/* =========================================================
   TP FEATURES
   ========================================================= */



.tp-features {
  position: relative;
  isolation: isolate;
  padding: 11rem 0 5rem;
  margin: -6.3rem 0;
  background: transparent !important;
  border-top: none !important;
  border-bottom: none !important;
}

.tp-features::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  max-width: 100vw;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(214, 237, 252, .92), rgba(201, 231, 249, .86)) !important;
  border: 1px solid rgba(15, 165, 235, .14);
  box-shadow: var(--tp-dashboard-card-shadow);
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,.94) 52%, rgba(0,0,0,.58) 76%, rgba(0,0,0,0) 100%);
  mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,.94) 52%, rgba(0,0,0,.58) 76%, rgba(0,0,0,0) 100%);
}

.tp-features > .container {
  position: relative;
  z-index: 1;
}

[data-theme-style="dark"] .tp-features {
  background: transparent !important;
  border-top: none !important;
  border-bottom: none !important;
}

[data-theme-style="dark"] .tp-features::before {
  background: linear-gradient(180deg, rgba(15, 28, 46, .92), rgba(7, 12, 22, .94)) !important;
  border: 1px solid rgba(95, 175, 235, .24);
  box-shadow: 0 8px 18px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .06);
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,.94) 52%, rgba(0,0,0,.58) 76%, rgba(0,0,0,0) 100%);
  mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,.94) 52%, rgba(0,0,0,.58) 76%, rgba(0,0,0,0) 100%);
}

/* CARDS */
.tp-features .card {
  background: linear-gradient(160deg, rgb(0 0 0 / 0%), rgb(255 255 255 / 46%));
  border: 1px solid rgb(255 255 255 / 35%);
  border-radius: 22px;
  box-shadow: 0 5px 40px rgb(106 106 106 / 12%);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: transform .35s ease, box-shadow .35s ease;
}

[data-theme-style="dark"] .tp-features .card {
  background: linear-gradient(160deg, rgb(0 0 0 / 0%), #00000038);
    border: 1px solid rgb(7 34 53);
    box-shadow: 0 5px 40px rgb(0 0 0 / 32%);
}

.tp-features .card:hover {
  transform: translateY(-6px);
  box-shadow: 0 5px 40px rgb(106 106 106 / 65%);
}

[data-theme-style="dark"] .tp-features .card:hover {
  transform: translateY(-6px);
  box-shadow: 0 5px 40px rgb(0 0 0 / 43%);
}

.tp-features .h5 {
  color: #2a2a2a;
  font-weight: 600;
}

[data-theme-style="dark"] .tp-features .h5 {
  color: #ffffffeb;
}

.tp-features .text-muted {
  color: rgb(0 0 0 / 65%) !important;
  font-size: .95rem;
  line-height: 1.6;
}

[data-theme-style="dark"] .tp-features .text-muted {
  color: #a3b4c8 !important;
}

.tp-features .index-card-image {
  width: 100%;
  height: 11rem;
  object-fit: cover;
  border-radius: 18px;
}

/* MOBILE */
@media (max-width: 768px) {
  .tp-features {
    background-size: cover;
    background-position: top center;
    padding: 11rem 0 4rem;
    margin: -12.5rem 0;
    border-radius: 0;
  }
  .tp-features .index-card-image {
  width: 100%;
  height: 13rem;
  object-fit: cover;
  border-radius: 18px;
}
}

/* =========================================================
   TP INTRO SECTION – WHITE SaaS TRON + TOP NOTCH (CUTOUT)
   + DECOR ICONS (SAFE, NO HTML CHANGES)
   Scope: only .tp-intro-section
   ========================================================= */

.tp-intro-section{
  position: relative;
  padding-top: 4.5rem;
}

/* obsah sekce */
.tp-intro-section > .container{
  position: relative;
  z-index: 2; /* ✅ text vždy nad ikonami */
  padding-top: 42px;
  padding-bottom: 56px;
}

/* ✅ IKONKY (dekor) – bezpečně na containeru */
.tp-intro-section > .container::before{
  content:"";
  position:absolute;
  inset: -22px -28px;
  pointer-events:none;
  z-index: 1;

  /* trochu prostoru "na kreslení" (ať to nevypadá uřízlé) */
  min-height: 260px;

  /* LEVÁ / PRAVÁ STRANA – mimo text (střed necháme volný) */
  background-position:
    4% 31%,     /* image */
    92% 16%,    /* mp4 */
    0% 54%,     /* music */
    100% 39%,    /* pdf */
    7% 79%,    /* zip */
    98% 82%,    /* folders */
    95% 54%;    /* video dole jemně uprostřed */

  /* různé velikosti (kontrolovaně) */
  background-size:
    80px 80px,
    70px 70px,
    70px 70px,
    60px 60px,
    68px 68px,
    64px 64px,
    52px 52px;

  /* jemné sjednocení + pastel dojem */
  opacity: 0;
  transform: scale(0.965);

  animation: tpIntroIconsIn .65s cubic-bezier(.22,.61,.36,1) forwards;
  animation-delay: .25s;
}

/* aby byl text vždy nad pseudo-elementem */
.tp-intro-section .tp-intro-title,
.tp-intro-section .tp-intro-text{
  position: relative;
  z-index: 2;
}

/* TITLE */
.tp-intro-title{
  font-size: 2.4rem;
  font-weight: 800;
  letter-spacing: -0.025em;
  margin-bottom: 1.2rem;

  color: rgba(11,18,32,.95);
  text-shadow: 0 1px 0 rgba(255,255,255,.6);
}

/* TEXT */
.tp-intro-text{
  font-size: 1.2rem;
  color: rgba(11,18,32,.72);
  margin: 0 auto;
  max-width: 920px;
}

.tp-intro-text strong{
  color: rgba(11,18,32,.9);
  font-weight: 600;
}

/* Animace – jednorázově, žádné kmity */
@keyframes tpIntroIconsIn{
  to{
    opacity: 1;
    transform: scale(1);
  }
}

/* MOBILE */
@media (max-width: 768px){
  

  .tp-intro-section > .container{
    padding-top: 28px;
    padding-bottom: 38px;
  }

  .tp-intro-title{ font-size: 2.0rem; }
  .tp-intro-text{ font-size: 1rem; line-height: 1.7; }
}

/* SMALL MOBILE – vypnout ikonky úplně */
@media (max-width: 575.98px){
  .tp-intro-section > .container::before{
    content: none;
  }
}

/* DARK */
[data-theme-style="dark"] .tp-intro-section{
  background: #040506;
}

[data-theme-style="dark"] .tp-intro-title{
  color: var(--tp-color-text-main);
  text-shadow: 0 1px 0 rgba(0,0,0,0.35);
}

[data-theme-style="dark"] .tp-intro-text{
  color: var(--tp-color-text-muted);
}

/* Dark: ikonky a stíny trochu jemněji */
[data-theme-style="dark"] .tp-intro-section > .container::before{
  opacity: 0;
  filter: drop-shadow(0 14px 34px rgba(0,0,0,0.40));
}


/* =========================================================
   TP BLOG SECTION – SaaS clean (LIGHT)
   Scope: only .tp-blog-section
   ========================================================= */

.tp-blog-section{
  position: relative;
  overflow: hidden;
}


.tp-blog-section > .container{
  position:relative;
  z-index:1;
}

/* Nadpis – čistý, SaaS */
.tp-blog-section h2{
  font-size: clamp(1.7rem, 2.6vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color:#0f172a;
  margin:0;
}

/* =========================================================
   BLOG CARDS – “product tiles”
   ========================================================= */

@media (min-width: 992px){
  .tp-blog-section .tp-blog-grid{
    display: grid;
    grid-template-columns: 35fr 32.5fr 32.5fr; /* 35 / 65 */
    gap: 1rem;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item{
    margin: 0 !important;
    padding: 0 !important;
    max-width: none !important;
    width: auto !important;
    flex: initial !important;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item:nth-child(1){
    grid-column: 1;
    grid-row: 1 / span 2;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item:nth-child(2){
    grid-column: 2;
    grid-row: 1;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item:nth-child(3){
    grid-column: 3;
    grid-row: 1;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item:nth-child(4){
    grid-column: 2;
    grid-row: 2;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item:nth-child(5){
    grid-column: 3;
    grid-row: 2;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item.tp-blog-item--featured{
    grid-column: 1;
    grid-row: 1 / span 2;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item.tp-blog-item--featured .card-title{
    font-size: clamp(1.45rem, 1.5vw, 1.72rem);
    line-height: 1.2;
  }

  .tp-blog-section .tp-blog-grid > .tp-blog-item:not(.tp-blog-item--featured) .card-title{
    font-size: clamp(0.99rem, 0.96vw, 1.2rem);
    line-height: 1.22;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
}

.tp-blog-section .card{
  overflow: hidden;
  transition: none !important;
}

.tp-blog-section .card:hover{
  transform: none !important;
  background: #ffffff !important;
  border-color: rgba(15,23,42,0.08) !important;
  box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
}

/* vnitřní padding – “air” */
.tp-blog-section .card-body{
  padding: 1.6rem 1.6rem 1.45rem;
}

/* Obrázek: sjednotit a udělat z něj hero thumbnail */
.tp-blog-section .blog-post-image-small{
  display:block;
  width:100%;
  height: 190px;              /* konzistentní výška */
  object-fit: cover;
  border-radius: 14px !important;

  border: 1px solid rgba(15,23,42,0.08);
  box-shadow: 0 10px 22px rgba(15,23,42,0.08);

  transition: transform .18s ease, box-shadow .18s ease;
}

.tp-blog-section .tp-blog-item.tp-blog-item--featured .blog-post-image-small{
  height: auto;
  aspect-ratio: 1 / 0.975;
  object-fit: cover;
}

.tp-blog-section .tp-blog-item:not(.tp-blog-item--featured) .blog-post-image-small{
  height: 180px;
}

.blog-post-image-popular{
  width: 3rem;
  height: 3rem;
  object-fit: cover;
}

.tp-blog-section .card:hover .blog-post-image-small{
  transform: none !important;
  box-shadow: 0 10px 22px rgba(15,23,42,0.08) !important;
}

/* Titulek – víc “SaaS headline” */
.tp-blog-section .card-title,
.tp-blog-section .card-title.h5{
  font-weight: 800;
  letter-spacing: -0.015em;
  line-height: 1.25;
  color:#0f172a;
  margin-top: .15rem;
}

.tp-blog-section .tp-blog-item:not(.tp-blog-item--featured) .card-title,
.tp-blog-section .tp-blog-item:not(.tp-blog-item--featured) .card-title.h5{
  font-weight: 500;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis;
  min-height: calc(1.24em * 2);
}

/* Hover titulku */
.tp-blog-section a.text-decoration-none:hover .card-title{
  color:#029cf6;
}

/* Perex – klidný, čitelný */
.tp-blog-section .text-muted{
  color: rgba(15,23,42,0.62) !important;
  font-size: 0.95rem;
  line-height: 1.65;
  margin-top: .35rem;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.tp-blog-section .tp-blog-item.tp-blog-item--featured .text-muted{
  -webkit-line-clamp: 6;
}

.tp-blog-section .tp-blog-item:not(.tp-blog-item--featured) .text-muted{
  display: none;
}

.tp-blog-section .tp-blog-item:not(.tp-blog-item--featured) .card-body{
  padding: 1.1rem 1.1rem 1rem;
}

/* Focus – přístupnost */
.tp-blog-section a:focus-visible{
  outline: 3px solid rgba(2,156,246,0.35);
  outline-offset: 4px;
  border-radius: 12px;
}

/* Jemnější spacing na mobilu */
@media (max-width: 768px){
  .tp-blog-section{ padding: 4.2rem 0; }
  .tp-blog-section .card-body{ padding: 1.35rem 1.35rem 1.2rem; }
  .tp-blog-section .blog-post-image-small{ height: 170px; }
  .tp-blog-section .tp-blog-item.tp-blog-item--featured .blog-post-image-small{ height: 210px; }
}


/* =========================================================
   TP BLOG SECTION – DARK (SaaS clean)
   ========================================================= */

[data-theme-style="dark"] .tp-blog-section::before{
  background:
    radial-gradient(120% 120% at 50% 0%, rgba(255,255,255,0.06), transparent 55%),
    radial-gradient(80% 120% at 0% 50%, rgba(0,0,0,0.75), transparent 55%),
    radial-gradient(80% 120% at 100% 50%, rgba(0,0,0,0.75), transparent 55%);
  opacity:.9;
}

[data-theme-style="dark"] .tp-blog-section h2{
  color: rgba(235,240,245,0.92);
}

[data-theme-style="dark"] .tp-blog-section .card{
  background: rgba(11,15,20,0.82) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;

  box-shadow:
    0 24px 70px rgba(0,0,0,0.75),
    0 0 0 1px rgba(255,255,255,0.04) inset;
}

[data-theme-style="dark"] .tp-blog-section .card:hover{
  background: rgba(11,15,20,0.82) !important;
  border-color: rgba(255,255,255,0.08) !important;
  box-shadow:
    0 24px 70px rgba(0,0,0,0.75),
    0 0 0 1px rgba(255,255,255,0.04) inset;
}

[data-theme-style="dark"] .tp-blog-section .card-title,
[data-theme-style="dark"] .tp-blog-section .card-title.h5{
  color: rgba(235,240,245,0.92);
}

[data-theme-style="dark"] .tp-blog-section a.text-decoration-none:hover .card-title{
  color: #ffffff;
}

[data-theme-style="dark"] .tp-blog-section .text-muted{
  color: rgba(235,240,245,0.62) !important;
}

[data-theme-style="dark"] .tp-blog-section .blog-post-image-small{
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 16px 44px rgba(0,0,0,0.60);
}

[data-theme-style="dark"] .tp-blog-section .card:hover .blog-post-image-small{
  box-shadow: 0 16px 44px rgba(0,0,0,0.60) !important;
}





/* =========================================================
   Transfer+ AUTH (Register / Login)
   Clean, update-safe, Light + Dark (Altum theme aware)
   ========================================================= */

/* ---------------------------------------------------------
   Base wrapper
   --------------------------------------------------------- */

.tp-auth-container {
  max-width: 1200px;
}

/* ---------------------------------------------------------
   Layout
   --------------------------------------------------------- */

.tp-auth-layout {
  padding: 0;
}

.tp-auth-left,
.tp-auth-right {
  padding: 1.5rem 1rem;
}

@media (min-width: 992px) {
  .tp-auth-left,
  .tp-auth-right {
    display: flex;
  }

  .tp-auth-left {
    padding-right: 40px;
  }

  .tp-auth-right {
    padding-left: 40px;
  }
}

/* ---------------------------------------------------------
   Inner widths
   --------------------------------------------------------- */

.tp-auth-left-inner {
  width: 500px;
  max-width: 550px;
  margin: 0 auto;
}

.tp-auth-right-inner {
  max-width: 550px;
  margin: 0 auto;
}

@media (max-width: 575.98px) {
  .tp-auth-left-inner {
  width:100%;
}
}

/* ---------------------------------------------------------
   Form card (LEFT)
   --------------------------------------------------------- */

.tp-auth-card {
  border-radius: 22px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 22px 70px rgba(2, 6, 23, 0.10);
}

/* ---------------------------------------------------------
   Right side typography
   --------------------------------------------------------- */

.tp-auth-kicker {
  display: inline-flex;
  align-items: center;
  padding: .44rem .76rem;
  margin-bottom: 1rem;

  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .02em;

  color: rgba(15, 23, 42, 0.72);
  background: rgba(2, 132, 199, 0.06);
  border: 1px solid rgba(15, 23, 42, 0.10);
  border-radius: 999px;
}

.tp-auth-title {
  margin: 0 0 .65rem;

  font-size: 2.05rem;
  line-height: 1.12;
  letter-spacing: -0.02em;
  font-weight: 800;

  color: rgba(2, 6, 23, 0.96);
}

.tp-auth-lead {
  margin: 0 0 1.25rem;

  font-size: 1.02rem;
  line-height: 1.6;

  color: rgba(15, 23, 42, 0.70);
}

/* ---------------------------------------------------------
   Benefits grid
   --------------------------------------------------------- */

.tp-auth-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: .9rem;
  margin-bottom: 1.25rem;
}

@media (min-width: 1200px) {
  .tp-auth-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ---------------------------------------------------------
   Auth UI preview image
   --------------------------------------------------------- */

.tp-auth-ui-preview {
  margin: 1.25rem 0 0.5rem;
  text-align: center;
}

.tp-auth-ui-preview img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;


}

/* Mobile fine-tuning */
@media (max-width: 575.98px) {
  .tp-auth-ui-preview {
    margin: 1rem 0;
  }

}

/* ---------------------------------------------------------
   Benefit card
   --------------------------------------------------------- */

.tp-auth-feature {
  display: flex;
  gap: .85rem;

  padding: 1.05rem;
  border-radius: 18px;

  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 14px 34px rgba(2, 6, 23, 0.06);
}

.tp-auth-ico {
  width: 40px;
  height: 40px;
  flex: 0 0 40px;

  display: grid;
  place-items: center;

  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.10);

  background:
    radial-gradient(circle at 30% 30%, rgba(76, 201, 255, 0.22), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(255, 140, 66, 0.18), transparent 60%),
    rgba(255, 255, 255, 0.85);
}

.tp-auth-ftitle {
  margin: 0 0 .15rem;

  font-weight: 800;
  line-height: 1.25;

  color: rgba(2, 6, 23, 0.92);
}

.tp-auth-ftext {
  margin: 0;

  font-size: .95rem;
  line-height: 1.45;

  color: rgba(15, 23, 42, 0.68);
}

/* ---------------------------------------------------------
   Proof line
   --------------------------------------------------------- */

.tp-auth-proof {
  margin-top: .25rem;
  padding-top: .9rem;

  font-size: .95rem;
  line-height: 1.5;

  color: rgba(15, 23, 42, 0.62);
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

/* ---------------------------------------------------------
   Mobile tweaks
   --------------------------------------------------------- */

@media (max-width: 991.98px) {
  .tp-auth-layout {
    padding: 0;
  }

  .tp-auth-left,
  .tp-auth-right {
    padding: 1.25rem 1rem;
  }

  .tp-auth-title {
    font-size: 1.7rem;
  }

  .tp-auth-right-inner {
    padding: 0 1.25rem;
  }
}

/* =========================================================
   DARK MODE 
   Uses existing: [data-theme-style="dark"]
   ========================================================= */

/* Right side text */
[data-theme-style="dark"] .tp-auth-kicker {
  color: rgba(200, 225, 255, 0.92);
  background: rgba(76, 201, 255, 0.10);
  border-color: rgba(76, 201, 255, 0.22);
}

[data-theme-style="dark"] .tp-auth-title {
  color: rgba(255, 255, 255, 0.96);
}

[data-theme-style="dark"] .tp-auth-lead {
  color: rgba(220, 230, 255, 0.78);
}

/* Benefits in dark */
[data-theme-style="dark"] .tp-auth-feature {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.10);
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
}

[data-theme-style="dark"] .tp-auth-ftitle {
  color: rgba(255, 255, 255, 0.92);
}

[data-theme-style="dark"] .tp-auth-ftext {
  color: rgba(220, 230, 255, 0.72);
}

[data-theme-style="dark"] .tp-auth-ico {
  border-color: rgba(255, 255, 255, 0.10);
  background:
    radial-gradient(circle at 30% 30%, rgba(76, 201, 255, 0.22), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(255, 140, 66, 0.18), transparent 60%),
    rgba(255, 255, 255, 0.06);
}

/* Proof line */
[data-theme-style="dark"] .tp-auth-proof {
  border-top-color: rgba(255, 255, 255, 0.14);
  color: rgba(220, 230, 255, 0.65);
}

/* Keep form card white */
[data-theme-style="dark"] .tp-auth-card {
  border-color: rgba(15, 23, 42, 0.10);
  box-shadow: 0 40px 140px rgba(0, 0, 0, 0.45);
}


/* ============================================
   Transfer+ – Report / Info button (fixed)
   ============================================ */

#info.link-info{
  position: fixed;
  left: 1.25rem;
  bottom: 1.25rem;
  z-index: 90;

  display: flex;
  align-items: center;
  justify-content: center;
}

/* samotné tlačítko */
#info.link-info a{
  width: 42px;
  height: 42px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  border-radius: 999px;

  background: rgba(255, 133, 3, 0.12); /* jemná oranžová = alert */
  border: 1px solid rgba(255, 133, 3, 0.35);

  color: var(--tp-orange);
  text-decoration: none !important;

  box-shadow: 0 0px 12px rgb(71 71 71 / 25%), 0 0 0 1px rgba(255, 255, 255, 0.55) inset;

  transition: none;
}

/* ikonka */
#info.link-info svg{
  font-size: 0.85rem;
  color: var(--tp-orange);
}

/* hover / focus – keep static, no lift */
#info.link-info a:hover,
#info.link-info a:focus{
  background: rgba(255, 133, 3, 0.12);
  transform: none;
  box-shadow: 0 0px 12px rgb(71 71 71 / 25%), 0 0 0 1px rgba(255, 255, 255, 0.55) inset;
}

/* accessibility */
#info.link-info a:focus-visible{
  outline: none;
  box-shadow:
    0 0 0 3px rgba(255,133,3,0.35),
    0 14px 32px rgba(255,133,3,0.35);
}

/* ============================================
   DARK MODE
   ============================================ */

[data-theme-style="dark"] #info.link-info a{
  background: rgba(255, 133, 3, 0.16);
  border: 1px solid rgba(255, 133, 3, 0.45);

  box-shadow:
    0 14px 36px rgba(0,0,0,0.65),
    0 0 14px rgba(255,133,3,0.35);
}

[data-theme-style="dark"] #info.link-info a:hover{
  background: rgba(255, 133, 3, 0.16);
  box-shadow:
    0 14px 36px rgba(0,0,0,0.65),
    0 0 14px rgba(255,133,3,0.35);
}


/* =========================================================
   TP NOTIFICATIONS – pás jen v rámci .container + fade do ztracena
   (NE fullscreen, NE nové věci)
   Scope: ONLY .tp-notifications
   ========================================================= */

.tp-notifications{
  padding: 13rem 0 10rem 0;
  position: relative;
}

/* Nadpis + popisek */
.tp-notifications h2{
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: .6rem;
}
.tp-notifications p.text-muted{
  font-size: 1.2rem;
    margin: 0 auto;
}

.tp-notifications .container{
  position: relative;
  overflow: hidden;             /* KLÍČ: nic mimo container nebude vidět */
  padding-bottom: 10px;         /* aby se nestín neřezal dole */
}

/* gradient do ztracena na krajích pásu */
.tp-notifications .container::before,
.tp-notifications .container::after{
  content:"";
  position:absolute;
  top: 0;
  bottom: 0;
  width: 90px;
  pointer-events:none;
  z-index: 5;
}
.tp-notifications .container::before{
  left: 0;
  background: linear-gradient(to right, #f6f8f9 0%, rgba(247, 249, 251, 0) 100%);
}
.tp-notifications .container::after{
  right: 0;
  background: linear-gradient(to left, #f6f8f9 0%, rgba(247,249,251,0) 100%);
}

[data-theme-style="dark"] .tp-notifications .container::before{
  left: 0;
  background: linear-gradient(to right, #040506 0%, rgba(247, 249, 251, 0) 100%);
}
[data-theme-style="dark"] .tp-notifications .container::after{
  right: 0;
  background: linear-gradient(to left, #040506 0%, rgba(247,249,251,0) 100%);
}

/* Bootstrap helpery pryč (mx-n4 dělá "full width" pocit) */
.tp-notifications .row.mx-n4{
  margin-left: 0 !important;
  margin-right: 0 !important;

  /* pás */
  display: inline-flex;         /* DŮLEŽITÉ: nebude to "na celou šířku" */
  flex-wrap: nowrap;
  align-items: center;
  gap: 50px !important;

  width: max-content;           /* šířka podle obsahu (marquee) */
  overflow: visible !important;
  height: 170px;

  /* zarovnání start, ať to necentruje "divně" */
  justify-content: flex-start !important;
}

/* col-6 / col-lg-4 zrušíme na auto-box */
.tp-notifications .row.mx-n4 > [class*="col-"]{
  padding: 0 !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
  overflow: visible !important;
}

/* zruší ořezy textu */
.tp-notifications .text-truncate{
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: normal !important;
}

/* BOX – jednotná velikost */
.tp-notifications .bg-white.index-highly-rounded{
  --tp-box-w: 148px;
  --tp-box-h: 92px;

  width: var(--tp-box-w) !important;
  min-width: var(--tp-box-w) !important;
  height: var(--tp-box-h) !important;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  padding: 14px 14px 12px !important;

  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,250,255,.92)) !important;
  border-radius: 22px !important;

  box-shadow:
    0 16px 38px rgba(6,16,34,.14),
    0 8px 18px rgba(6,16,34,.10),
    inset 0 1px 0 rgba(255,255,255,.9) !important;

  overflow: visible !important;
}

[data-theme-style="dark"] .tp-notifications .bg-white.index-highly-rounded{
  background: linear-gradient(180deg, hsl(218,23%,21%), rgb(0 0 0 / 92%)) !important;
  border-radius: 18px !important;

  box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

/* jednotná výška pro ikonu */
.tp-notifications .bg-white.index-highly-rounded > div:first-child{
  height: 34px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.tp-notifications .bg-white.index-highly-rounded i{
  font-size: 22px !important;
  line-height: 1 !important;
  display:inline-block;
}

/* label – bez ořezu, stejný */
.tp-notifications .bg-white.index-highly-rounded .h6{
  margin: 8px 0 0 !important;
  font-weight: 800 !important;
  font-size: 12.5px !important;
  line-height: 1.15 !important;
  color: rgba(11,18,32,.86) !important;

  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: clip !important;
}

/* label – bez ořezu, stejný */
[data-theme-style="dark"] .tp-notifications .bg-white.index-highly-rounded .h6{
  color: #dae8f2 !important;
}

/* vypnout jakékoliv zoom/hover animace (nejsou to odkazy) */
.tp-notifications .icon-zoom-animation,
.tp-notifications .icon-zoom-animation *{
  transition: none !important;
  transform: none !important;
}

/* RESPONSIVE */
@media (max-width: 991.98px){
  .tp-notifications{ padding: 13rem 0 10rem }
  .tp-notifications .container::before,
  .tp-notifications .container::after{ width: 70px; }

  .tp-notifications .bg-white.index-highly-rounded{
    --tp-box-w: 132px;
    --tp-box-h: 86px;
    border-radius: 16px !important;
  }
  .tp-notifications .bg-white.index-highly-rounded i{ font-size: 21px !important; }
  .tp-notifications .bg-white.index-highly-rounded .h6{ font-size: 12px !important; }
}

@media (max-width: 575.98px){

  /* spacing sekce */
  .tp-notifications{
    padding: 15rem 0 8rem;
  }

  .tp-notifications h2,
  .tp-notifications .text-muted{
  padding: 0 0.4rem;
  }

  /* samotný běžící pás */
  .tp-notifications .row.mx-n4{
    gap: 14px;
  }

  .tp-notifications .container::before,
  .tp-notifications .container::after{
    display: none !important;
  }

  /* boxy – stejné, větší, čitelné */
  .tp-notifications .bg-white.index-highly-rounded{
    --tp-box-w: 120px;
    --tp-box-h: 82px;
    padding: 12px 12px 10px !important;
  }

  /* ikona */
  .tp-notifications .bg-white.index-highly-rounded > div:first-child{
    height: 32px;
  }

  .tp-notifications .bg-white.index-highly-rounded i{
    font-size: 20px !important;
  }

  /* text */
  .tp-notifications .bg-white.index-highly-rounded .h6{
    font-size: 11.5px !important;
    line-height: 1.15;
  }
}

/* =========================================================
   TP TESTIMONIALS
   Scope: .tp-testimonials only
   ========================================================= */

.tp-testimonials{
  position: relative;
  overflow: visible;
  border-top: 1px solid rgba(29, 84, 180, .86);
  box-shadow: var(--tp-dashboard-card-shadow);
  background:
    radial-gradient(120% 85% at 50% 0%, rgba(59, 130, 246, .2) 0%, rgba(59, 130, 246, 0) 60%),
    linear-gradient(155deg, #061a3b 0%, #0a2859 36%, #133f83 72%, #1c5aa5 100%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #0a2859;
}

[data-theme-style="dark"] .tp-testimonials{
  position: relative;
  overflow: visible;
  border-top: 1px solid rgba(62, 122, 221, .78);
  box-shadow: var(--tp-dashboard-card-shadow);
  background:
    radial-gradient(130% 90% at 50% 0%, rgba(56, 189, 248, .12) 0%, rgba(56, 189, 248, 0) 60%),
    linear-gradient(155deg, #050d1f 0%, #0a1d42 42%, #12366f 78%, #194b8d 100%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #091a38;
}

/* smajlík vpravo dole */
.tp-testimonials::after{
  content: "";
  position: absolute;
  bottom: 9px;
  right: -41px;
  width: 250px;
  height: 250px;

  background-image: url("https://transferplus.s3.eu-central-1.amazonaws.com/assets/images/icon/testimonials_2.webp");
  background-size: contain;
  background-repeat: no-repeat;
  filter: drop-shadow(0 18px 28px rgba(8, 26, 56, .42));

  z-index: 2;
}


/* inner rounded area */
.tp-testimonials .bg-primary-100{
  position: relative;
  background: transparent !important;
  z-index: 4;
}

/* -----------------------------------------
   HEADLINE
------------------------------------------ */
.tp-testimonials h2{
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #f8fbff;
  text-shadow: 0 2px 16px rgba(8, 26, 56, .25);
}

[data-theme-style="dark"] .tp-testimonials h2{
  font-weight: 800;
  letter-spacing: -0.02em;
}

.tp-testimonials h2 svg{
  color: #d9ecff !important;
  margin-left: .35rem;
  filter: drop-shadow(0 2px 8px rgba(56, 189, 248, .28));
}

[data-theme-style="dark"] .tp-testimonials h2 svg{
  margin-left: .35rem;
}

/* glass cards */
.tp-testimonials .card{
  background: linear-gradient(180deg, rgba(243, 249, 255, .98), rgba(234, 244, 255, .95));
  border: 1px solid rgba(197, 226, 250, .55);
  border-radius: 22px;
  box-shadow: 0 16px 34px rgba(6, 26, 58, .16);
  height: 100%;
}

/* glass cards */
[data-theme-style="dark"] .tp-testimonials .card{
  background: linear-gradient(165deg, rgba(9, 28, 63, .96), rgba(14, 43, 90, .95));
  border: 1px solid rgba(97, 156, 230, .36) !important;
  border-radius: 22px;
  box-shadow: 0 18px 36px rgba(2, 8, 24, .52);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* -----------------------------------------
   CARD BODY
------------------------------------------ */
.tp-testimonials .card-body{
  padding: 2.8rem 2.6rem 3rem;
  text-align: left;
}


/* -----------------------------------------
   AVATAR
------------------------------------------ */
.tp-testimonials .index-testimonial-avatar{
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid #ffffff !important;
  box-shadow: 0 10px 24px rgba(7, 24, 51, .2);
  transform: translateY(-80%);
  left: 55%;
}

[data-theme-style="dark"] .tp-testimonials .index-testimonial-avatar{
  border: 4px solid #112c56 !important;
  box-shadow: 0 10px 28px rgba(2, 10, 22, .62);
}


/* -----------------------------------------
   AUTHOR
------------------------------------------ */
.tp-testimonials .blockquote-footer{
  margin-top: 1.6rem;
  font-size: 0.95rem;
  line-height: 1.4;
}

.tp-testimonials .blockquote-footer .font-weight-bold{
  color: #0f274a;
}

[data-theme-style="dark"] .tp-testimonials .blockquote-footer .font-weight-bold{
  color: #e2eeff !important;
}

.tp-testimonials .index-testimonial-comment{
  font-size: 0.85rem;
  color: rgba(15, 39, 74, .65) !important;
}

[data-theme-style="dark"] .tp-testimonials .index-testimonial-comment{
  font-size: 0.85rem;
  color: rgba(212, 229, 255, .72) !important;
}

/* vnitřní spacing */
.tp-testimonials .card-body{
  padding: 24px;
}

/* -----------------------------------------
   QUOTE TEXT
------------------------------------------ */
.tp-testimonials p{
  margin-top: 1.6rem;
  line-height: 1.65;
  color: rgba(14, 37, 72, .9) !important;
}



[data-theme-style="dark"] .tp-testimonials p{
  color: #e6f0ff !important;
}

/* quote marks */
.tp-testimonials p .h5{
  color: #4fb6ff !important;
}

[data-theme-style="dark"] .tp-testimonials p .h5{
  color: #9fd6ff !important;
}


/* -----------------------------------------
   RESPONSIVE
------------------------------------------ */
@media (max-width: 991.98px){
  .tp-testimonials .card-body{
    padding: 2.4rem 2.2rem 2.6rem;
  }

  .tp-testimonials::after{
  content: "";
  position: absolute;
    bottom: 9px;
    right: -41px;
    width: 250px;
    height: 250px;
  z-index: 10;
}
  .tp-testimonials h2{
    font-size: 2rem;
    padding-top: 2rem;
  }
}

@media (max-width: 575.98px){
  .tp-testimonials .bg-primary-100{
    padding: 3.5rem 0;
    border-radius: 28px;
  }

  .tp-testimonials::after{
  content: "";
  position: absolute;
    bottom: 9px;
    right: -41px;
    width: 250px;
    height: 250px;
  z-index: 10;
}

  .tp-testimonials h2{
    font-size: 2rem;
    padding-top: 2rem;
  }
}


/* =========================================================
   TP PRICES – clean, contrast, update-safe
   Scope: .tp-prices + .tp-prices-plan
   ========================================================= */

/* HOMEPAGE spacing – beze změny */
.tp-prices{
  position: relative;
  overflow: hidden;
  padding: 13rem 0 10rem;
}

/* PLANS PAGE – bez homepage paddingu */
.tp-prices-plan{
  position: relative;
  overflow: visible;
  padding: 0.8rem 0;
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}

/* v HTML není container – uděláme ho přes #plans */
:is(.tp-prices, .tp-prices-plan) #plans{
  max-width: 1140px;
  margin: 0 auto;
  
}

/* Headline */
:is(.tp-prices, .tp-prices-plan) h2{
  font-weight: 850;
  letter-spacing: -0.02em;
}

:is(.tp-prices, .tp-prices-plan) .text-center > .text-muted{
  margin: .55rem auto 0;
  line-height: 1.6;
}

/* ---------------------------------------------------------
   Switches (měsíčně / půlročně / ročně) – žádné divočiny
   --------------------------------------------------------- */
:is(.tp-prices, .tp-prices-plan) .btn-group-custom{
  display: inline-flex;
  gap: .35rem;
  padding: .36rem;
  border-radius: 14px;
  background: #f2f6fb;
  border: 1px solid #d8e3ef;
  box-shadow: none;
}

:is(.tp-prices, .tp-prices-plan) .btn-group-custom .btn{
  border-radius: 10px !important;
  padding: .55rem 1rem !important;
  font-weight: 700;
  color: #4a5b70;
  background: transparent;
  border: 1px solid transparent;
  box-shadow: none;
  transition: border-color .16s ease, background .16s ease, color .16s ease;
}

:is(.tp-prices, .tp-prices-plan) .btn-group-custom .btn:hover{
  transform: none;
  border-color: #b8cbe0;
  background: #ffffff;
  color: #1c2b3d;
}

:is(.tp-prices, .tp-prices-plan) .btn-group-custom .btn.active{
  background: #0f6db0;
  border-color: #0f6db0;
  color: #ffffff;
  box-shadow:
    0 8px 20px rgba(15,109,176,0.28),
    0 0 0 1px rgba(255,255,255,0.14) inset;
}

/* ---------------------------------------------------------
   Cards
   --------------------------------------------------------- */
:is(.tp-prices, .tp-prices-plan) .pricing-card{
  border-radius: 22px !important;
  border: 1px solid #dfe7f1;
  box-shadow: 0 8px 22px rgba(15,23,42,0.05) !important;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .pricing-card{
  border-radius: 22px !important;
  border: 1px solid #223247;
  box-shadow: 0 10px 24px rgba(0,0,0,0.26) !important;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card:hover{
  transform: translateY(-2px);
  border-color: #cdd9e7;
  box-shadow:
    0 14px 34px rgba(2,6,23,0.08),
    0 0 0 1px rgba(255,255,255,0.72) inset !important;
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .pricing-card:hover{
  transform: translateY(-2px);
  border-color: #31527c;
  box-shadow:
    0 18px 38px rgba(0,0,0,0.32),
    0 0 0 1px rgba(255,255,255,0.08) inset !important;
}

/* Body spacing */
:is(.tp-prices, .tp-prices-plan) .pricing-card .card-body{
  padding: 1.55rem 1.55rem 1.15rem !important;
}

/* Plan title bar */
:is(.tp-prices, .tp-prices-plan) .pricing-card .bg-gray-100{
  background: rgba(15,165,235,0.06) !important;
  border: 1px solid rgba(15,165,235,0.14) !important;
  border-radius: 999px !important;
}

/* Pricing typography */
:is(.tp-prices, .tp-prices-plan) .pricing-card .h1{
  font-weight: 700;
  letter-spacing: -0.03em;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card .mb-4.text-center .text-muted{
  font-size: .98rem;
  line-height: 1.6;
}

/* Features list rows */
:is(.tp-prices, .tp-prices-plan) .pricing-card .d-flex.justify-content-between.align-items-center.my-3{
  padding: .35rem 0;
  border-bottom: 1px solid rgba(15,23,42,0.06);
  margin: 0 !important;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card .d-flex.justify-content-between.align-items-center.my-3:last-child{
  border-bottom: 0;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card .d-flex.justify-content-between.align-items-center.my-3 > div{
  font-size: .90rem;
  line-height: 1.7;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card .d-flex.justify-content-between.align-items-center.my-3 > div.text-muted{
  color: rgba(11,18,32,.52) !important;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card svg{
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
  opacity: .95;
} 

/* CTA */
:is(.tp-prices, .tp-prices-plan) .pricing-card .p-3.pb-4{
  padding: 1rem 1.35rem 1.35rem !important;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card .p-3.pb-4 .btn{
  border-radius: 999px !important;
  padding: .9rem 1.05rem !important;
  font-weight: 850;
  letter-spacing: .01em;
  box-shadow: 0 18px 42px rgba(2,6,23,0.10);
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-primary-btn{
  --tp-pricing-accent: #20a0ea;
  width: 100% !important;
  border-color: rgba(18, 52, 124, .38) !important;
  background: linear-gradient(180deg, #39b4f3 0%, #20a0ea 52%, #1491dd 100%) !important;
  color: #ffffff !important;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-primary-btn:hover,
:is(.tp-prices, .tp-prices-plan) .tp-pricing-primary-btn:focus-visible{
  border-color: rgba(18, 52, 124, .58) !important;
  background: linear-gradient(180deg, #1a59c1 0%, #15489d 52%, #123d83 100%) !important;
  color: #ffffff !important;
}

@supports (background: color-mix(in srgb, #000 50%, #fff)) {
  :is(.tp-prices, .tp-prices-plan) .tp-pricing-primary-btn{
    border-color: color-mix(in srgb, var(--tp-pricing-accent) 55%, #12347c) !important;
    background: linear-gradient(
      180deg,
      color-mix(in srgb, var(--tp-pricing-accent) 76%, #ffffff) 0%,
      var(--tp-pricing-accent) 52%,
      color-mix(in srgb, var(--tp-pricing-accent) 82%, #10253f) 100%
    ) !important;
  }

  :is(.tp-prices, .tp-prices-plan) .tp-pricing-primary-btn:hover,
  :is(.tp-prices, .tp-prices-plan) .tp-pricing-primary-btn:focus-visible{
    border-color: color-mix(in srgb, var(--tp-pricing-accent) 45%, #0b1f4d) !important;
    background: linear-gradient(
      180deg,
      color-mix(in srgb, var(--tp-pricing-accent) 62%, #123d83) 0%,
      color-mix(in srgb, var(--tp-pricing-accent) 48%, #123d83) 52%,
      color-mix(in srgb, var(--tp-pricing-accent) 34%, #0b1f4d) 100%
    ) !important;
  }
}


/* Tag "Nejvýhodnější" */
:is(.tp-prices, .tp-prices-plan) .pricing-tag{
  z-index: 3;
  padding: .35rem .99rem 0.45rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .88rem;
  letter-spacing: .02em;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card .pricing-tag{
  top: 0 !important;
  left: 50% !important;
  right: auto !important;
  transform: translate(-50%, -50%) !important;
  max-width: calc(100% - 18px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  z-index: 6;
}

:is(.tp-prices, .tp-prices-plan) .pricing-card .pricing-tag + .card-body{
  padding-top: 2.25rem !important;
}


/* ---------------------------------------------------------
   Responsive
   --------------------------------------------------------- */
@media (max-width: 991.98px){
  .tp-prices{ padding: 52px 15px 70px; }

  :is(.tp-prices, .tp-prices-plan) #plans{
    border-radius: 28px;
    padding: 46px 16px 44px !important;
  }

  :is(.tp-prices, .tp-prices-plan) .btn-group-custom{
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
  }

  :is(.tp-prices, .tp-prices-plan) .pricing-card .card-body{
    padding: 1.35rem 1.25rem 1.05rem !important;
  }
}

@media (max-width: 575.98px){
  :is(.tp-prices, .tp-prices-plan) #plans{
    border-radius: 22px;
    padding: 40px 12px 40px !important;
  }


  :is(.tp-prices, .tp-prices-plan) .pricing-card .d-flex.justify-content-between.align-items-center.my-3 > div{
    font-size: .92rem;
  }

  :is(.tp-prices, .tp-prices-plan) .pricing-card .p-3.pb-4{
    padding: .9rem 1.1rem 1.2rem !important;
  }
}

/* ---------------------------------------------------------
   Dark mode
   --------------------------------------------------------- */

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) h2{
  color: rgba(235,240,245,0.94);
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .btn-group-custom{
  background: #111a27;
  border-color: #23364d;
  box-shadow: none;
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .btn-group-custom .btn{
  color: rgba(227,235,244,0.78);
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .btn-group-custom .btn:hover{
  transform: none;
  border-color: #3d5774;
  background: rgba(255,255,255,0.04);
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .btn-group-custom .btn.active{
    background: #1d7fc3 !important;
    border-color: #1d7fc3;
    color: #ffffff;
    box-shadow: 0 8px 18px rgba(18, 123, 196, 0.34);
}


[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .pricing-card .h1{
  color: rgba(235,240,245,0.95);
}


[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .pricing-card .d-flex.justify-content-between.align-items-center.my-3{
  border-bottom-color: rgba(255,255,255,0.07);
}


[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .pricing-card .d-flex.justify-content-between.align-items-center.my-3 > div.text-muted{
  color: rgba(235,240,245,0.52) !important;
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .pricing-card .bg-gray-100{
  background: rgb(4 5 6 / 47%) !important;
  border-color: rgba(255,255,255,0.10) !important;
}

/* ---------------------------------------------------------
   Pricing layout v2: 3 hlavni sloupce + free pod nimi
   --------------------------------------------------------- */
:is(.tp-prices, .tp-prices-plan) .tp-pricing-layout{
  width: 100%;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-grid{
  margin-left: -0.4rem;
  margin-right: -0.4rem;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-grid > [class*="col-"]{
  padding-left: 0.4rem;
  padding-right: 0.4rem;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-main-col{
  display: flex;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-main-col .pricing-card{
  width: 100%;
  overflow: visible;
  border-width: 1px !important;
  background: #ffffff;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-main-col:nth-of-type(2) .pricing-card{
  box-shadow:
    0 16px 34px rgba(15, 23, 42, 0.12),
    0 0 0 1px rgba(255, 255, 255, 0.6) inset !important;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-row{
  margin-top: 1rem;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-strip{
  --tp-pricing-free-accent: #1f8bd6;
  display: grid;
  grid-template-columns: minmax(280px, 1.15fr) minmax(320px, 1.3fr) minmax(210px, .8fr);
  align-items: center;
  gap: 1.2rem 1.6rem;
  border: 1px solid #dfe7f1;
  border-radius: 22px;
  background: #ffffff;
  box-shadow: 0 8px 22px rgba(15,23,42,0.05);
  min-height: 170px;
  padding: 1.35rem 1.5rem 1.35rem 1.55rem;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-tag{
  top: 0 !important;
  right: 10px !important;
  left: auto !important;
  transform: translateY(-50%) !important;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-main{
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(320px, 1fr);
  gap: 1rem 1.5rem;
  align-items: start;
  grid-column: 1 / span 2;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-main.tp-pricing-free-main-simple{
  align-items: center;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-summary{
  min-width: 0;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-name{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.2rem;
  padding: .5rem 1.15rem;
  border-radius: 999px;
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: #4b5463;
  background: rgba(15, 165, 235, 0.06);
  border: 1px solid rgba(15, 165, 235, 0.14);
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-price{
  margin-top: .55rem;
  font-size: 1.86rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: #13253b;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-description{
  margin-top: .6rem;
  line-height: 1.55;
  max-width: 34ch;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-metrics{
  display: grid;
  gap: .55rem;
  padding: .1rem 0;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-metrics > div{
  font-size: .98rem;
  line-height: 1.5;
  color: #1f334b;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-metrics > div strong{
  font-weight: 750;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-cta{
  grid-column: 3;
  padding-left: 1.1rem;
  border-left: 1px solid rgba(15,23,42,0.09);
  min-height: 100%;
  display: flex;
  align-items: center;
}

:is(.tp-prices, .tp-prices-plan) .tp-pricing-free-cta .btn{
  width: 100%;
  padding: .95rem 1.05rem !important;
  border-radius: 999px !important;
  font-weight: 850;
  letter-spacing: .01em;
  box-shadow: 0 18px 42px rgba(2,6,23,0.10);
}

@media (max-width: 1199.98px){
  :is(.tp-prices, .tp-prices-plan) .tp-pricing-main-col:nth-of-type(2) .pricing-card{
    box-shadow:
      0 12px 26px rgba(15, 23, 42, 0.1),
      0 0 0 1px rgba(255, 255, 255, 0.55) inset !important;
  }

  :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-strip{
    grid-template-columns: 1fr;
    gap: 1rem;
    min-height: 0;
    padding: 1.1rem 1.15rem 1.15rem;
  }

  :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-main{
    grid-template-columns: 1fr;
    grid-column: 1;
    gap: .85rem;
  }

  :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-cta{
    grid-column: 1;
    padding-left: 0;
    border-left: 0;
    border-top: 1px solid rgba(15,23,42,0.09);
    padding-top: 1rem;
  }
}

@media (max-width: 575.98px){
  :is(.tp-prices, .tp-prices-plan) .tp-pricing-grid{
    margin-left: -0.2rem;
    margin-right: -0.2rem;
  }

  :is(.tp-prices, .tp-prices-plan) .tp-pricing-grid > [class*="col-"]{
    padding-left: 0.2rem;
    padding-right: 0.2rem;
  }

  :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-strip{
    padding: .9rem .85rem .95rem;
  }
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .tp-pricing-main-col .pricing-card{
  background: #111b29;
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .tp-pricing-main-col:nth-of-type(2) .pricing-card{
  box-shadow:
    0 16px 32px rgba(0, 0, 0, 0.36),
    0 0 0 1px rgba(255,255,255,0.1) inset !important;
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-strip{
  background: #111f2f;
  border-color: rgba(99, 198, 255, 0.26);
  box-shadow: 0 14px 30px rgba(0,0,0,0.3);
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-name{
  color: rgba(227,235,244,0.84);
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.14);
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-price{
  color: #ebf3ff;
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-metrics > div{
  color: #d6e6f8;
}

[data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-cta{
  border-left-color: rgba(255,255,255,0.1);
}

@media (max-width: 1199.98px){
  [data-theme-style="dark"] :is(.tp-prices, .tp-prices-plan) .tp-pricing-free-cta{
    border-top-color: rgba(255,255,255,0.1);
  }
}

/* =========================================================
   UNIVERSAL SAVE BUTTON – low shadow, subtle, hover orange
   (same interaction as "Vybrat soubory": hover -> press down)
   ========================================================= */

/* cílení jen na submit "Uložit" (bez zásahu do jiných primárek) */
button.btn.btn-block.btn-primary[type="submit"][name="submit"],
.tp-inline-auth-submit{
  position: relative;
  overflow: hidden;

  border-radius: 999px;
  border: 1px solid rgba(15,165,235,0.40) !important;

  padding: .88rem 1.2rem;
  font-weight: 750;
  letter-spacing: .01em;
  font-size: 1.1rem;
  color: rgba(255,255,255,0.96) !important;

  /* default modrá (jemně, bez “materiálu”) */
  background: linear-gradient(180deg, rgb(15 165 235 / 63%) 0%, rgba(15, 165, 235, 0.92) 62%, rgba(0, 130, 205, 0.92) 100%) !important;

  /* ✅ minimální “SaaS” stín */
  box-shadow:
    0 6px 12px rgba(6,16,34,0.14),
    inset 0 1px 0 rgba(255,255,255,0.14);

  transition:
    transform .16s ease,
    box-shadow .16s ease,
    background .16s ease,
    border-color .16s ease,
    filter .16s ease;
}

/* jemný vnitřní sheen – skoro neviditelný */
button.btn.btn-block.btn-primary[type="submit"][name="submit"]::after,
.tp-inline-auth-submit::after{
  content:"";
  position:absolute;
  inset: 2px;
  border-radius: inherit;
  pointer-events:none;

  background: linear-gradient(
    115deg,
    transparent 0%,
    rgba(255,255,255,0.00) 42%,
    rgba(255,255,255,0.22) 50%,
    rgba(255,255,255,0.00) 58%,
    transparent 100%
  );

  opacity: .10;
  transform: translateX(-60%);
  animation: tpSaveSheen2 7.2s ease-in-out infinite;
}
@keyframes tpSaveSheen2{
  0%,100%{ transform: translateX(-60%); }
  50%{ transform: translateX(60%); }
}

/* ✅ HOVER = oranžová + stisk (stejně jako Vybrat soubory) */
button.btn.btn-block.btn-primary[type="submit"][name="submit"]:hover,
.tp-inline-auth-submit:hover{
  transform: translateY(2px);

  border-color: rgba(255,133,3,0.45) !important;

  background: linear-gradient(
    180deg,
    rgba(255,133,3,0.18) 0%,
    rgba(255,133,3,0.95) 62%,
    rgba(230,112,0,0.95) 100%
  ) !important;

  /* stín se zmenší = efekt přitlačení */
  box-shadow:
    0 3px 8px rgba(6,16,34,0.16),
    inset 0 1px 0 rgba(255,255,255,0.12);

  filter: saturate(1.03);
}
button.btn.btn-block.btn-primary[type="submit"][name="submit"]:hover::after,
.tp-inline-auth-submit:hover::after{
  opacity: .14;
}

/* ACTIVE = ještě o chlup víc “pressed” */
button.btn.btn-block.btn-primary[type="submit"][name="submit"]:active,
.tp-inline-auth-submit:active{
  transform: translateY(3px);

  box-shadow:
    0 2px 6px rgba(6,16,34,0.16),
    inset 0 2px 6px rgba(0,0,0,0.18);
}
button.btn.btn-block.btn-primary[type="submit"][name="submit"]:active::after,
.tp-inline-auth-submit:active::after{
  opacity: .08;
  transform: translateX(0);
  animation: none;
}

/* =========================================================
   DARK – stejné chování, jen tmavší stíny a bez “svitu”
   ========================================================= */
[data-theme-style="dark"] button.btn.btn-block.btn-primary[type="submit"][name="submit"],
[data-theme-style="dark"] .tp-inline-auth-submit{
  border-color: rgba(15,165,235,0.28) !important;

  background: linear-gradient(180deg, rgb(15 165 235 / 35%) 0%, rgba(15, 165, 235, 0.78) 62%, rgba(0, 130, 205, 0.82) 100%) !important;

  box-shadow:
    0 7px 14px rgba(0,0,0,0.50),
    inset 0 1px 0 rgba(255,255,255,0.08);
}

[data-theme-style="dark"] button.btn.btn-block.btn-primary[type="submit"][name="submit"]:hover,
[data-theme-style="dark"] .tp-inline-auth-submit:hover{
  border-color: rgba(255,133,3,0.34) !important;

  background:linear-gradient(180deg, rgb(255 133 3 / 51%) 0%, rgba(255, 133, 3, 0.88) 62%, rgba(230, 112, 0, 0.88) 100%) !important;

  box-shadow:
    0 4px 10px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

[data-theme-style="dark"] button.btn.btn-block.btn-primary[type="submit"][name="submit"]:active,
[data-theme-style="dark"] .tp-inline-auth-submit:active{
  box-shadow:
    0 3px 8px rgba(0,0,0,0.55),
    inset 0 2px 6px rgba(0,0,0,0.28);
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  button.btn.btn-block.btn-primary[type="submit"][name="submit"]::after,
  .tp-inline-auth-submit::after{
    animation: none !important;
    transform: none !important;
    opacity: .08;
  }
}



/* -------------------------
   2) COLLAPSE BUTTONS (account preferences)
   .btn-gray-200 + data-toggle="collapse"
   ------------------------- */

.btn.btn-gray-200[data-toggle="collapse"]{
  position: relative;
  overflow: hidden;

  border-radius: 14px;
  border: 1px solid rgba(16,24,40,0.10) !important;

  background: linear-gradient(180deg,
    rgba(245,247,250,0.96) 0%,
    rgba(236,242,248,0.96) 100%
  ) !important;

  color: rgba(11,18,32,0.78) !important;
  font-weight: 720;

  padding: .85rem 1.05rem;

  box-shadow:
    0 4px 10px rgba(6,16,34,0.10),
    inset 0 1px 0 rgba(255,255,255,0.85);

  transition:
    transform .16s ease,
    box-shadow .16s ease,
    border-color .16s ease,
    background .16s ease,
    color .16s ease;
}

/* ikona vlevo */
.btn.btn-gray-200[data-toggle="collapse"] svg{
  color: rgba(11,18,32,0.50) !important;
  transition: color .16s ease, transform .16s ease;
}

/* hover = orange + pressed */
.btn.btn-gray-200[data-toggle="collapse"]:hover{
  transform: translateY(2px);
  border-color: rgba(255,133,3,0.26) !important;

  background: linear-gradient(180deg,
    rgba(255,133,3,0.08) 0%,
    rgba(236,242,248,0.96) 100%
  ) !important;

  box-shadow:
    0 3px 8px rgba(6,16,34,0.12),
    inset 0 1px 0 rgba(255,255,255,0.85);
}

.btn.btn-gray-200[data-toggle="collapse"]:hover svg{
  color: rgba(255,133,3,0.92) !important;
}

/* expanded = opened state (blue accent, no “neon”) */
.btn.btn-gray-200[data-toggle="collapse"][aria-expanded="true"]{
  border-color: rgba(15,165,235,0.38) !important;

  background: linear-gradient(180deg,
    rgba(232,248,255,0.98) 0%,
    rgba(214,242,255,0.92) 100%
  ) !important;

  color: rgba(11,18,32,0.92) !important;

  box-shadow:
    0 6px 14px rgba(6,16,34,0.14),
    inset 0 1px 0 rgba(255,255,255,0.90);
}

.btn.btn-gray-200[data-toggle="collapse"][aria-expanded="true"] svg{
  color: var(--tp-blue-light) !important;
}

/* active click */
.btn.btn-gray-200[data-toggle="collapse"]:active{
  transform: translateY(3px);
  box-shadow:
    0 2px 6px rgba(6,16,34,0.14),
    inset 0 2px 6px rgba(0,0,0,0.08);
}


/* =========================================================
   DARK THEME
   ========================================================= */

[data-theme-style="dark"] .btn.btn-custom{
  border-color: rgba(255,255,255,0.10) !important;

  background: linear-gradient(180deg,
    rgba(255,255,255,0.07) 0%,
    rgba(255,255,255,0.04) 100%
  ) !important;

  color: rgba(220,230,255,0.80) !important;

  box-shadow:
    0 8px 18px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

[data-theme-style="dark"] .btn.btn-custom svg{
  color: rgba(220,230,255,0.62) !important;
}

[data-theme-style="dark"] .btn.btn-custom:hover{
  transform: translateY(2px);
  border-color: rgba(255,133,3,0.28) !important;

  background: linear-gradient(180deg,
    rgba(255,133,3,0.10) 0%,
    rgba(255,255,255,0.05) 100%
  ) !important;

  box-shadow:
    0 6px 14px rgba(0,0,0,0.52),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

[data-theme-style="dark"] .btn.btn-custom:hover svg{
  color: rgba(255,133,3,0.92) !important;
}

[data-theme-style="dark"] .btn.btn-custom.active,
[data-theme-style="dark"] .btn.btn-custom[aria-current="page"]{
  border-color: rgba(15,165,235,0.35) !important;

  background: linear-gradient(180deg,
    rgba(15,165,235,0.18) 0%,
    rgba(255,255,255,0.05) 100%
  ) !important;

  color: rgba(255,255,255,0.92) !important;

  box-shadow:
    0 10px 22px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.07);
}

[data-theme-style="dark"] .btn.btn-custom.active svg,
[data-theme-style="dark"] .btn.btn-custom[aria-current="page"] svg{
  color: var(--tp-blue-light) !important;
}

/* collapse buttons dark */
[data-theme-style="dark"] .btn.btn-gray-200[data-toggle="collapse"]{
  border-color: rgba(255,255,255,0.10) !important;

  background: linear-gradient(180deg,
    rgba(255,255,255,0.06) 0%,
    rgba(255,255,255,0.04) 100%
  ) !important;

  color: rgba(220,230,255,0.78) !important;

  box-shadow:
    0 8px 18px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

[data-theme-style="dark"] .btn.btn-gray-200[data-toggle="collapse"] svg{
  color: rgba(220,230,255,0.60) !important;
}

[data-theme-style="dark"] .btn.btn-gray-200[data-toggle="collapse"]:hover{
  transform: translateY(2px);
  border-color: rgba(255,133,3,0.24) !important;

  background: linear-gradient(180deg,
    rgba(255,133,3,0.10) 0%,
    rgba(255,255,255,0.04) 100%
  ) !important;

  box-shadow:
    0 6px 14px rgba(0,0,0,0.52),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

[data-theme-style="dark"] .btn.btn-gray-200[data-toggle="collapse"]:hover svg{
  color: rgba(255,133,3,0.92) !important;
}

[data-theme-style="dark"] .btn.btn-gray-200[data-toggle="collapse"][aria-expanded="true"]{
  border-color: rgba(15,165,235,0.32) !important;

  background: linear-gradient(180deg,
    rgba(15,165,235,0.18) 0%,
    rgba(255,255,255,0.05) 100%
  ) !important;

  color: rgba(255,255,255,0.90) !important;

  box-shadow:
    0 10px 22px rgba(0,0,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.07);
}

[data-theme-style="dark"] .btn.btn-gray-200[data-toggle="collapse"][aria-expanded="true"] svg{
  color: var(--tp-blue-light) !important;
}

/* =========================================================
   TOP MENU BUTTONS (.btn-custom)
   - Statistics tabs + Account menu
   - Light + Dark + Mobile
   - FIX: ellipsis + žádné uřezané stíny + nerušící shadows
   ========================================================= */

/* 1) Zajisti, že se stíny neřežou wrapperem */
.row.row-cols-2.row-cols-md-3.row-cols-xl-6,
.row.d-none.d-lg-flex{
  overflow: visible !important;
}

.row.row-cols-2.row-cols-md-3.row-cols-xl-6 > div,
.row.d-none.d-lg-flex > div{
  overflow: visible !important; /* wrapper (p-1/p-2) nesmí řezat stín */
}

/* 2) Základní vzhled tlačítek */
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom,
.row.d-none.d-lg-flex .btn.btn-custom{
  /* layout */
  width: 100%;
  min-width: 0;                 /* ✅ nutné pro ellipsis ve flexu */
  align-items: center;
  justify-content: center;
  gap: .55rem;

  /* ellipsis */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;

  /* typografie */
  font-weight: 650;
  font-size: .95rem;
  letter-spacing: .01em;

  /* tvar */
  border-radius: 14px;
  padding: .72rem .95rem;

  /* light – decentní */
background: linear-gradient(180deg, rgba(15,165,235,.14), rgba(15,165,235,.08));
  border-color: rgba(15,165,235,.45);
  color: rgba(11,18,32,.86) !important;

  /* stín – MENŠÍ a čistý (žádný „kouř“) */
  box-shadow:
    0 6px 14px rgba(6,16,34,.08),
    inset 0 1px 0 rgba(255,255,255,.85);

  transition:
    transform .16s ease,
    box-shadow .16s ease,
    border-color .16s ease,
    background .16s ease,
    filter .16s ease;
}

/* Ikona nesmí „sežrat“ místo textu */
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom svg,
.row.d-none.d-lg-flex .btn.btn-custom svg{
  flex: 0 0 auto;
  opacity: .78;
}

/* Text uvnitř buttonu – pro jistotu, kdyby byl span apod. */
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom > *,
.row.d-none.d-lg-flex .btn.btn-custom > *{
  min-width: 0; /* ✅ umožní ellipsis */
}

/* 3) Hover – vždy oranžový (jemně, bez přepalu) */
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom:hover,
.row.d-none.d-lg-flex .btn.btn-custom:hover{
  background: linear-gradient(180deg, rgba(255,133,3,.16), rgba(255,133,3,.08));
  border-color: rgba(255,133,3,.38);

  /* menší „lift“ */
  transform: translateY(-1px);

  box-shadow:
    0 8px 18px rgba(6,16,34,.10),
    inset 0 1px 0 rgba(255,255,255,.85);

  filter: saturate(1.02);
}

/* 4) Active/current tab */
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom.active,
.row.d-none.d-lg-flex .btn.btn-custom.active{
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,250,255,.94));
  border: 1px solid rgba(15,165,235,0.18);
  color: rgba(11,18,32,.78) !important;

  box-shadow:0 1px 7px rgb(6 16 34 / 7%), inset 0 1px 0 rgba(255, 255, 255, .85);

  transform: none;
}

.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom.active svg,
.row.d-none.d-lg-flex .btn.btn-custom.active svg{
  opacity: .95;
  color: var(--tp-blue-light) !important;
}

/* 5) Pressed / click – stejné „stisknutí“ jako u Vybrat soubory (jemné) */
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom:active,
.row.d-none.d-lg-flex .btn.btn-custom:active{
  transform: translateY(1px);
  box-shadow:
    0 4px 10px rgba(6,16,34,.08),
    inset 0 2px 6px rgba(6,16,34,.10);
}

/* 6) Mobile: méně paddingu a jistota čitelnosti */
@media (max-width: 768px){
  .row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom,
  .row.d-none.d-lg-flex .btn.btn-custom{
    font-size: .92rem;
    padding: .68rem .85rem;
    border-radius: 13px;
  }
}

/* =========================================================
   DARK THEME
   (bez zelené, jen Transfer+ modrá/oranžová)
   ========================================================= */

[data-theme-style="dark"]
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom,
[data-theme-style="dark"]
.row.d-none.d-lg-flex .btn.btn-custom{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(220,230,255,.78) !important;

  box-shadow:
    0 10px 22px rgba(0,0,0,.42),
    inset 0 1px 0 rgba(255,255,255,.06);
}

[data-theme-style="dark"]
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom svg,
[data-theme-style="dark"]
.row.d-none.d-lg-flex .btn.btn-custom svg{
  opacity: .82;
  color: rgba(220,230,255,.75) !important;
}

[data-theme-style="dark"]
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom:hover,
[data-theme-style="dark"]
.row.d-none.d-lg-flex .btn.btn-custom:hover{
  background: linear-gradient(180deg, rgba(255,133,3,.22), rgba(255,133,3,.10));
  border-color: rgba(255,133,3,.36);

  transform: translateY(-1px);

  box-shadow:
    0 12px 26px rgba(0,0,0,.50),
    inset 0 1px 0 rgba(255,255,255,.06);
}

[data-theme-style="dark"]
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom.active,
[data-theme-style="dark"]
.row.d-none.d-lg-flex .btn.btn-custom.active{
  background: linear-gradient(180deg, rgba(15,165,235,.22), rgba(15,165,235,.10));
  border-color: rgba(15,165,235,.38);
  color: rgba(255,255,255,.88) !important;
}

[data-theme-style="dark"]
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom.active svg,
[data-theme-style="dark"]
.row.d-none.d-lg-flex .btn.btn-custom.active svg{
  color: var(--tp-blue-light) !important;
  opacity: .95;
}

[data-theme-style="dark"]
.row.row-cols-2.row-cols-md-3.row-cols-xl-6 .btn.btn-custom:active,
[data-theme-style="dark"]
.row.d-none.d-lg-flex .btn.btn-custom:active{
  transform: translateY(1px);
  box-shadow:
    0 8px 18px rgba(0,0,0,.42),
    inset 0 2px 7px rgba(0,0,0,.30);
}

/* =========================================================
   TOP NAV STRIP (transfer/account)
   ========================================================= */

.tp-topnav {
  display: flex;
  flex-wrap: nowrap;
  gap: 0;
  align-items: stretch;
  margin: 1.2rem 0 3rem !important;
  padding-bottom: 0;
  border: 0;
  border-radius: 20px;
  background: linear-gradient(180deg, rgb(255 255 255 / 98%), rgb(246 248 249));
  box-shadow:
    0 -12px 20px -20px rgba(6,16,34,.42),
    inset 0 1px 0 rgba(255,255,255,.88);
  position: relative;
  overflow: visible;
}

.tp-account-preferences-section-title h2 {
    letter-spacing: .05em;
}

.tp-account-branding-promo-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
    gap: 1.25rem;
    align-items: stretch;
}

.tp-account-branding-promo-copy {
    position: relative;
    z-index: 2;
}

.tp-account-branding-promo-kicker {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .36rem .7rem;
    margin-bottom: .85rem;
    border-radius: 999px;
    background: rgba(15, 165, 235, .1);
    color: #0b72bd;
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.tp-account-branding-promo-title {
    font-weight: 850;
    line-height: 1.08;
    max-width: 18ch;
}

.tp-account-branding-promo-description {
    font-size: 1rem;
    line-height: 1.6;
    max-width: 56ch;
}

.tp-account-branding-promo-bullets {
    display: grid;
    gap: .7rem;
    color: #233246;
}

.tp-account-branding-promo-bullets li {
    display: flex;
    align-items: center;
    gap: .72rem;
    min-height: 50px;
    padding: .72rem 1rem !important;
    border-radius: .72rem !important;
    border: 1px solid #e8eaed !important;
    background: #f0f1f2 !important;
    color: #1089D0 !important;
    font-size: 0.90rem !important;
    font-weight: 600 !important;
    line-height: 1.2;
    margin: 0;
}

.tp-account-branding-promo-bullets i {
    width: 1rem;
    min-width: 1rem;
    color: #0fa5eb !important;
    font-size: 1rem !important;
    margin-top: 0;
    flex: 0 0 auto;
}

.tp-account-branding-promo-visual {
    position: relative;
    min-height: 360px;
    border-radius: 16px;
    padding: .95rem;
    border: 1px solid rgba(15, 165, 235, .12);
    background: radial-gradient(circle at 25% 10%, rgba(15, 165, 235, .1), transparent 48%), linear-gradient(180deg, rgba(246, 251, 255, .95), rgba(236, 246, 255, .9));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
    overflow: hidden;
}
.tp-account-branding-promo-image-shell {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 328px;
    overflow: hidden;
}

.tp-account-branding-promo-image {
    position: absolute;
    inset: .55rem;
    width: calc(100% - 1.1rem);
    height: calc(100% - 1.1rem);
    object-fit: contain;
    object-position: center;
    display: block;
    border-radius: 12px;
    z-index: 1;
}

.tp-account-branding-promo-image-placeholder {
    position: absolute;
    inset: .9rem;
    border-radius: 14px;
    border: 1px dashed rgba(18, 52, 124, .18);
    background: linear-gradient(180deg, rgba(255,255,255,.76), rgba(241, 248, 255, .8));
    display: grid;
    place-items: center;
    text-align: center;
    gap: .5rem;
    color: rgba(16, 37, 63, .58);
    padding: 1rem;
    font-weight: 600;
    z-index: 1;
}

.tp-account-branding-promo-image-placeholder i {
    font-size: 1.25rem;
    color: rgba(18, 52, 124, .45);
}

.tp-account-branding-promo-image-placeholder span {
    max-width: 24ch;
    line-height: 1.35;
    font-size: .9rem;
}

.tp-account-branding-promo-note {
    position: absolute;
    left: 1.25rem;
    right: 1.25rem;
    bottom: 1rem;
    border-radius: 14px;
    border: 1px solid rgba(15, 165, 235, .14);
    background: linear-gradient(180deg, rgba(239, 248, 255, .95), rgba(227, 243, 255, .9));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .85);
    padding: .75rem .85rem;
    z-index: 3;
}

.tp-account-branding-promo-note-badge {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    margin-bottom: .45rem;
    color: #0b72bd;
    font-weight: 700;
    font-size: .82rem;
}

.tp-account-branding-promo-note-title {
    font-weight: 700;
    color: #10253f;
    margin-bottom: .25rem;
}

[data-theme-style="dark"] .tp-account-branding-promo-kicker {
    background: rgba(15, 165, 235, .18);
    color: #7dd3fc;
}

[data-theme-style="dark"] .tp-account-branding-promo-title {
    color: rgba(255, 255, 255, .95);
}

[data-theme-style="dark"] .tp-account-branding-promo-description {
    color: rgba(255,255,255,.72) !important;
}

[data-theme-style="dark"] .tp-account-branding-promo-bullets {
    color: rgba(255, 255, 255, .86);
}

[data-theme-style="dark"] .tp-account-branding-promo-bullets li {
    background: linear-gradient(180deg, #101319, #101319) !important;
    border: 1px solid rgb(0 0 0 / 18%) !important;
    border-radius: 18px !important;
    box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
    color: rgba(255, 255, 255, .9) !important;
}

[data-theme-style="dark"] .tp-account-branding-promo-bullets i {
    color: #7bd4ff !important;
}

[data-theme-style="dark"] .tp-account-branding-promo-visual {
    background: radial-gradient(circle at 25% 10%, rgba(15,165,235,.18), transparent 48%), linear-gradient(180deg, rgba(7, 16, 29, .95), rgba(4, 8, 14, .95));
    border-color: rgba(69, 127, 207, .16);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

[data-theme-style="dark"] .tp-account-branding-promo-image-shell {
    box-shadow: none;
}

[data-theme-style="dark"] .tp-account-branding-promo-image {
    filter: drop-shadow(0 14px 20px rgba(0, 0, 0, .22));
}

[data-theme-style="dark"] .tp-account-branding-promo-image-placeholder {
    border-color: rgba(69,127,207,.22);
    background: linear-gradient(180deg, rgba(13, 24, 43, .72), rgba(10, 18, 32, .78));
    color: rgba(255,255,255,.64);
}

[data-theme-style="dark"] .tp-account-branding-promo-image-placeholder i {
    color: rgba(125, 211, 252, .58);
}

[data-theme-style="dark"] .tp-account-branding-promo-note {
    background: rgba(11, 22, 41, .72);
    border-color: rgba(69, 127, 207, .24);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
}

[data-theme-style="dark"] .tp-account-branding-promo-note-title {
    color: rgba(255, 255, 255, .94);
}

@media (max-width: 991.98px) {
    .tp-account-branding-promo-grid {
        grid-template-columns: 1fr;
        gap: .85rem;
    }

    .tp-account-branding-promo-visual {
        min-height: 310px;
    }

    .tp-account-branding-promo-note {
        left: .75rem;
        right: .75rem;
        bottom: .7rem;
        padding: .65rem .7rem;
    }
}

@media (max-width: 575.98px) {
    .tp-account-branding-promo-title {
        font-size: 1.45rem;
        max-width: none;
    }

    .tp-account-branding-promo-description {
        font-size: .96rem;
    }

    .tp-account-branding-promo-visual {
        min-height: 280px;
        padding: .8rem;
    }

    .tp-account-branding-promo-note {
        position: static;
        margin-top: .6rem;
    }
}

.tp-topnav-item {
  position: relative;
  flex: 1 1 0;
  min-width: 116px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .3rem;
  min-height: 74px;
  padding: .55rem .42rem .45rem;
  border: 0;
  border-right: 1px solid rgb(243 243 243);
  border-radius: 0;
  background: transparent !important;
  box-shadow: none;
  color: rgba(11,18,32,.84) !important;
  text-align: center;
  text-decoration: none !important;
  transition: background .15s ease, color .15s ease, filter .15s ease;
}

.tp-topnav-item:first-child {
  border-top-left-radius: 19px;
  border-bottom-left-radius: 19px;
}

.tp-topnav-item:last-child {
  border-right: 0;
  border-top-right-radius: 19px;
  border-bottom-right-radius: 19px;
}

.tp-topnav-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.45rem;
  height: 1.45rem;
  color: rgba(15,165,235,.95);
}

.tp-topnav-label {
  display: block;
  max-width: 100%;
  font-size: .85rem;
  font-weight: 600;
  line-height: 1.1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tp-topnav-item:hover {
  background: linear-gradient(180deg, rgba(15,165,235,.16), rgba(15,165,235,.08)) !important;
  color: rgba(11,18,32,.95) !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:hover,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:focus,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:active,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"],
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:hover,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:focus,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:active {
  background: #e8edf4 !important;
  color: #8190a6 !important;
  border-right-color: #d2dbe8 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  filter: grayscale(.22) !important;
  opacity: .52 !important;
  transition: none !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled .tp-topnav-icon,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:hover .tp-topnav-icon,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"] .tp-topnav-icon,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:hover .tp-topnav-icon {
  color: #8ea0b9 !important;
  opacity: .8 !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled .tp-topnav-label,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"] .tp-topnav-label {
  color: #7f8da4 !important;
  text-decoration: line-through !important;
  text-decoration-thickness: 1px !important;
}

.tp-topnav-item.active {
  background: #12347c !important;
  color: #fff !important;
}

.tp-topnav-item.active .tp-topnav-icon {
  color: #fff;
}

.tp-topnav-item.active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: calc(-.36rem - 1px);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: .46rem solid transparent;
  border-right: .46rem solid transparent;
  border-top: .46rem solid rgba(18,52,124,.36);
  z-index: 3;
}

.tp-topnav-item.active::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -0.35rem;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: .4rem solid transparent;
  border-right: .4rem solid transparent;
  border-top: .4rem solid #12347c;
  z-index: 4;
}

.tp-topnav-item.tp-topnav-item-danger {
  color: rgba(161,31,31,.88) !important;
}

.tp-topnav-item.tp-topnav-item-danger .tp-topnav-icon {
  color: rgba(183,44,44,.9);
}

.tp-topnav-item.tp-topnav-item-danger:hover {
  background: linear-gradient(180deg, rgba(255,220,220,.42), rgba(255,215,215,.3)) !important;
  color: rgba(145,20,20,.92) !important;
}

.tp-topnav-item.tp-topnav-item-danger.active {
  background: linear-gradient(180deg, rgba(255,220,220,.6), rgba(255,210,210,.45)) !important;
  color: rgba(138,15,15,.95) !important;
}

.tp-topnav-item.tp-topnav-item-danger.active::after {
  border-top-color: rgba(200,66,66,.45);
}

.tp-topnav-item.tp-topnav-item-danger.active::before {
  border-top-color: rgba(200,66,66,.9);
}

[data-theme-style="dark"] .tp-topnav {
  background: linear-gradient(180deg, rgb(28 33 44), rgb(255 255 255 / 0%));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

[data-theme-style="dark"] .tp-topnav-item {
  border-right: 1px solid rgb(4 5 6) !important;
  color: rgba(221,232,255,.84) !important;
}

[data-theme-style="dark"] .tp-topnav-icon {
  color: rgba(63,185,240,.9);
}

[data-theme-style="dark"] .tp-topnav-item:hover {
  background: linear-gradient(180deg, rgba(63,185,240,.24), rgba(63,185,240,.12));
  color: rgba(241,247,255,.95) !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:hover,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:focus,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:active,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"],
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:hover,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:focus,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:active {
  background: rgba(70, 80, 96, .58) !important;
  color: rgba(171, 186, 208, .84) !important;
  border-right-color: rgba(96, 112, 138, .72) !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  filter: grayscale(.3) !important;
  opacity: .5 !important;
  transition: none !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled .tp-topnav-icon,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:hover .tp-topnav-icon,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"] .tp-topnav-icon,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:hover .tp-topnav-icon {
  color: rgba(163, 179, 205, .88) !important;
  opacity: .78 !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled .tp-topnav-label,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"] .tp-topnav-label {
  color: rgba(171, 186, 208, .86) !important;
  text-decoration: line-through !important;
  text-decoration-thickness: 1px !important;
}

[data-theme-style="dark"] .tp-topnav-item.active {
  background: #12347c !important;
  color: #fff !important;
}

[data-theme-style="dark"] .tp-topnav-item.active .tp-topnav-icon {
  color: #fff;
}

[data-theme-style="dark"] .tp-topnav-item.active::after {
  border-top-color: rgba(18,52,124,.36);
}

[data-theme-style="dark"] .tp-topnav-item.active::before {
  border-top-color: #12347c;
}

[data-theme-style="dark"] .tp-topnav-item.tp-topnav-item-danger {
  color: rgba(255,200,200,.92) !important;
}

[data-theme-style="dark"] .tp-topnav-item.tp-topnav-item-danger .tp-topnav-icon {
  color: rgba(255,188,188,.93);
}

@media (max-width: 991.98px) {
  .tp-topnav {
    margin: 0rem 0 2.15rem !important;
    padding-bottom: 0;
    overflow: visible;
    justify-content: stretch;
  }

  .tp-topnav-item {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    min-height: 62px;
    padding: .7rem .24rem;
    border-radius: 0;
    gap: 0;
  }

  .tp-topnav-item:first-child {
    border-top-left-radius: 17px;
    border-bottom-left-radius: 17px;
  }

  .tp-topnav-item:last-child {
    border-top-right-radius: 17px;
    border-bottom-right-radius: 17px;
  }

  .tp-topnav-icon {
    width: 1.25rem;
    height: 1.25rem;
  }

  .tp-topnav-label {
    display: none;
  }
}

/* =========================================================
   TRANSFER DETAIL NAV - PRO SAAS REFRESH
   ========================================================= */

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4){
  border: 1px solid rgba(15, 165, 235, .28);
  background: linear-gradient(145deg, #0fa5eb 0%, #0fa5eb 48%, #238ec8 100%);
  box-shadow: 0 14px 28px rgba(7, 31, 56, .16), inset 0 1px 0 rgba(255,255,255,.26);
  overflow: visible;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item{
  border-right-color: rgba(204, 234, 252, .34) !important;
  color: rgba(241, 250, 255, .95) !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-icon{
  color: rgba(225, 243, 255, .98) !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current{
  background: linear-gradient(145deg, #163f96 0%, #133a8a 56%, #12347c 100%) !important;
  color: #ffffff !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active .tp-topnav-icon,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current .tp-topnav-icon{
  color: #ffffff !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active::before,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current::before{
  border-top-color: #12347c !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active::after,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current::after{
  border-top-color: rgba(6, 61, 98, .26) !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active *,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current *,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-current="page"],
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-current="page"] *{
  cursor: default;
  pointer-events: none;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item:hover{
  background: linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.08)) !important;
  color: #ffffff !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-danger:hover{
  background: linear-gradient(180deg, rgba(196, 44, 44, .9), rgba(152, 22, 22, .88)) !important;
  color: #fff3ef !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-danger:hover .tp-topnav-icon{
  color: #ffe1da !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:hover,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:focus,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:active,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"],
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:hover,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:focus,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:active{
  background: rgba(11, 76, 127, .34) !important;
  color: rgba(211, 232, 247, .62) !important;
  border-right-color: rgba(176, 210, 235, .22) !important;
  opacity: .74 !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled .tp-topnav-icon,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:hover .tp-topnav-icon,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"] .tp-topnav-icon,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:hover .tp-topnav-icon{
  color: rgba(198, 220, 239, .72) !important;
}

:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled .tp-topnav-label,
:is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"] .tp-topnav-label{
  color: rgba(206, 227, 244, .72) !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4){
  border-color: rgb(0 0 0 / 18%);
  background: linear-gradient(180deg, rgb(7 22 39), rgb(15 76 129));
  box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%);
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item{
  border-right-color: rgba(152, 198, 236, .24) !important;
  color: rgba(229, 242, 255, .93) !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-icon{
  color: rgba(158, 214, 255, .95) !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current{
  background: linear-gradient(145deg, #163f96 0%, #133a8a 56%, #12347c 100%) !important;
  color: #f2f8ff !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active .tp-topnav-icon,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current .tp-topnav-icon{
  color: #d9edff !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active::before,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current::before{
  border-top-color: #12347c !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.active::after,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-current::after{
  border-top-color: rgba(2, 23, 41, .42) !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item:hover{
  background: linear-gradient(180deg, rgba(130, 194, 238, .2), rgba(88, 156, 214, .13)) !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-danger:hover{
  background: linear-gradient(180deg, rgba(169, 46, 46, .96), rgba(120, 22, 22, .94)) !important;
  color: #fff0ed !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-danger:hover .tp-topnav-icon{
  color: #ffd4cc !important;
}

[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:hover,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:focus,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item.tp-topnav-item-disabled:active,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"],
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:hover,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:focus,
[data-theme-style="dark"] :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4) .tp-topnav-item[aria-disabled="true"]:active{
  background: rgba(11, 41, 71, .72) !important;
  color: rgba(178, 201, 224, .72) !important;
  border-right-color: rgba(119, 151, 184, .34) !important;
}

@media (max-width: 991.98px){
  :is(.tp-transfer-topnav, .tp-account-topnav, .tp-topnav.tp-account-topnav.mb-4){
    margin: .1rem 0 1.9rem !important;
    border-radius: 16px;
  }
}

/* =========================================================
   TRANSFER UPDATE + ANALYTICS - SIMPLE SUBTABS
   ========================================================= */

.tp-split-layout {
  display: grid;
  grid-template-columns: minmax(0, 16rem) minmax(0, 1fr);
  gap: 1.2rem;
  align-items: start;
  margin-top: 1.15rem;
}

.tp-split-sidebar {
  min-width: 0;
  position: sticky;
  top: 1rem;
}

.tp-split-content {
  min-width: 0;
}

.tp-subtabs-shell {
  position: relative;
  z-index: 2;
  margin: 0;
}

.tp-subtabs-track {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: .42rem;
  padding: .55rem;
  border: 0;
  border-radius: 18px;
  box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9);
  background: #ffffff;
}

.tp-subtab-btn {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  min-height: 2.52rem;
  gap: .5rem;
  padding: .5rem .72rem;
  border: 1px solid transparent;
  border-radius: 11px;
  background: transparent;
  color: rgba(21,34,53,.86);
  font-size: .88rem;
  font-weight: 640;
  line-height: 1.2;
  text-decoration: none;
  white-space: nowrap;
  transition: background .16s ease, border-color .16s ease, color .16s ease, box-shadow .16s ease;
}

.tp-subtab-btn i,
.tp-subtab-btn svg {
  flex: 0 0 auto;
  color: rgba(15,165,235,.9);
}

.tp-subtab-btn:hover {
  background: rgba(15,165,235,.12);
  border-color: rgba(15,165,235,.28);
  color: rgba(16,28,46,.95);
  text-decoration: none;
}

.tp-subtab-btn.active {
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,252,255,.95));
  border-color: rgba(15,165,235,.52);
  color: rgba(8,20,37,.98);
  box-shadow: 0 4px 12px rgba(6,16,34,.08), inset 0 1px 0 rgba(255,255,255,.9);
}

.tp-subtab-btn.active i,
.tp-subtab-btn.active svg {
  color: #0fa5eb;
}

.tp-update-subtabs .tp-subtab-btn {
  font-size: .9rem;
}

.tp-update-subtabs .tp-subtab-btn span {
  display: inline-block;
}

.tp-update-split-layout {
  gap: 1.5rem;
}

.tp-stats-split-layout {
  gap: 1.5rem;
}

.tp-stats-subtabs .tp-subtabs-track {
  max-height: min(67vh, 39rem);
  overflow-y: auto;
  overflow-x: hidden;
}

.tp-stats-subtabs .tp-subtab-btn span {
  display: inline-block;
  font-size: .84rem;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tp-update-card {
  border-top-left-radius: 16px !important;
  border-top-right-radius: 16px !important;
  border-top: 1px solid rgba(4,16,26,.08) !important;
  margin-top: 0;
}

.tp-update-card > .card-body {
  padding-top: 1.15rem;
}

.tp-update-pane-title {
  font-size: 1.2rem;
  line-height: 1.2;
  font-weight: 700;
  color: rgba(4,16,26,.92);
  margin: 0 0 1rem;
}

[data-theme-style="dark"] .tp-subtabs-track {
  border-color: rgba(95,175,235,.28);
  background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.03));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
}

[data-theme-style="dark"] .tp-subtab-btn {
  color: rgba(224,236,255,.9);
}

[data-theme-style="dark"] .tp-subtab-btn i,
[data-theme-style="dark"] .tp-subtab-btn svg {
  color: rgba(160,220,255,.93);
}

[data-theme-style="dark"] .tp-subtab-btn:hover {
  background: rgba(95,175,235,.22);
  border-color: rgba(95,175,235,.36);
  color: rgba(242,248,255,.96);
}

[data-theme-style="dark"] .tp-subtab-btn.active {
  background: linear-gradient(180deg, rgba(245,251,255,.97), rgba(231,241,252,.96));
  border-color: rgba(95,175,235,.46);
  color: rgba(4,16,26,.95);
}

[data-theme-style="dark"] .tp-subtab-btn.active i,
[data-theme-style="dark"] .tp-subtab-btn.active svg {
  color: rgba(4,16,26,.92);
}

[data-theme-style="dark"] .tp-update-card {
  border-top-color: rgba(95,175,235,.32) !important;
}

[data-theme-style="dark"] .tp-update-pane-title {
  color: rgba(240,247,255,.95);
}

@media (max-width: 991.98px) {
  .tp-split-layout {
    display: block;
    margin-top: .8rem;
  }

  .tp-split-sidebar {
    position: static;
    margin-bottom: 1rem;
  }

  .tp-subtabs-shell {
    margin: .2rem 0 1rem;
    border: 0 !important;
    box-shadow: none !important;
  }

  .tp-subtabs-track {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
    gap: .56rem;
    padding: .15rem 0 .35rem;
    max-height: none;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none;
  }

  .tp-subtabs-track::-webkit-scrollbar {
    width: 0 !important;
    height: 0 !important;
    display: none !important;
    background: transparent !important;
  }

  .tp-subtabs-track::-webkit-scrollbar-track,
  .tp-subtabs-track::-webkit-scrollbar-thumb {
    background: transparent !important;
    border: 0 !important;
  }

  .tp-subtab-btn {
    width: auto;
    min-width: max-content;
    min-height: 2.4rem;
    padding: .48rem .78rem;
  }

  .tp-stats-subtabs .tp-subtab-btn {
    width: auto;
    min-width: max-content;
    justify-content: flex-start;
    padding: .48rem .78rem;
  }

  .tp-stats-subtabs .tp-subtabs-track {
    max-height: none !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    border-radius: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .tp-stats-subtabs .tp-subtab-btn span {
    display: inline-block;
    margin-left: 0;
    max-width: none;
    overflow: visible;
    text-overflow: clip;
    font-size: .84rem;
  }

  .tp-stats-subtabs .tp-subtab-btn.active {
    width: auto;
    min-width: max-content;
    padding: .48rem .78rem;
  }

  .tp-stats-subtabs .tp-subtab-btn.active span {
    display: inline-block;
    margin-left: 0;
    max-width: none;
    overflow: visible;
    text-overflow: clip;
    font-size: .84rem;
  }

  /* Mobilní selecty: 16px omezuje zoom/picker offset bugy (iOS/Chrome) */
  .tp-update-card select.custom-select,
  #upload_form select.custom-select,
  #upload_form .custom-select.custom-select-sm {
    font-size: 16px !important;
  }
}

/* =========================================================
   TRANSFER UPDATE - THEME BUILDER CARDS
   ========================================================= */

.tp-theme-preset-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.tp-theme-preset-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: .38rem;
  border: 1px solid rgba(4,16,26,.16);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,249,252,.96));
  box-shadow: 0 4px 10px rgba(6,16,34,.06), inset 0 1px 0 rgba(255,255,255,.8);
  padding: .35rem;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}

.tp-theme-preset-card:hover {
  transform: translateY(-1px);
  border-color: rgba(255,133,3,.42);
  background: linear-gradient(180deg, rgba(255,133,3,.14), rgba(255,133,3,.08));
}

.tp-theme-preset-card.active {
  border-color: rgba(15,165,235,.68);
  background: linear-gradient(180deg, rgba(15,165,235,.18), rgba(15,165,235,.1));
  box-shadow: 0 0 0 2px rgba(15,165,235,.18), 0 8px 18px rgba(6,16,34,.09), inset 0 1px 0 rgba(255,255,255,.86);
}

.tp-theme-preset-card.active::after {
  content: "";
  position: absolute;
  top: .38rem;
  right: .38rem;
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 999px;
  background: #0fa5eb;
  box-shadow: 0 1px 4px rgba(4,16,26,.22), inset 0 1px 0 rgba(255,255,255,.4);
  pointer-events: none;
}

.tp-theme-preset-card.active::before {
  content: "";
  position: absolute;
  top: .72rem;
  right: .72rem;
  width: .34rem;
  height: .18rem;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
  z-index: 1;
  pointer-events: none;
}

.tp-theme-preset-thumb {
  display: block;
  width: 100%;
  border-radius: 9px;
  overflow: hidden;
  border: 1px solid rgba(4,16,26,.18);
  background: #f6f8f9;
}

.tp-theme-preset-thumb img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: cover;
}

.tp-theme-preset-label {
  display: block;
  font-weight: 700;
  font-size: .76rem;
  color: rgba(11,18,32,.86);
  text-align: center;
  line-height: 1.2;
}

.tp-theme-card-mode-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
}

.tp-theme-card-mode {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .55rem;
  border: 1px solid rgba(4,16,26,.16);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,249,252,.96));
  box-shadow: 0 4px 10px rgba(6,16,34,.06), inset 0 1px 0 rgba(255,255,255,.8);
  padding: .75rem;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}

.tp-theme-card-mode:hover {
  transform: translateY(-1px);
  border-color: rgba(255,133,3,.42);
  background: linear-gradient(180deg, rgba(255,133,3,.14), rgba(255,133,3,.08));
}

.tp-theme-card-mode.active {
  border-color: rgba(15,165,235,.68);
  background: linear-gradient(180deg, rgba(15,165,235,.18), rgba(15,165,235,.1));
  box-shadow: 0 0 0 2px rgba(15,165,235,.18), 0 8px 18px rgba(6,16,34,.09), inset 0 1px 0 rgba(255,255,255,.86);
}

.tp-theme-card-mode-thumb {
  width: 100%;
  height: 58px;
  border-radius: 12px;
  border: 1px solid rgba(4,16,26,.22);
  background:
    radial-gradient(circle at 85% 20%, rgba(255,255,255,.55) 0%, rgba(255,255,255,0) 38%),
    linear-gradient(135deg, rgba(15,165,235,.42), rgba(4,16,26,.2));
}

.tp-theme-card-mode-solid {
  background:
    linear-gradient(180deg, rgba(255,255,255,.9), rgba(225,238,249,.95));
}

.tp-theme-card-mode-glass {
  background:
    linear-gradient(180deg, rgba(255,255,255,.42), rgba(255,255,255,.2));
  backdrop-filter: blur(1.5px);
}

.tp-theme-card-mode-label {
  font-weight: 700;
  font-size: .9rem;
  color: rgba(11,18,32,.86);
}

.tp-theme-reset-wrap {
  margin-top: .45rem;
  margin-bottom: 1rem !important;
}

.tp-theme-reset-button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  font-weight: 650;
  border-radius: 14px;
  padding: .68rem 1rem !important;
  background: linear-gradient(180deg, rgba(15,165,235,.14), rgba(15,165,235,.08)) !important;
  border-color: rgba(15,165,235,.45) !important;
  color: rgba(11,18,32,.86) !important;
  box-shadow: 0 6px 14px rgba(6,16,34,.08), inset 0 1px 0 rgba(255,255,255,.85);
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}

.tp-theme-reset-button:hover {
  transform: translateY(-1px);
  background: linear-gradient(180deg, rgba(255,133,3,.16), rgba(255,133,3,.08)) !important;
  border-color: rgba(255,133,3,.38) !important;
}

.tp-theme-reset-button.active {
  border-color: rgba(15,165,235,.62) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.97), rgba(244,249,255,.93)) !important;
  color: rgba(11,18,32,.88) !important;
  box-shadow: 0 0 0 2px rgba(15,165,235,.16), 0 6px 14px rgba(6,16,34,.1), inset 0 1px 0 rgba(255,255,255,.9);
}

[data-theme-style="dark"] .tp-theme-preset-card,
[data-theme-style="dark"] .tp-theme-card-mode {
  border-color: rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow: 0 10px 22px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.06);
}

[data-theme-style="dark"] .tp-theme-preset-card:hover,
[data-theme-style="dark"] .tp-theme-card-mode:hover {
  border-color: rgba(255,133,3,.38);
  background: linear-gradient(180deg, rgba(255,133,3,.22), rgba(255,133,3,.1));
}

[data-theme-style="dark"] .tp-theme-preset-card.active,
[data-theme-style="dark"] .tp-theme-card-mode.active {
  border-color: rgba(15,165,235,.45);
  background: linear-gradient(180deg, rgba(15,165,235,.2), rgba(15,165,235,.1));
  box-shadow: 0 0 0 2px rgba(15,165,235,.2), 0 10px 22px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.06);
}

[data-theme-style="dark"] .tp-theme-preset-label,
[data-theme-style="dark"] .tp-theme-card-mode-label {
  color: rgba(220,230,255,.88);
}

[data-theme-style="dark"] .tp-theme-preset-card.active::after {
  background: #3fb9f0;
  box-shadow: 0 1px 5px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.22);
}

[data-theme-style="dark"] .tp-theme-preset-card.active::before {
  border-left-color: #031520;
  border-bottom-color: #031520;
}

[data-theme-style="dark"] .tp-theme-preset-thumb {
  border-color: rgba(255,255,255,.2);
  background: rgba(10,16,24,.75);
}

[data-theme-style="dark"] .tp-theme-card-mode-thumb {
  border-color: rgba(255,255,255,.2);
}

[data-theme-style="dark"] .tp-theme-card-mode-solid {
  background: linear-gradient(180deg, rgba(36,44,56,.9), rgba(22,27,35,.9));
}

[data-theme-style="dark"] .tp-theme-card-mode-glass {
  background: linear-gradient(180deg, rgba(255,255,255,.2), rgba(255,255,255,.08));
}

[data-theme-style="dark"] .tp-theme-reset-button {
  border-color: rgba(255,255,255,.14) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)) !important;
  color: rgba(220,230,255,.88) !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.06);
}

[data-theme-style="dark"] .tp-theme-reset-button:hover {
  border-color: rgba(255,133,3,.38) !important;
  background: linear-gradient(180deg, rgba(255,133,3,.22), rgba(255,133,3,.1)) !important;
}

[data-theme-style="dark"] .tp-theme-reset-button.active {
  border-color: rgba(15,165,235,.45) !important;
  background: linear-gradient(180deg, rgba(15,165,235,.2), rgba(15,165,235,.1)) !important;
  color: rgba(255,255,255,.92) !important;
  box-shadow: 0 0 0 2px rgba(15,165,235,.2), 0 10px 22px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.06);
}

@media (max-width: 768px) {
  .tp-theme-preset-grid,
  .tp-theme-card-mode-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1200px) {
  .tp-theme-preset-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 575.98px) {
  .tp-theme-preset-grid {
    grid-template-columns: 1fr 1fr;
    gap: .72rem;
  }

  .tp-theme-card-mode-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 410px) {
  .tp-theme-preset-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   TRANSFER UPDATE - THEME BUILDER REFRESH
   ========================================================= */

.tp-theme-builder-block{
  margin-top: .35rem;
  padding: 1rem 1rem .2rem;
  border: 1px solid rgba(15, 84, 136, .18);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(248, 252, 255, .96), rgba(238, 247, 255, .92));
  box-shadow: 0 12px 24px -18px rgba(8, 34, 59, .34), inset 0 1px 0 rgba(255,255,255,.84);
}

.tp-theme-builder-title{
  font-size: 1.04rem;
  font-weight: 800;
  color: #08213b;
  letter-spacing: .01em;
}

.tp-theme-builder-help{
  margin-top: .2rem;
  margin-bottom: .95rem !important;
  max-width: 64ch;
  color: rgba(8, 33, 60, .66) !important;
}

.tp-theme-builder-group{
  margin-bottom: 1rem;
}

.tp-theme-builder-group > label{
  display: inline-flex;
  align-items: center;
  margin-bottom: .55rem;
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(8, 33, 60, .72);
}

.tp-theme-builder-block .tp-theme-preset-grid{
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .8rem;
}

.tp-theme-builder-block .tp-theme-preset-card{
  gap: .5rem;
  border-radius: 14px;
  border-color: rgba(11, 71, 122, .2);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(243, 249, 255, .96));
  box-shadow: 0 10px 24px -18px rgba(7, 36, 64, .38), inset 0 1px 0 rgba(255,255,255,.92);
  padding: .48rem;
}

.tp-theme-builder-block .tp-theme-preset-card:hover{
  border-color: rgba(15, 165, 235, .5);
  background: linear-gradient(180deg, rgba(234, 247, 255, .98), rgba(226, 241, 252, .95));
}

.tp-theme-builder-block .tp-theme-preset-card.active{
  border-color: rgba(15,165,235,.66);
  background: linear-gradient(180deg, rgba(225, 242, 255, .98), rgba(216, 236, 252, .95));
  box-shadow: 0 0 0 2px rgba(15,165,235,.2), 0 12px 24px -18px rgba(7, 36, 64, .45), inset 0 1px 0 rgba(255,255,255,.94);
}

.tp-theme-builder-block .tp-theme-preset-thumb{
  border-radius: 10px;
  border-color: rgba(10, 63, 108, .2);
  background: #eef4fa;
}

.tp-theme-builder-block .tp-theme-preset-thumb img{
  aspect-ratio: 16 / 10;
}

.tp-theme-builder-block .tp-theme-preset-label{
  font-size: .84rem;
  font-weight: 760;
  color: rgba(8, 29, 52, .88);
}

.tp-theme-builder-block .tp-theme-card-mode-grid{
  gap: .75rem;
}

.tp-theme-builder-block .tp-theme-card-mode{
  min-height: 120px;
  border-radius: 14px;
  border-color: rgba(11, 71, 122, .2);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(243, 249, 255, .96));
  box-shadow: 0 10px 24px -18px rgba(7, 36, 64, .38), inset 0 1px 0 rgba(255,255,255,.92);
}

.tp-theme-builder-block .tp-theme-card-mode:hover{
  border-color: rgba(15, 165, 235, .5);
  background: linear-gradient(180deg, rgba(234, 247, 255, .98), rgba(226, 241, 252, .95));
}

.tp-theme-builder-block .tp-theme-card-mode.active{
  border-color: rgba(15,165,235,.66);
  background: linear-gradient(180deg, rgba(225, 242, 255, .98), rgba(216, 236, 252, .95));
  box-shadow: 0 0 0 2px rgba(15,165,235,.2), 0 12px 24px -18px rgba(7, 36, 64, .45), inset 0 1px 0 rgba(255,255,255,.94);
}

.tp-theme-builder-block .tp-theme-card-mode-thumb{
  height: 62px;
  border-color: rgba(10, 63, 108, .22);
}

.tp-theme-builder-block .tp-theme-card-mode-label{
  font-size: .88rem;
}

.tp-theme-builder-block .tp-theme-builder-upload{
  border: 1px solid rgba(11, 71, 122, .18);
  border-radius: 14px;
  padding: .85rem .9rem .5rem;
  background: linear-gradient(180deg, rgba(255,255,255,.84), rgba(244, 250, 255, .8));
}

.tp-theme-builder-block .tp-theme-builder-upload .row{
  align-items: center;
  margin-left: -.4rem;
  margin-right: -.4rem;
}

.tp-theme-builder-block .tp-theme-builder-upload .col,
.tp-theme-builder-block .tp-theme-builder-upload .col-3,
.tp-theme-builder-block .tp-theme-builder-upload .col-12{
  padding-left: .4rem;
  padding-right: .4rem;
}

.tp-theme-builder-block .tp-theme-builder-upload .altum-file-input{
  width: 100%;
  min-height: 46px;
  border: 1px dashed rgba(14, 108, 172, .42);
  border-radius: 12px;
  background: rgba(255,255,255,.94);
  padding: .5rem .6rem;
  color: rgba(8, 29, 52, .9);
}

.tp-theme-builder-block .tp-theme-builder-upload .altum-file-input::file-selector-button{
  border: 0;
  border-radius: .62rem;
  background: linear-gradient(180deg, rgba(15,165,235,.2), rgba(15,165,235,.12));
  color: #0a2a48;
  font-weight: 700;
  padding: .42rem .72rem;
  margin-right: .6rem;
  cursor: pointer;
}

.tp-theme-builder-block .tp-theme-builder-upload .altum-file-input::-webkit-file-upload-button{
  border: 0;
  border-radius: .62rem;
  background: linear-gradient(180deg, rgba(15,165,235,.2), rgba(15,165,235,.12));
  color: #0a2a48;
  font-weight: 700;
  padding: .42rem .72rem;
  margin-right: .6rem;
  cursor: pointer;
}

.tp-theme-builder-block .tp-theme-builder-upload .altum-file-input-preview{
  max-height: 72px;
  border: 1px solid rgba(10, 63, 108, .2);
  box-shadow: 0 8px 18px -12px rgba(7, 36, 64, .42);
}

[data-theme-style="dark"] .tp-theme-builder-block{
  border-color: rgba(90, 160, 220, .24);
  background: linear-gradient(180deg, rgba(12, 25, 43, .94), rgba(8, 17, 31, .95));
  box-shadow: 0 14px 28px -16px rgba(0,0,0,.64), inset 0 1px 0 rgba(176, 214, 255, .08);
}

[data-theme-style="dark"] .tp-theme-builder-title{
  color: rgba(236, 245, 255, .96);
}

[data-theme-style="dark"] .tp-theme-builder-help{
  color: rgba(199, 218, 242, .72) !important;
}

[data-theme-style="dark"] .tp-theme-builder-group > label{
  color: rgba(190, 212, 240, .74);
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-preset-card,
[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-card-mode{
  border-color: rgba(92, 157, 216, .26);
  background: linear-gradient(180deg, rgba(16, 33, 56, .92), rgba(12, 25, 43, .92));
  box-shadow: 0 12px 24px -16px rgba(0,0,0,.56), inset 0 1px 0 rgba(255,255,255,.06);
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-preset-card:hover,
[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-card-mode:hover{
  border-color: rgba(121, 191, 250, .42);
  background: linear-gradient(180deg, rgba(22, 52, 86, .92), rgba(15, 37, 64, .92));
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-preset-card.active,
[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-card-mode.active{
  border-color: rgba(121, 191, 250, .5);
  background: linear-gradient(180deg, rgba(28, 66, 105, .95), rgba(20, 49, 82, .95));
  box-shadow: 0 0 0 2px rgba(63,185,240,.22), 0 14px 28px -16px rgba(0,0,0,.62), inset 0 1px 0 rgba(255,255,255,.08);
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-preset-label,
[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-card-mode-label{
  color: rgba(228, 240, 255, .92);
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-preset-thumb,
[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-card-mode-thumb{
  border-color: rgba(125, 187, 244, .34);
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-builder-upload{
  border-color: rgba(90, 160, 220, .24);
  background: linear-gradient(180deg, rgba(15, 31, 53, .78), rgba(10, 22, 39, .74));
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-builder-upload .altum-file-input{
  border-color: rgba(126, 191, 245, .36);
  background: rgba(10, 22, 38, .78);
  color: rgba(225, 238, 255, .9);
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-builder-upload .altum-file-input::file-selector-button,
[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-builder-upload .altum-file-input::-webkit-file-upload-button{
  background: linear-gradient(180deg, rgba(74, 166, 232, .34), rgba(53, 140, 205, .24));
  color: rgba(235, 245, 255, .95);
}

[data-theme-style="dark"] .tp-theme-builder-block .tp-theme-builder-upload .altum-file-input-preview{
  border-color: rgba(125, 187, 244, .34);
  box-shadow: 0 10px 20px -12px rgba(0,0,0,.62);
}

@media (min-width: 1200px){
  .tp-theme-builder-block .tp-theme-preset-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px){
  .tp-theme-builder-block{
    padding: .85rem .82rem .1rem;
  }

  .tp-theme-builder-block .tp-theme-preset-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .72rem;
  }
}

@media (max-width: 575.98px){
  .tp-theme-builder-block .tp-theme-card-mode-grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 410px){
  .tp-theme-builder-block .tp-theme-preset-grid{
    grid-template-columns: 1fr;
  }
}

/* Uploader should keep this section clean, without extra card wrapper. */
#upload_main_dropzone .tp-theme-builder-block{
  margin-top: .35rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}


/* =========================================================
   ADMIN / DASHBOARD – větší sekční nadpisy (h2.small...)
   ========================================================= */

h2.small.font-weight-bold.text-uppercase.text-muted{
    font-size: 0.95rem !important;
    letter-spacing: 0.04em;
    color: #04101A !important;
}

.border-gray-100 {
    border-color: #04101a0f !important;
}

[data-theme-style="dark"] h2.small.font-weight-bold.text-uppercase.text-muted{
    font-size: 0.95rem !important;
    letter-spacing: 0.04em;
    color: hsl(211,25%,71%) !important;
}

[data-theme-style="dark"] .border-gray-100 {
    border-color: #1c2330 !important; 
}


/* =========================================================
   TP CTA HOME
   ========================================================= */

/* 1) Sekce CTA */
.tp-ctahome{
  position: relative;
  padding: 10rem 0;
}

[data-theme-style="dark"] .tp-ctahome{
  position: relative;
  padding: 10rem 0;
}

.tp-ctahome .index-cta h2.h1{
  font-weight: 850 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.08 !important;
  margin-bottom: .8rem !important;
}
.tp-ctahome .index-cta p.h5{
  margin: 0 !important;
  font-weight: 450 !important;
  line-height: 1.45 !important;
}

.tp-ctahome .index-cta{
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,0.55);
  background: linear-gradient(180deg, rgb(255 255 255 / 45%), rgba(255, 255, 255, 0.68));

  backdrop-filter: blur(22px) saturate(1.15);
  -webkit-backdrop-filter: blur(22px) saturate(1.15);

  box-shadow:
    0 30px 70px rgba(0,0,0,0.18),
    0 6px 18px rgba(0,0,0,0.10);

  overflow: hidden;
}

[data-theme-style="dark"] .tp-ctahome .index-cta{
  border-radius: 28px;
  background: linear-gradient(180deg, rgb(0 0 0 / 45%), rgb(0 0 0 / 68%));

  backdrop-filter: blur(22px) saturate(1.15);
  -webkit-backdrop-filter: blur(22px) saturate(1.15);

  box-shadow:
    0 30px 70px rgba(0,0,0,0.18),
    0 6px 18px rgba(0,0,0,0.10);

  overflow: hidden;
}

/* jemný horní highlight (glass feeling) */
.tp-ctahome .index-cta::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0.55),
    rgba(255,255,255,0.15) 45%,
    rgba(255,255,255,0.00) 70%
  );
}

@media (max-width: 991.98px){
  .tp-ctahome{  margin: 2rem 0 2rem;
                padding: 5rem 0;       
  }

}

/* =========================================================
   TP SELFPROMO – footer promo (random)
   ========================================================= */

.tp-selfpromo{
  position: relative;
  z-index: 30;
  margin-top: 5.5rem;
  --tp-selfpromo-bleed: 0rem;
  --tp-selfpromo-edge-padding: 0rem;
  --tp-blue-mid: #238ec8;
  --tp-dashboard-card-radius: 18px;
  --tp-dashboard-card-border: 1px solid rgba(15, 165, 235, .24);
  --tp-dashboard-card-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9);
}

@media (max-width: 991.98px){
  .tp-selfpromo{
    margin-top: 2rem;
    --tp-selfpromo-bleed: 0rem;
  }
}

@media (max-width: 1199.98px) and (min-width: 992px) {
  .tp-selfpromo {
    --tp-selfpromo-bleed: clamp(2rem, 5.5vw, 5rem);
  }
}

@media (min-width: 1400px) {
  .tp-selfpromo {
    --tp-selfpromo-bleed: clamp(14rem, 21vw, 32rem);
    --tp-selfpromo-edge-padding: clamp(.12rem, .35vw, .35rem);
  }
}

.tp-selfpromo > .container.d-print-none > .card {
  position: relative;
  overflow: visible !important;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  max-width: 100vw;
  margin-left: 0;
  margin-right: 0;
  border-color: #0fa5eb !important;
  background: linear-gradient(145deg, #0fa5eb 0%, #0fa5eb 48%, var(--tp-blue-mid) 100%) !important;
  box-shadow: var(--tp-dashboard-card-shadow);
  border-radius: 0 !important;
  border: var(--tp-dashboard-card-border, 1px solid rgba(15, 165, 235, .24)) !important;
}

/* layout */
.tp-selfpromo-content{
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.55rem 1.65rem;
  max-width: 1140px;
  margin-left: auto;
  margin-right: auto;
}

.tp-selfpromo-left{
  flex: 0 0 45%;
  min-width: 0; /* kvůli text-overflow, kdybys někde přidal */
  padding: 0 0 0 1rem;
}

.tp-selfpromo-right{
flex: 1 1 55%;
    position: relative;
    min-height: 200px;
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    pointer-events: none;
}

/* obrázek vyteče nahoru */
.tp-selfpromo-img{
  width: min(500px, 100%);
    height: auto;
    display: block;
}

.tp-selfpromo-title{
  margin: 0 0 1rem 0;
    font-weight: 900;
    letter-spacing: -0.015em;
    line-height: 1.12;
    font-size: 1.8rem;
    color: rgba(255, 255, 255, .96);
}

.tp-selfpromo-text{
  margin: 0 0 1.4rem 0;
    max-width: 62ch;
    color: rgba(235, 246, 255, .92);
    font-size: 1.1rem;
    line-height: 1.5;
}

.tp-selfpromo-actions{
  margin-top: .85rem;
}

/* mobile: stacking */
@media (max-width: 991.98px){
  .tp-selfpromo > .container.d-print-none > .card {
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    max-width: 100vw;
    margin-left: 0;
    margin-right: 0;
    border-radius: 0 !important;
  }

  .tp-selfpromo-content{
    flex-direction: column;
    align-items: flex-start;
    padding: 3rem 2rem;
  }

  .tp-selfpromo-left,
  .tp-selfpromo-right{
    flex: 1 1 auto;
    width: 100%;
            text-align: center;

  }

  .tp-selfpromo-right{
    justify-content: center;
    align-items: flex-end;
    min-height: 0;
    margin-top: 2rem;
  }

  .tp-selfpromo-img{
    width: min(460px, 100%);
  }
}

[data-theme-style="dark"] .tp-selfpromo-title{
  color: rgba(255,255,255,0.92);
}

[data-theme-style="dark"] .tp-selfpromo-text{
  color: rgba(220,230,255,0.68);
}

[data-theme-style="dark"] .tp-selfpromo > .container.d-print-none > .card {
  border-color: rgb(0 0 0 / 18%) !important;
  background: linear-gradient(180deg, rgb(7 22 39), rgb(15 76 129)) !important;
  border-radius: 0 !important;
  box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}



.transfer-preview video{
  width: 100%;
  max-height: 60vh;
  object-fit: contain;
  display: block;
}

.transfer-preview embed,
.transfer-preview iframe,
.transfer-preview img {
    width: 100% !important;
    height: auto;
    max-height: 60vh;
    object-fit: contain;
}

@media (max-width: 768px) {
    .transfer-preview embed,
    .transfer-preview iframe,
    .transfer-preview img {
        max-height: 45vh;
    }
}
 


/* ============================================
   NOTIFICATIONS LIST (PAGE) – Transfer+
   Scope: only list cards in page content
   Targets: .card.mb-5 > .card-body ... .bg-gray-100 items
   ============================================ */

/* Jednotlivá notifikace = item */
.card.mb-5 .bg-gray-100{
  /* z původního bg-gray-100 uděláme “list item card” */
  background: rgba(255,255,255,0.96) !important;
  border: 1px solid rgba(15,165,235,0.14) !important;
  border-radius: 18px !important;

  /* menší spacing, ať to není namačkané */
  padding: 14px 14px !important;
  margin: 10px 0 !important;

  /* jemný stín (žádné ořezy) */
  box-shadow:0 5px 8px rgb(15 23 42 / 3%), 0 0 0 1px rgba(255, 255, 255, 0.65) inset !important;

  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease, background-color .16s ease;

  /* FIX: zabrání “vylití” uvnitř zaoblené karty */
  overflow: hidden;
}

/* “Icon capsule” vlevo */
.card.mb-5 .bg-gray-100 .bg-gray-50{
  background: linear-gradient(
    to bottom,
    rgba(3, 28, 45, 0.06),
    rgba(15,165,235,0.06)
  ) !important;
  border: 1px solid rgba(15,165,235,0.18) !important;
  border-radius: 14px !important;

  /* žádné velké aury */
  box-shadow: 0 0 0 rgba(0,0,0,0) !important;

  /* FIX: ikonový blok se nesmí roztahovat */
  flex: 0 0 auto;
}

/* Ikony – čistě “brand”, bez přepalu */
.card.mb-5 .bg-gray-100 svg{
  color: #0fa5eb !important;
  filter: drop-shadow(0 0 5px rgba(15,165,235,0.18));
}

/* Texty */
.card.mb-5 .bg-gray-100 .text-body,
.card.mb-5 .bg-gray-100 a.text-body{
  color: rgba(15, 23, 42, 0.92) !important;
}

.card.mb-5 .bg-gray-100 .text-muted{
  color: rgba(15, 23, 42, 0.62) !important;
}

/* Title – aby nepůsobil “těžce”, ale byl čitelný */
.card.mb-5 .bg-gray-100 .font-weight-bold{
  font-weight: 750 !important;
  letter-spacing: -0.01em;
}

/* Link v title – hover oranž + underline off */
.card.mb-5 .bg-gray-100 a{
  text-decoration: none !important;
  transition: color .14s ease;
}

/* Čas vpravo – menší a stabilní */
.card.mb-5 .bg-gray-100 small.text-muted{
  white-space: nowrap;
}

/* =========================================================
   ✅ FIX: MOBILE WRAP / OVERFLOW (přetékání textů)
   - klíč: min-width:0 na flex child + wrap textů
   ========================================================= */

/* Flex child (.flex-fill) musí umět “zmenšit se”, jinak text přeteče */
.card.mb-5 .bg-gray-100 .flex-fill{
  min-width: 0 !important;
}

/* Dlouhé názvy souborů/URL se musí zalomit */
.card.mb-5 .bg-gray-100 .font-weight-bold,
.card.mb-5 .bg-gray-100 a.stretched-link,
.card.mb-5 .bg-gray-100 small.text-muted{
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Mobil: přepneme layout na “čas pod text” a dovolíme zalomení času */
@media (max-width: 991.98px){
  .card.mb-5 .bg-gray-100 .d-flex.flex-column.flex-lg-row{
    gap: 6px;
  }

  .card.mb-5 .bg-gray-100 .d-flex.flex-column.flex-lg-row > div:last-child{
    margin-top: 2px;
  }

  /* FIX: na mobilu ať čas klidně zalomí / nebo spadne pod text bez tlačení layoutu */
  .card.mb-5 .bg-gray-100 small.text-muted{
    white-space: normal;
  }
}

/* ============================================
   DARK MODE – stejný pattern jako dropdown
   ============================================ */

[data-theme-style="dark"] .card.mb-5{
  background: linear-gradient(
    to bottom,
    rgba(22, 28, 36, 0.96),
    rgba(14, 18, 24, 0.96)
  ) !important;

  border: 1px solid rgba(255,255,255,0.08) !important;
  box-shadow:
    0 18px 44px rgba(0,0,0,0.72),
    0 0 0 1px rgba(255,255,255,0.05) inset !important;
}

[data-theme-style="dark"] .card.mb-5 .bg-gray-100{
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(60,180,255,0.16) !important;

  box-shadow:
    0 10px 22px rgba(0,0,0,0.55),
    0 0 0 1px rgba(255,255,255,0.04) inset !important;

  /* FIX zůstává i v darku */
  overflow: hidden;
}

[data-theme-style="dark"] .card.mb-5 .bg-gray-100:hover{
  border-color: rgba(255,133,3,0.38) !important;
  box-shadow:
    0 14px 30px rgba(0,0,0,0.62),
    0 0 0 1px rgba(255,133,3,0.16) inset !important;
}

[data-theme-style="dark"] .card.mb-5 .bg-gray-100 .bg-gray-50{
  background: rgba(60,180,255,0.08) !important;
  border: 1px solid rgba(60,180,255,0.18) !important;

  /* FIX */
  flex: 0 0 auto;
}

[data-theme-style="dark"] .card.mb-5 .bg-gray-100 svg{
  color: #3cb4ff !important;
  filter: drop-shadow(0 0 5px rgba(60,180,255,0.22));
}

[data-theme-style="dark"] .card.mb-5 .bg-gray-100 .text-body,
[data-theme-style="dark"] .card.mb-5 .bg-gray-100 a.text-body{
  color: rgba(235, 240, 245, 0.92) !important;
}

[data-theme-style="dark"] .card.mb-5 .bg-gray-100 .text-muted{
  color: rgba(235, 240, 245, 0.62) !important;
}

/* =========================================================
   TRON FORMS – SWITCH + CHECKBOX + BADGES (LIGHT + DARK)
   - Safe scoped selectors (no collisions)
   - Checkbox uses custom checkmark SVG (always visible)
   ========================================================= */


/* =========================================================
   CUSTOM SWITCH (LIGHT)
   Works with: .custom-control.custom-switch
   ========================================================= */

/* Track */
.custom-control.custom-switch .custom-control-label::before{
  background-color: rgba(15, 23, 42, 0.18);
  border: 1px solid rgba(15, 23, 42, 0.25);
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.15);
  transition: all .18s ease;
}

/* Knob */
.custom-control.custom-switch .custom-control-label::after{
  background-color: #ffffff;
  box-shadow: 0 2px 5px rgba(0,0,0,0.25);
  transition: all .18s ease;
}

/* Enabled OFF */
.custom-control.custom-switch
.custom-control-input:not(:disabled):not(:checked)
+ .custom-control-label::before{
  background-color: rgba(15, 23, 42, 0.22);
  border-color: rgba(15, 23, 42, 0.28);
}

/* Hover (enabled only) */
.custom-control.custom-switch
.custom-control-input:not(:disabled)
+ .custom-control-label:hover::before{
  background-color: rgba(15, 165, 235, 0.18);
  border-color: rgba(15, 165, 235, 0.35);
}

/* Enabled ON */
.custom-control.custom-switch
.custom-control-input:checked:not(:disabled)
+ .custom-control-label::before{
  background: linear-gradient(to bottom, #3bbcff, #0fa5eb);
  border-color: rgba(15, 165, 235, 0.55);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.45),
    0 0 0 1px rgba(15,165,235,0.35),
    0 0 12px rgba(15,165,235,0.45);
}

/* Knob ON */
.custom-control.custom-switch
.custom-control-input:checked:not(:disabled)
+ .custom-control-label::after{
  background-color: #ffffff;
  box-shadow:
    0 3px 6px rgba(0,0,0,0.35),
    0 0 6px rgba(15,165,235,0.45);
}

/* Disabled */
.custom-control.custom-switch
.custom-control-input:disabled
+ .custom-control-label{
  cursor: not-allowed;
  opacity: .55;
}

.custom-control.custom-switch
.custom-control-input:disabled
+ .custom-control-label::before{
  background-color: rgba(15, 23, 42, 0.12);
  border-color: rgba(15, 23, 42, 0.18);
  box-shadow: inset 0 1px 1px rgba(0,0,0,0.10);
}

.custom-control.custom-switch
.custom-control-input:disabled
+ .custom-control-label::after{
  background-color: #f1f3f5;
  box-shadow: none;
}

/* Text under switch */
.custom-control.custom-switch
.custom-control-input:disabled
~ .form-text{
  opacity: .55;
}


/* =========================================================
   CUSTOM SWITCH (DARK)
   Works with: [data-theme-style="dark"] .custom-control.custom-switch
   ========================================================= */

[data-theme-style="dark"] .custom-control.custom-switch .custom-control-label::before{
  background-color: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.18);
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.45);
}

[data-theme-style="dark"] .custom-control.custom-switch .custom-control-label::after{
  background-color: #e5e7eb;
  box-shadow: 0 2px 6px rgba(0,0,0,0.65);
}

/* Enabled OFF (dark) */
[data-theme-style="dark"] .custom-control.custom-switch
.custom-control-input:not(:disabled):not(:checked)
+ .custom-control-label::before{
  background-color: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.22);
}

/* Hover (dark, enabled only) */
[data-theme-style="dark"] .custom-control.custom-switch
.custom-control-input:not(:disabled)
+ .custom-control-label:hover::before{
  background-color: rgba(60,180,255,0.20);
  border-color: rgba(60,180,255,0.35);
}

/* Enabled ON (dark) */
[data-theme-style="dark"] .custom-control.custom-switch
.custom-control-input:checked:not(:disabled)
+ .custom-control-label::before{
  background: linear-gradient(to bottom, #3cb4ff, #0fa5eb);
  border-color: rgba(60,180,255,0.55);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.25),
    0 0 0 1px rgba(60,180,255,0.35),
    0 0 16px rgba(60,180,255,0.45);
}

[data-theme-style="dark"] .custom-control.custom-switch
.custom-control-input:checked:not(:disabled)
+ .custom-control-label::after{
  background-color: #ffffff;
  box-shadow:
    0 3px 8px rgba(0,0,0,0.75),
    0 0 8px rgba(60,180,255,0.55);
}

/* Disabled (dark) */
[data-theme-style="dark"] .custom-control.custom-switch
.custom-control-input:disabled
+ .custom-control-label{
  opacity: .45;
  cursor: not-allowed;
}

[data-theme-style="dark"] .custom-control.custom-switch
.custom-control-input:disabled
+ .custom-control-label::before{
  background-color: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
  box-shadow: inset 0 1px 1px rgba(0,0,0,0.5);
}

[data-theme-style="dark"] .custom-control.custom-switch
.custom-control-input:disabled
+ .custom-control-label::after{
  background-color: rgba(255,255,255,0.75);
  box-shadow: none;
}

[data-theme-style="dark"] .custom-control.custom-switch
.custom-control-input:disabled
~ .form-text{
  opacity: .45;
}


/* =========================================================
   CUSTOM CHECKBOX (LIGHT)
   Works with: .custom-control.custom-checkbox
   Uses custom checkmark SVG on ::after (always visible)
   ========================================================= */

/* Base box */
.custom-control.custom-checkbox .custom-control-label::before{
  border-radius: .55rem !important;
  background: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(15,165,235,0.22) !important;

  box-shadow:
    0 6px 14px rgba(0,0,0,0.06),
    0 0 0 1px rgba(255,255,255,0.70) inset,
    0 0 12px rgba(15,165,235,0.10) !important;

  transition: all .16s ease;
}

/* Make label clickable */
.custom-control.custom-checkbox .custom-control-label{
  cursor: pointer;
}

/* Hover (enabled only) */
.custom-control.custom-checkbox
.custom-control-input:not(:disabled)
+ .custom-control-label:hover::before{
  border-color: rgba(15,165,235,0.40) !important;
  box-shadow:
    0 10px 22px rgba(0,0,0,0.10),
    0 0 0 1px rgba(15,165,235,0.18) inset,
    0 0 16px rgba(15,165,235,0.18) !important;
}

/* Focus (keyboard) */
.custom-control.custom-checkbox
.custom-control-input:focus
+ .custom-control-label::before{
  box-shadow:
    0 0 0 3px rgba(15,165,235,0.18),
    0 10px 22px rgba(0,0,0,0.10),
    0 0 16px rgba(15,165,235,0.18) !important;
}

/* Checked box */
.custom-control.custom-checkbox
.custom-control-input:checked
+ .custom-control-label::before{
  background: linear-gradient(to bottom, #3bbcff, #0fa5eb) !important;
  border-color: rgba(15,165,235,0.55) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.40),
    0 0 0 1px rgba(15,165,235,0.30),
    0 0 16px rgba(15,165,235,0.40) !important;
}

/* === Custom checkmark (SVG) – always visible === */
.custom-control.custom-checkbox .custom-control-label::after{
  transition: all .16s ease;
}

/* When checked, paint our own checkmark */
.custom-control.custom-checkbox
.custom-control-input:checked
+ .custom-control-label::after{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%23ffffff' d='M6.2 11.3 2.9 8a1 1 0 1 1 1.4-1.4l2 2 5-5A1 1 0 1 1 12.7 4l-5.8 7.3a1 1 0 0 1-1.5 0z'/%3E%3C/svg%3E") !important;
  background-size: 0.85rem 0.85rem !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  filter: drop-shadow(0 0 6px rgba(15,165,235,0.25));
}

/* Disabled */
.custom-control.custom-checkbox
.custom-control-input:disabled
+ .custom-control-label{
  cursor: not-allowed;
  opacity: .55;
}

.custom-control.custom-checkbox
.custom-control-input:disabled
+ .custom-control-label::before{
  background: rgba(15, 23, 42, 0.07) !important;
  border-color: rgba(15, 23, 42, 0.12) !important;
  box-shadow: inset 0 1px 1px rgba(0,0,0,0.08) !important;
}

.custom-control.custom-checkbox
.custom-control-input:disabled:checked
+ .custom-control-label::before{
  background: rgba(15,165,235,0.30) !important;
  border-color: rgba(15,165,235,0.22) !important;
  box-shadow: none !important;
}

.custom-control.custom-checkbox
.custom-control-input:disabled:checked
+ .custom-control-label::after{
  opacity: .85;
  filter: none;
}


/* =========================================================
   BADGE in checkbox label (LIGHT)
   Example: <small class="badge badge-light badge-pill">E-mail</small>
   ========================================================= */

.custom-control.custom-checkbox .custom-control-label .badge.badge-light.badge-pill{
  background: rgba(15,165,235,0.10) !important;
  border: 1px solid rgba(15,165,235,0.22) !important;
  color: rgba(15, 23, 42, 0.88) !important;

  border-radius: 999px !important;
  padding: .22rem .55rem !important;
  font-weight: 600;
  letter-spacing: .2px;

  box-shadow:
    0 6px 14px rgba(0,0,0,0.06),
    0 0 12px rgba(15,165,235,0.10) !important;
}

.custom-control.custom-checkbox
.custom-control-input:checked
+ .custom-control-label .badge.badge-light.badge-pill{
  background: rgba(15,165,235,0.16) !important;
  border-color: rgba(15,165,235,0.35) !important;
  box-shadow:
    0 10px 22px rgba(0,0,0,0.10),
    0 0 14px rgba(15,165,235,0.16) !important;
}


/* =========================================================
   CUSTOM CHECKBOX (DARK) + BADGE (DARK)
   ========================================================= */

[data-theme-style="dark"] .custom-control.custom-checkbox .custom-control-label::before{
  background: rgba(255,255,255,0.05) !important;
  border-color: rgba(60,180,255,0.18) !important;
  box-shadow:
    0 10px 24px rgba(0,0,0,0.55),
    0 0 0 1px rgba(255,255,255,0.04) inset,
    0 0 14px rgba(60,180,255,0.10) !important;
}

[data-theme-style="dark"] .custom-control.custom-checkbox
.custom-control-input:not(:disabled)
+ .custom-control-label:hover::before{
  border-color: rgba(60,180,255,0.35) !important;
  box-shadow:
    0 14px 30px rgba(0,0,0,0.62),
    0 0 0 1px rgba(60,180,255,0.14) inset,
    0 0 18px rgba(60,180,255,0.16) !important;
}

[data-theme-style="dark"] .custom-control.custom-checkbox
.custom-control-input:focus
+ .custom-control-label::before{
  box-shadow:
    0 0 0 3px rgba(60,180,255,0.16),
    0 14px 30px rgba(0,0,0,0.62),
    0 0 18px rgba(60,180,255,0.16) !important;
}

[data-theme-style="dark"] .custom-control.custom-checkbox
.custom-control-input:checked
+ .custom-control-label::before{
  background: linear-gradient(to bottom, #3cb4ff, #0fa5eb) !important;
  border-color: rgba(60,180,255,0.55) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.20),
    0 0 0 1px rgba(60,180,255,0.28),
    0 0 18px rgba(60,180,255,0.40) !important;
}

/* Checkmark (dark) – same SVG, just stronger glow */
[data-theme-style="dark"] .custom-control.custom-checkbox
.custom-control-input:checked
+ .custom-control-label::after{
  filter: drop-shadow(0 0 7px rgba(60,180,255,0.30));
}

[data-theme-style="dark"] .custom-control.custom-checkbox
.custom-control-input:disabled
+ .custom-control-label{
  opacity: .45;
}

[data-theme-style="dark"] .custom-control.custom-checkbox
.custom-control-input:disabled
+ .custom-control-label::before{
  background: rgba(255,255,255,0.03) !important;
  border-color: rgba(255,255,255,0.10) !important;
  box-shadow: inset 0 1px 1px rgba(0,0,0,0.55) !important;
}

[data-theme-style="dark"] .custom-control.custom-checkbox
.custom-control-input:disabled:checked
+ .custom-control-label::before{
  background: rgba(60,180,255,0.18) !important;
  border-color: rgba(60,180,255,0.16) !important;
  box-shadow: none !important;
}

/* Badge (dark) */
[data-theme-style="dark"] .custom-control.custom-checkbox .custom-control-label .badge.badge-light.badge-pill{
  background: rgba(60,180,255,0.14) !important;
  border-color: rgba(60,180,255,0.22) !important;
  color: rgba(235, 240, 245, 0.90) !important;
  box-shadow:
    0 12px 26px rgba(0,0,0,0.55),
    0 0 14px rgba(60,180,255,0.14) !important;
}

[data-theme-style="dark"] .custom-control.custom-checkbox
.custom-control-input:checked
+ .custom-control-label .badge.badge-light.badge-pill{
  background: rgba(60,180,255,0.20) !important;
  border-color: rgba(60,180,255,0.30) !important;
  box-shadow:
    0 14px 30px rgba(0,0,0,0.62),
    0 0 18px rgba(60,180,255,0.18) !important;
}

/* === Transfer Download Theme (Custom) START === */
body.tp-download-theme,
body.tp-download-theme[data-theme-style="light"],
body.tp-download-theme[data-theme-style="dark"] {
    min-height: 100vh;
    background: var(--tp-bg) !important;
    color: var(--tp-text) !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    background-attachment: fixed !important;
}

body.tp-download-theme .tp-download-page .card {
    background: var(--tp-card-bg) !important;
    border: 1px solid var(--tp-card-border) !important;
    backdrop-filter: var(--tp-card-backdrop, none) !important;
    -webkit-backdrop-filter: var(--tp-card-backdrop, none) !important;
    box-shadow: var(--tp-shadow, 0 12px 28px rgba(15,23,42,.18)) !important;
    color: var(--tp-text) !important;
}

body.tp-download-theme .tp-download-page .card * {
    color: inherit;
}

body.tp-download-theme .tp-download-page .text-muted {
    color: var(--tp-muted) !important;
}

body.tp-download-theme .tp-download-page .text-primary {
    color: var(--tp-accent) !important;
}

body.tp-download-theme .tp-download-page .tp-download-meta-row,
body.tp-download-theme .tp-download-page .tp-download-meta-row *,
body.tp-download-theme .tp-download-page .row.text-muted.small,
body.tp-download-theme .tp-download-page .row.text-muted.small * {
    color: var(--tp-muted) !important;
}

body.tp-download-theme .tp-download-page .tp-download-meta-row {
    margin-top: 1.15rem;
    gap: .55rem;
    padding: 0;
    margin-left: 0 !important;
    margin-right: 0 !important;
    display: flex;
    flex-wrap: wrap;
}

body.tp-download-theme .tp-download-page .tp-download-controls-panel {
    margin-top: 1rem;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: .62rem;
    padding: .94rem .92rem .88rem;
    border-radius: 1rem;
    border: 1px solid var(--tp-soft-border);
    background: var(--tp-soft-bg);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.28);
    font-size: .82rem;
}

body.tp-download-theme .tp-download-page .tp-download-controls-title {
    display: block;
    font-size: .72rem;
    letter-spacing: .04em;
    text-transform: uppercase;
    opacity: .75;
    line-height: 1;
    margin: 0;
}

body.tp-download-theme .tp-download-page .tp-download-controls-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .72rem;
    flex-wrap: wrap;
}

body.tp-download-theme .tp-download-page .tp-download-controls-chips {
    display: flex;
    align-items: center;
    gap: .58rem;
    flex-wrap: wrap;
}

body.tp-download-theme .tp-download-page .tp-download-controls-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: .6rem;
    flex-wrap: nowrap;
    min-width: 0;
}

body.tp-download-theme .tp-download-page .tp-download-control-chip {
    display: inline-flex;
    align-items: center;
    gap: .42rem;
    min-height: 1.94rem;
    padding: .38rem .64rem .38rem .58rem;
    border-radius: 999px;
    border: 1px solid var(--tp-soft-border);
    background: rgba(255,255,255,.16);
    white-space: nowrap;
    font-size: .82rem;
    line-height: 1.15;
}

body.tp-download-theme[data-theme-style="dark"] .tp-download-page .tp-download-control-chip {
    background: rgba(9,14,24,.22);
}

body.tp-download-theme .tp-download-page .tp-download-chip-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: .86rem;
}

body.tp-download-theme .tp-download-page .tp-download-chip-icon .svg-inline--fa,
body.tp-download-theme .tp-download-page .tp-download-chip-icon i {
    font-size: .76rem;
    line-height: 1;
    vertical-align: middle;
    opacity: .86;
}

body.tp-download-theme .tp-download-page .tp-download-chip-text {
    display: inline-flex;
    align-items: center;
    line-height: 1.12;
}

body.tp-download-theme .tp-download-page .tp-download-controls-sort {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: flex-end;
    gap: .6rem;
    min-width: 0;
    flex-wrap: nowrap;
}

body.tp-download-theme .tp-download-page .tp-download-view-toggle {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--tp-soft-border);
    border-radius: 999px;
    background: rgba(255,255,255,.16);
    overflow: hidden;
}

body.tp-download-theme[data-theme-style="dark"] .tp-download-page .tp-download-view-toggle {
    background: rgba(9,14,24,.22);
}

body.tp-download-theme .tp-download-page .tp-download-view-btn {
    border: 0;
    background: transparent;
    color: var(--tp-text) !important;
    font-size: .86rem;
    line-height: 1;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 1.9rem;
    cursor: pointer;
    opacity: .9;
}

body.tp-download-theme .tp-download-page .tp-download-view-btn .svg-inline--fa,
body.tp-download-theme .tp-download-page .tp-download-view-btn i {
    color: var(--tp-text) !important;
    opacity: 1;
}

body.tp-download-theme .tp-download-page .tp-download-view-btn + .tp-download-view-btn {
    border-left: 1px solid var(--tp-soft-border);
}

body.tp-download-theme .tp-download-page .tp-download-view-btn.is-active {
    background: rgba(255,255,255,.28);
    opacity: 1;
}

body.tp-download-theme[data-theme-style="dark"] .tp-download-page .tp-download-view-btn.is-active {
    background: rgba(255,255,255,.1);
}

body.tp-download-theme .tp-download-page .tp-download-summary-row {
    background: var(--tp-soft-bg) !important;
    border: 1px solid var(--tp-soft-border) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.35) !important;
    color: var(--tp-text) !important;
    border-radius: 999px !important;
    padding: 0.55rem .85rem !important;
    margin-bottom: 1rem !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

body.tp-download-theme .tp-download-page .bg-gray-100 {
    background: var(--tp-soft-bg) !important;
    border-color: var(--tp-soft-border) !important;
}

body.tp-download-theme .tp-download-page .badge.badge-light {
    background: var(--tp-soft-bg) !important;
    border: 1px solid var(--tp-soft-border) !important;
    color: var(--tp-text) !important;
}

body.tp-download-theme .tp-download-page .tp-download-summary-row .text-muted,
body.tp-download-theme .tp-download-page .tp-download-summary-row .svg-inline--fa,
body.tp-download-theme .tp-download-page .tp-download-summary-row i {
    color: var(--tp-text) !important;
}

body.tp-download-theme .tp-download-page .tp-download-meta-row .svg-inline--fa,
body.tp-download-theme .tp-download-page .tp-download-meta-row i,
body.tp-download-theme .tp-download-page .row.text-muted.small .svg-inline--fa,
body.tp-download-theme .tp-download-page .row.text-muted.small i {
    color: var(--tp-text) !important;
    opacity: .84;
}

body.tp-download-theme .tp-download-page .tp-download-meta-row > .col-auto,
body.tp-download-theme .tp-download-page .row.text-muted.small > .col-auto {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    background: var(--tp-soft-bg) !important;
    border: 1px solid var(--tp-soft-border) !important;
    border-radius: 999px;
    padding: .46rem .8rem;
    min-height: 2.28rem;
    white-space: nowrap;
    margin: 0 !important;
    max-width: 100%;
}

body.tp-download-theme .tp-download-page .tp-download-sort-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 400;
    font-size: .76rem;
    opacity: .9;
    white-space: nowrap;
    min-width: 1rem;
    color: var(--tp-text);
}

body.tp-download-theme .tp-download-page .tp-download-sort-group {
    display: inline-flex;
    align-items: center;
    gap: .36rem;
    white-space: nowrap;
    flex: 0 0 auto;
    justify-content: flex-end;
}

body.tp-download-theme .tp-download-page .tp-download-sort-group .custom-select {
    min-width: 102px;
    width: 102px;
    height: 1.88rem;
    border-radius: 999px;
    border: 1px solid var(--tp-soft-border) !important;
    background-color: rgba(255,255,255,.26) !important;
    color: var(--tp-text) !important;
    font-size: .79rem;
    font-weight: 400;
    line-height: 1.25;
    padding: .18rem 1.5rem .18rem .5rem !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
}

body.tp-download-theme .tp-download-page .tp-download-sort-group .custom-select:focus {
    border-color: var(--tp-accent) !important;
    box-shadow: 0 0 0 .18rem rgba(15,165,235,.14), inset 0 1px 0 rgba(255,255,255,.35) !important;
}

body.tp-download-theme[data-theme-style="dark"] .tp-download-page .tp-download-sort-group .custom-select {
    background-color: rgba(9,14,24,.28) !important;
}

body.tp-download-theme .tp-download-page #tp_download_files_list {
    display: flex;
    flex-direction: column;
    gap: .68rem;
}

body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .9rem;
    align-items: start;
}

body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] [data-file-entry] {
    border: 1px solid var(--tp-soft-border);
    border-radius: .9rem;
    background: var(--tp-soft-bg);
    padding: .58rem .62rem;
    box-shadow: 0 10px 24px rgba(15,23,42,.06), inset 0 1px 0 rgba(255,255,255,.30);
    overflow: hidden;
}

body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] .tp-download-file-row {
    margin: 0 0 .44rem !important;
    padding: .12rem .22rem;
}

body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] .row.align-items-center.mb-5 {
    margin-bottom: 0 !important;
}

body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] .transfer-preview img,
body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] .transfer-preview video {
    width: 100%;
    height: 210px;
    object-fit: cover;
}

body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) [data-file-entry] {
    border: 1px solid var(--tp-soft-border);
    border-radius: 1rem;
    background: var(--tp-soft-bg);
    padding: .46rem .58rem;
    box-shadow: 0 8px 18px rgba(15,23,42,.04), inset 0 1px 0 rgba(255,255,255,.26);
    overflow: hidden;
}

body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) [data-file-entry]:hover {
    border-color: var(--tp-soft-border);
    box-shadow: 0 8px 18px rgba(15,23,42,.04), inset 0 1px 0 rgba(255,255,255,.26);
}

body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) .row.align-items-center.mb-5 {
    margin: .42rem 0 .05rem !important;
}

body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) .transfer-preview {
    overflow: hidden;
    border-radius: .9rem;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
}

body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) .transfer-preview img,
body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) .transfer-preview video,
body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) .transfer-preview embed,
body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) .transfer-preview iframe {
    border-radius: .9rem !important;
    border: 0 !important;
    background: transparent;
    box-shadow: none;
}

body.tp-download-theme .tp-download-page [data-file-entry] {
    border-radius: 1rem;
    transition: box-shadow .15s ease, border-color .15s ease;
}

body.tp-download-theme .tp-download-page [data-file-entry]:focus-within {
    box-shadow: 0 0 0 .18rem rgba(15,165,235,.14), 0 10px 24px rgba(15,23,42,.06), inset 0 1px 0 rgba(255,255,255,.32);
}

body.tp-download-theme .tp-download-page .tp-download-file-row {
    min-height: 2.75rem;
    padding: .32rem .46rem;
    border-radius: .82rem;
    border: 0;
    transition: color .15s ease;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

body.tp-download-theme .tp-download-page .tp-download-file-row > .col.d-flex {
    min-width: 0;
}

body.tp-download-theme .tp-download-page .tp-download-file-row > .col.d-flex > .text-truncate {
    min-width: 0;
    display: block;
}

body.tp-download-theme .tp-download-page .tp-download-file-row:hover {
    background: transparent !important;
}

body.tp-download-theme .tp-download-page .btn-primary,
body.tp-download-theme .tp-download-page .btn-outline-primary {
    border-color: var(--tp-button-bg) !important;
    background: var(--tp-button-bg) !important;
    color: var(--tp-button-text) !important;
    box-shadow: 0 12px 26px rgba(15,23,42,.12), inset 0 1px 0 rgba(255,255,255,.22) !important;
    padding: .88rem .85rem !important;
    border-radius: 0.9rem;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    display: block !important;
    font-weight: 750;
    letter-spacing: .01em;
    transition: filter .15s ease, transform .15s ease, box-shadow .15s ease;
}

body.tp-download-theme .tp-download-page .btn-primary .svg-inline--fa {
    color: inherit !important;
}

body.tp-download-theme .tp-download-page [data-download-button] .svg-inline--fa {
    color: var(--tp-text) !important;
    opacity: .9;
}

body.tp-download-theme .tp-download-page .tp-download-file-button {
    width: 1.9rem;
    height: 1.9rem;
    min-width: 1.9rem;
    padding: 0 !important;
    margin: 0 .18rem !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: .68rem;
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.12);
    transition: background-color .15s ease, border-color .15s ease, color .15s ease;
}

body.tp-download-theme[data-theme-style="dark"] .tp-download-page .tp-download-file-button {
    background: rgba(9,14,24,.22);
    border-color: rgba(255,255,255,.08);
}

body.tp-download-theme .tp-download-page .tp-download-file-button:hover {
    background: rgba(255,255,255,.26);
    border-color: var(--tp-soft-border);
}

body.tp-download-theme .tp-download-page .tp-download-file-button:hover .svg-inline--fa {
    color: var(--tp-accent-alt) !important;
}

body.tp-download-theme .tp-download-page a,
body.tp-download-theme footer a,
body.tp-download-theme footer .btn-link,
body.tp-download-theme footer .text-muted a {
    color: var(--tp-accent-alt) !important;
}

body.tp-download-theme.tp-preset-transferplus[data-theme-style="light"] {
    --tp-soft-bg: #eef3f6;
    --tp-soft-border: #cfdce6;
    --tp-row-hover: #e8f1f7;
}

/* Transfer+ preset specific download summary styling */
body.tp-download-theme.tp-preset-transferplus .tp-download-page .bg-gray-100 {
    background: #30a5ea !important;
    border-color: #1289cf !important;
}

body.tp-download-theme.tp-preset-transferplus .tp-download-page .bg-gray-100,
body.tp-download-theme.tp-preset-transferplus .tp-download-page .bg-gray-100 .text-muted,
body.tp-download-theme.tp-preset-transferplus .tp-download-page .bg-gray-100 i,
body.tp-download-theme.tp-preset-transferplus .tp-download-page .bg-gray-100 .svg-inline--fa,
body.tp-download-theme.tp-preset-transferplus .tp-download-page .tp-download-summary-row,
body.tp-download-theme.tp-preset-transferplus .tp-download-page .tp-download-summary-row .text-muted,
body.tp-download-theme.tp-preset-transferplus .tp-download-page .tp-download-summary-row i,
body.tp-download-theme.tp-preset-transferplus .tp-download-page .tp-download-summary-row .svg-inline--fa {
    color: #fff !important;
}

body.tp-download-theme.tp-preset-blue[data-theme-style="light"] {
    --tp-soft-bg: rgba(34, 154, 242, .16);
    --tp-soft-border: rgba(6, 122, 214, .52);
    --tp-row-hover: rgba(6, 122, 214, .2);
}

body.tp-download-theme.tp-preset-pink[data-theme-style="light"] {
    --tp-soft-bg: rgba(233, 31, 160, .16);
    --tp-soft-border: rgba(214, 10, 146, .5);
    --tp-row-hover: rgba(214, 10, 146, .2);
}

body.tp-download-theme.tp-preset-purple[data-theme-style="light"] {
    --tp-soft-bg: rgba(126, 76, 235, .16);
    --tp-soft-border: rgba(108, 57, 220, .52);
    --tp-row-hover: rgba(108, 57, 220, .2);
}

body.tp-download-theme.tp-preset-emerald[data-theme-style="light"] {
    --tp-soft-bg: rgba(19, 170, 117, .16);
    --tp-soft-border: rgba(10, 149, 100, .5);
    --tp-row-hover: rgba(10, 149, 100, .2);
}

body.tp-download-theme.tp-preset-slate[data-theme-style="light"] {
    --tp-soft-bg: rgba(78, 102, 138, .16);
    --tp-soft-border: rgba(58, 79, 112, .5);
    --tp-row-hover: rgba(58, 79, 112, .2);
}

body.tp-download-theme.tp-preset-transferplus[data-theme-style="dark"] {
    --tp-soft-bg: rgba(9, 20, 30, .58);
    --tp-soft-border: rgba(39, 76, 102, .72);
    --tp-row-hover: rgba(14, 33, 48, .78);
}

body.tp-download-theme.tp-preset-blue[data-theme-style="dark"] {
    --tp-soft-bg: rgba(11, 42, 72, .62);
    --tp-soft-border: rgba(60, 136, 206, .62);
    --tp-row-hover: rgba(16, 56, 94, .82);
}

body.tp-download-theme.tp-preset-pink[data-theme-style="dark"] {
    --tp-soft-bg: rgba(70, 22, 62, .62);
    --tp-soft-border: rgba(168, 78, 149, .66);
    --tp-row-hover: rgba(88, 29, 79, .82);
}

body.tp-download-theme.tp-preset-purple[data-theme-style="dark"] {
    --tp-soft-bg: rgba(42, 28, 76, .62);
    --tp-soft-border: rgba(120, 98, 189, .66);
    --tp-row-hover: rgba(54, 36, 95, .82);
}

body.tp-download-theme.tp-preset-emerald[data-theme-style="dark"] {
    --tp-soft-bg: rgba(17, 54, 40, .62);
    --tp-soft-border: rgba(78, 151, 120, .66);
    --tp-row-hover: rgba(22, 68, 50, .82);
}

body.tp-download-theme.tp-preset-slate[data-theme-style="dark"] {
    --tp-soft-bg: rgba(27, 42, 62, .62);
    --tp-soft-border: rgba(86, 114, 149, .66);
    --tp-row-hover: rgba(34, 53, 78, .82);
}

body.tp-download-theme .transfer-logo {
    filter: none !important;
}

body.tp-download-theme .tp-download-page .btn-outline-primary:hover,
body.tp-download-theme .tp-download-page .btn-primary:hover {
    filter: brightness(.96);
    box-shadow: 0 16px 34px rgba(15,23,42,.16), inset 0 1px 0 rgba(255,255,255,.24) !important;
}

@media (max-width: 768px) {
    body.tp-download-theme .tp-download-page .card.py-6 {
        padding-top: 1.15rem !important;
        padding-bottom: 1.15rem !important;
    }

    body.tp-download-theme .tp-download-page .card .card-body {
        padding: 0.5rem 1.5rem !important;
    }

    body.tp-download-theme .tp-download-page .card {
        border-radius: 1rem !important;
    }

    body.tp-download-theme .tp-download-page h1.h3 {
        font-size: 1.5rem !important;
        line-height: 1.2 !important;
    }

    body.tp-download-theme .tp-download-page .tp-download-meta-row {
        gap: .45rem;
    }

    body.tp-download-theme .tp-download-page .tp-download-meta-row > .col-auto,
    body.tp-download-theme .tp-download-page .row.text-muted.small > .col-auto {
        width: auto;
        justify-content: flex-start;
        padding: .46rem .8rem;
    }

    body.tp-download-theme .tp-download-page .tp-download-controls-panel {
        padding: .78rem .64rem .72rem;
        gap: .56rem;
    }

    body.tp-download-theme .tp-download-page .tp-download-controls-meta {
        width: 100%;
        order: 0;
        justify-content: flex-start;
        gap: .58rem;
    }

    body.tp-download-theme .tp-download-page .tp-download-controls-actions {
        width: 100%;
        justify-content: flex-start;
        gap: .46rem;
        flex-wrap: nowrap;
        margin-top: .05rem;
    }

    body.tp-download-theme .tp-download-page .tp-download-sort-group {
        display: inline-flex;
        align-items: center;
        gap: .28rem;
        flex-wrap: nowrap;
        white-space: nowrap;
    }

    body.tp-download-theme .tp-download-page .tp-download-summary-row {
        border-radius: .95rem !important;
        padding: .55rem .72rem !important;
    }

    body.tp-download-theme .tp-download-page .tp-download-file-row {
        min-height: 2.55rem;
        padding-left: .22rem;
        padding-right: .22rem;
    }

    body.tp-download-theme .tp-download-page #tp_download_files_list:not([data-view="grid"]) [data-file-entry] {
        padding: .36rem .44rem;
        border-radius: .88rem;
    }

    body.tp-download-theme .tp-download-page .tp-download-file-row > .col.d-flex {
        min-width: 0;
    }

    body.tp-download-theme .tp-download-page .tp-download-file-row > .col.d-flex > .text-truncate {
        min-width: 0;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    body.tp-download-theme .tp-download-page .btn-primary,
    body.tp-download-theme .tp-download-page .btn-outline-primary {
        padding: .88rem .72rem !important;
    }

    body.tp-download-theme .tp-download-page .tp-download-sort-group .custom-select {
        width: 98px;
        min-width: 98px;
    }

    body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] {
        grid-template-columns: 1fr;
        gap: .72rem;
    }

    body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] .transfer-preview img,
    body.tp-download-theme .tp-download-page #tp_download_files_list[data-view="grid"] .transfer-preview video {
        height: auto;
    }

    body.tp-download-theme,
    body.tp-download-theme[data-theme-style="light"],
    body.tp-download-theme[data-theme-style="dark"] {
        background-attachment: scroll !important;
    }
}
/* === Transfer Download Theme (Custom) END === */

/* Transfer download logo spacing */
body.tp-download-theme .tp-download-brand {
    margin-bottom: 2.25rem !important;
}

body.tp-download-theme .tp-brand-logo {
    height: 2.45rem !important;
    max-height: 2.45rem !important;
    width: auto !important;
    max-width: 100% !important;
    object-fit: contain;
    display: block;
    margin: 0 auto !important;
}

body.tp-download-theme .tp-download-brand > a {
    display: inline-flex;
    justify-content: center;
    width: 100%;
}

/* ============================================
   INTERNAL NOTIFICATIONS (dropdown + page)
   ============================================ */

nav.navbar #internal_notifications_content .tp-internal-notification-item {
    margin: 0 0 1rem;
}

nav.navbar #internal_notifications_content .tp-internal-notification-item:last-of-type {
    margin-bottom: .72rem;
}

nav.navbar #internal_notifications_content .tp-internal-notification-item-inner {
    display: flex;
    align-items: flex-start;
    gap: 1.2rem;
    padding: 1.2rem 1.24rem;
    border-radius: 1.02rem;
    border: 1px solid rgba(15, 165, 235, .16);
    background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(248, 252, 255, .97));
    box-shadow: 0 3px 8px rgba(6, 16, 34, .05), inset 0 1px 0 rgba(255, 255, 255, .92);
}

nav.navbar #internal_notifications_content .tp-internal-notification-item.is-unread .tp-internal-notification-item-inner {
    border-color: rgba(15, 165, 235, .34);
    background: linear-gradient(180deg, rgba(232, 246, 255, .8), rgba(248, 252, 255, .98));
}

nav.navbar #internal_notifications_content .tp-internal-notification-icon-wrap {
    flex: 0 0 auto;
}

nav.navbar #internal_notifications_content .tp-internal-notification-icon-box {
    width: 3rem;
    height: 3rem;
    border-radius: .9rem;
    border: 1px solid rgba(15, 165, 235, .2);
    background: linear-gradient(180deg, rgba(242, 250, 255, .95), rgba(230, 245, 255, .9));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #0fa5eb;
}

nav.navbar #internal_notifications_content .tp-internal-notification-icon-box i,
nav.navbar #internal_notifications_content .tp-internal-notification-icon-box .svg-inline--fa {
    font-size: 1.02rem;
}

nav.navbar #internal_notifications_content .tp-internal-notification-content {
    min-width: 0;
}

nav.navbar #internal_notifications_content .tp-internal-notification-title {
    font-size: .95rem;
    line-height: 1.34;
    font-weight: 700;
    color: #10253f;
    margin-bottom: .36rem;
}

nav.navbar #internal_notifications_content .tp-internal-notification-description {
    font-size: .88rem;
    line-height: 1.52;
    color: rgba(16, 37, 63, .74);
    margin-bottom: .46rem;
}

nav.navbar #internal_notifications_content .tp-internal-notification-time {
    font-size: .8rem;
    line-height: 1.34;
    color: rgba(16, 37, 63, .55);
}

nav.navbar #internal_notifications_content .tp-internal-notifications-more-wrap {
    padding-top: .5rem;
}

nav.navbar #internal_notifications_content .tp-internal-notifications-more {
    border-radius: 999px !important;
    border: 1px solid rgba(15, 165, 235, .28) !important;
    background: linear-gradient(180deg, rgba(234, 247, 255, .96), rgba(220, 241, 255, .94)) !important;
    color: #12347c !important;
    font-weight: 700;
    min-height: 2.28rem;
    padding: .52rem .95rem !important;
    box-shadow: none !important;
}

nav.navbar #internal_notifications_content .tp-internal-notifications-more:hover,
nav.navbar #internal_notifications_content .tp-internal-notifications-more:focus {
    background: linear-gradient(180deg, rgba(218, 240, 255, .98), rgba(206, 235, 255, .96)) !important;
    color: #0b2557 !important;
}

.tp-internal-notifications-page .tp-internal-notifications-panel .card-body {
    padding: 1.62rem !important;
}

.tp-internal-notifications-page .tp-internal-notification-row {
    display: flex;
    gap: 1.34rem;
    align-items: flex-start;
    padding: 1.3rem 1.4rem;
    border-radius: 1.08rem;
    border: 1px solid rgba(15, 165, 235, .16);
    background: #fff;
}

.tp-internal-notifications-page .tp-internal-notification-row + .tp-internal-notification-row {
    margin-top: 1.18rem;
}

.tp-internal-notifications-page .tp-internal-notification-row.is-unread {
    border-color: rgba(15, 165, 235, .3);
    background: linear-gradient(180deg, rgba(234, 246, 255, .82), rgba(255, 255, 255, .98));
}

.tp-internal-notifications-page .tp-internal-notification-icon-box {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 1.02rem;
    border: 1px solid rgba(15, 165, 235, .24);
    background: linear-gradient(180deg, rgba(238, 249, 255, .95), rgba(227, 245, 255, .92));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #0fa5eb;
}

.tp-internal-notifications-page .tp-internal-notification-icon-box i,
.tp-internal-notifications-page .tp-internal-notification-icon-box .svg-inline--fa {
    font-size: 1.14rem;
}

.tp-internal-notifications-page .tp-internal-notification-main {
    min-width: 0;
    flex: 1 1 auto;
}

.tp-internal-notifications-page .tp-internal-notification-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.2rem;
}

.tp-internal-notifications-page .tp-internal-notification-title {
    font-size: 1rem;
    line-height: 1.36;
    font-weight: 730;
    color: #10253f;
    margin-bottom: .46rem;
}

.tp-internal-notifications-page .tp-internal-notification-description {
    font-size: .98rem;
    line-height: 1.58;
    color: rgba(16, 37, 63, .72);
}

.tp-internal-notifications-page .tp-internal-notification-time {
    flex: 0 0 auto;
    font-size: .8rem;
    line-height: 1.35;
    color: rgba(16, 37, 63, .58);
    white-space: nowrap;
}

.tp-internal-notifications-page .tp-internal-notifications-pagination .pagination {
    margin-bottom: 0;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content.tp-internal-notifications-dropdown {
    border-color: rgba(95, 170, 227, .18) !important;
    background: linear-gradient(180deg, rgba(25, 33, 44, .98), rgba(12, 17, 25, .98)) !important;
    box-shadow: 0 18px 42px rgba(2, 8, 20, .68), inset 0 1px 0 rgba(255, 255, 255, .08) !important;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notification-item-inner {
    border-color: rgba(95, 170, 227, .2);
    background: linear-gradient(180deg, rgba(29, 40, 55, .96), rgba(17, 25, 35, .96));
    box-shadow: 0 4px 12px rgba(2, 8, 20, .42), inset 0 1px 0 rgba(255, 255, 255, .06);
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notification-item.is-unread .tp-internal-notification-item-inner {
    border-color: rgba(95, 170, 227, .4);
    background: linear-gradient(180deg, rgba(25, 48, 72, .7), rgba(18, 30, 43, .96));
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notification-icon-box {
    border-color: rgba(95, 170, 227, .32);
    background: linear-gradient(180deg, rgba(29, 53, 80, .76), rgba(20, 36, 54, .88));
    color: #74c4ff;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notification-title {
    color: rgba(236, 245, 255, .96);
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notification-description {
    color: rgba(205, 222, 238, .76);
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notification-time {
    color: rgba(197, 218, 238, .58);
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notifications-more {
    border-color: rgba(95, 170, 227, .34) !important;
    background: linear-gradient(180deg, rgba(29, 53, 80, .72), rgba(20, 36, 54, .9)) !important;
    color: #e3f2ff !important;
}

[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notifications-more:hover,
[data-theme-style="dark"] nav.navbar #internal_notifications_content .tp-internal-notifications-more:focus {
    background: linear-gradient(180deg, rgba(36, 66, 98, .78), rgba(24, 44, 66, .92)) !important;
}

[data-theme-style="dark"] .tp-internal-notifications-page .tp-internal-notifications-panel {
    border-color: rgba(255, 255, 255, .08) !important;
    background: linear-gradient(180deg, hsl(218deg 23.65% 16.68%), rgb(0 0 0 / 92%)) !important;
    box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .1), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

[data-theme-style="dark"] .tp-internal-notifications-page .tp-internal-notification-row {
    border-color: rgba(95, 170, 227, .2);
    background: linear-gradient(180deg, rgba(26, 37, 52, .94), rgba(15, 23, 33, .94));
}

[data-theme-style="dark"] .tp-internal-notifications-page .tp-internal-notification-row.is-unread {
    border-color: rgba(95, 170, 227, .42);
    background: linear-gradient(180deg, rgba(20, 43, 68, .75), rgba(15, 27, 41, .95));
}

[data-theme-style="dark"] .tp-internal-notifications-page .tp-internal-notification-icon-box {
    border-color: rgba(95, 170, 227, .32);
    background: linear-gradient(180deg, rgba(31, 58, 86, .7), rgba(22, 39, 58, .88));
    color: #74c4ff;
}

[data-theme-style="dark"] .tp-internal-notifications-page .tp-internal-notification-title {
    color: #e9f2ff;
}

[data-theme-style="dark"] .tp-internal-notifications-page .tp-internal-notification-description {
    color: rgba(208, 223, 241, .76);
}

[data-theme-style="dark"] .tp-internal-notifications-page .tp-internal-notification-time {
    color: rgba(195, 214, 236, .62);
}

/* Global badge refresh */
.badge-info,
.badge-light {
    color: hsl(220.75deg 74.65% 27.84%) !important;
    background-color: rgb(232 247 254) !important;
}

a.badge-info:hover,
a.badge-info:focus,
a.badge-light:hover,
a.badge-light:focus,
.badge-info:hover,
.badge-light:hover {
    color: hsl(220.75deg 74.65% 27.84%) !important;
    background-color: rgb(214 238 252) !important;
}

[data-theme-style=dark] .badge-info,
[data-theme-style=dark] .badge-light {
    background-color: hsl(220.75deg 74.65% 27.84%) !important;
    color: hsl(199.09deg 91.67% 95.29%) !important;
}

[data-theme-style=dark] a.badge-info:hover,
[data-theme-style=dark] a.badge-info:focus,
[data-theme-style=dark] a.badge-light:hover,
[data-theme-style=dark] a.badge-light:focus,
[data-theme-style=dark] .badge-info:hover,
[data-theme-style=dark] .badge-light:hover {
    background-color: hsl(220.75deg 74.65% 24%) !important;
    color: hsl(199.09deg 91.67% 95.29%) !important;
}

.tp-dsa-menu-item {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: .7rem;
}

.tp-dsa-menu-item-label {
    min-width: 0;
}

.tp-dsa-menu-badge {
    flex: 0 0 auto;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #e11d48;
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    line-height: 1;
    box-shadow: 0 0 0 0 rgba(225, 29, 72, .52);
    animation: tp-dsa-menu-badge-pulse 1.5s ease-out infinite;
}

@keyframes tp-dsa-menu-badge-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(225, 29, 72, .52);
    }
    70% {
        box-shadow: 0 0 0 8px rgba(225, 29, 72, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(225, 29, 72, 0);
    }
}

@media (max-width: 767.98px) {
    .tp-internal-notifications-page .tp-internal-notifications-panel .card-body {
        padding: 1.18rem !important;
    }

    .tp-internal-notifications-page .tp-internal-notification-row {
        padding: 1.08rem;
        gap: 1rem;
    }

    .tp-internal-notifications-page .tp-internal-notification-icon-box {
        width: 2.9rem;
        height: 2.9rem;
        border-radius: .84rem;
    }

    .tp-internal-notifications-page .tp-internal-notification-head {
        flex-direction: column;
        gap: .56rem;
    }

    .tp-internal-notifications-page .tp-internal-notification-title {
        font-size: 1rem;
    }

    .tp-internal-notifications-page .tp-internal-notification-description {
        font-size: .92rem;
    }

    .tp-internal-notifications-page .tp-internal-notification-time {
        font-size: .82rem;
    }
}

/* =========================================================
   HOMEPAGE USECASES (final) - matches provided reference
   green -> Transfer+ blue palette
   ========================================================= */

.tp-home-usecases {
    padding: 3rem 0 8rem !important;
}

.tp-home-usecases::before {
    display: none !important;
}

.tp-home-usecases .tp-home-usecase-row {
    margin: 0 0 6.2rem !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    position: relative;
    z-index: 1;
}

.tp-home-usecases .tp-home-usecase-row:last-child {
    margin-bottom: 0 !important;
}

.tp-home-usecases .tp-usecase-animate {
    opacity: 0;
    will-change: opacity, transform;
    transition: opacity .62s ease, transform .62s cubic-bezier(.22, .61, .36, 1);
    transition-delay: var(--tp-usecase-delay, 0ms);
}

.tp-home-usecases .tp-usecase-from-left {
    transform: translate3d(-36px, 0, 0);
}

.tp-home-usecases .tp-usecase-from-right {
    transform: translate3d(36px, 0, 0);
}

.tp-home-usecases .tp-usecase-inner.tp-usecase-from-left {
    transform: translate3d(-20px, 0, 0);
}

.tp-home-usecases .tp-usecase-row-in .tp-usecase-animate {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.tp-home-usecases .tp-home-usecase-content {
    max-width: 560px;
    padding: .2rem .8rem .2rem 0 !important;
}

@media (min-width: 992px) {
    .tp-home-usecases .tp-home-usecase-row:nth-child(2) .tp-home-usecase-content {
        padding-left: 1.35rem !important;
    }
}

.tp-home-usecases .tp-home-usecase-kicker {
    display: inline-flex;
    align-items: center;
    padding: .50rem 1rem !important;
    border-radius: 2rem !important;
    border: 0 !important;
    text-transform: uppercase !important;
    letter-spacing: .085em !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    color: #1089D0 !important;
    background: #e3f4fd !important;
    margin-bottom: 1.05rem !important;
}

.tp-home-usecases .tp-home-usecase-title {
    position: relative;
    font-size: 2.4rem;
    line-height: 1.10 !important;
    letter-spacing: -.035em !important;
    font-weight: 800 !important;
    color: #04101a !important;
    margin: 0 0 1.2rem !important;
    text-wrap: balance;
}

.tp-home-usecases .tp-home-usecase-text {
    margin: 0 0 1.3rem !important;
    font-size: 1.16rem !important;
    line-height: 1.58 !important;
    color: rgb(10 16 26 / 53%) !important;
    max-width: 38ch;
}

.tp-home-usecases .tp-home-usecase-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: grid;
    grid-template-columns: 1fr;
    gap: .72rem !important;
    max-width: 430px;
}

.tp-home-usecases .tp-home-usecase-list li {
    list-style: none !important;
    display: flex;
    align-items: center;
    gap: .72rem;
    min-height: 50px;
    padding: .72rem 1rem !important;
    border-radius: .72rem !important;
    border: 1px solid #e8eaed !important;
    background: #f0f1f2 !important;
    color: #1089D0 !important;
    font-size: 0.90rem !important;
    font-weight: 600 !important;
}

.tp-home-usecases .tp-home-usecase-list li i {
    width: 1rem;
    min-width: 1rem;
    color: #0fa5eb !important;
    font-size: 1rem !important;
}

.tp-home-usecases .tp-home-usecase-visual {
    position: relative;
    min-height: 440px !important;
    height: 100%;
    padding: 1.85rem !important;
    border-radius: 18px !important;
    border: 1px solid #e4e5e8 !important;
    background: #eff1f2 !important;
    box-shadow: none !important;
    overflow: visible !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.tp-home-usecases .tp-home-usecase-visual::before {
    content: "";
    position: absolute;
    inset: 1.55rem;
    border-radius: 18px;
    border: 1px solid #e6e7ea;
    background: linear-gradient(180deg, rgb(255 255 255) 0%, rgb(250 250 250) 100%);
}

.tp-home-usecases .tp-home-usecase-visual::after {
    content: "";
    position: absolute;
    right: -0.8rem;
    bottom: -0.2rem;
    width: 140px;
    height: 120px;
    border-radius: .72rem;
    z-index: 4;
    background-image: var(--tp-usecase-badge-image, none);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.tp-home-usecases .tp-home-usecase-visual img {
    position: relative;
    z-index: 2;
    display: block;
    align-self: center;
    width: min(100%, 460px) !important;
    max-height: 365px !important;
    height: auto !important;
    margin: 0 auto !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    padding: 0 !important;
    object-fit: contain !important;
    filter: drop-shadow(0 18px 22px rgba(9, 20, 39, .16));
}

[data-theme-style="dark"] .tp-home-usecases {
    background: #040506 !important;
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-kicker {
    color: #8fdcff !important;
    background: linear-gradient(180deg, rgba(15, 78, 120, .92), rgba(10, 52, 82, .92)) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08), 0 4px 14px rgba(0, 0, 0, .18);
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-title {
    color: #f4f8ff !important;
    text-shadow: 0 1px 0 rgba(0, 0, 0, .55);
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-text {
    color: rgba(223, 234, 248, .78) !important;
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-list li {
    background: linear-gradient(180deg, #101319, #101319) !important;
    border: 1px solid rgb(0 0 0 / 18%) !important;
    border-radius: 18px !important;
    box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-list li i {
    color: #7bd4ff !important;
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-visual {
    background: linear-gradient(180deg, hsl(218, 23%, 21%), rgb(16 19 25)) !important;
    border: 1px solid rgb(0 0 0 / 18%) !important;
    border-radius: 18px !important;
    box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-visual::before {
    inset: 1.2rem;
    border-radius: 14px;
    background: #040506;
    border: 1px solid rgba(60, 97, 142, .38);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .03);
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-visual::after {
    background-color: transparent;
    border: 0;
    box-shadow: none;
}

[data-theme-style="dark"] .tp-home-usecases .tp-home-usecase-visual img {
    filter: drop-shadow(0 18px 28px rgba(0, 0, 0, .42));
}

@media (max-width: 991.98px) {
    .tp-home-usecases .tp-home-usecase-row:nth-child(2) .tp-home-usecase-content {
        padding-left: 0 !important;
    }

    .tp-home-usecases .tp-usecase-from-left,
    .tp-home-usecases .tp-usecase-from-right,
    .tp-home-usecases .tp-usecase-inner.tp-usecase-from-left {
        transform: translate3d(0, 22px, 0);
    }

    .tp-home-usecases {
        padding: 3rem 0 2.2rem !important;
    }

    .tp-home-usecases .tp-home-usecase-row {
        margin-bottom: 3.2rem !important;
    }

    .tp-home-usecases .tp-home-usecase-content {
        padding: 0 !important;
    }

    .tp-home-usecases .tp-home-usecase-title {
        font-size: clamp(2rem, 8.2vw, 3rem) !important;
        max-width: 100%;
    }

    .tp-home-usecases .tp-home-usecase-list {
        max-width: 100%;
    }

    .tp-home-usecases .tp-home-usecase-visual {
        min-height: 320px !important;
        margin-top: .5rem;
    }

    .tp-home-usecases .tp-home-usecase-visual::after {
        display: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .tp-home-usecases .tp-usecase-animate {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
}

/* ============================================
   HOMEPAGE INLINE AUTH (guest hero)
   ============================================ */
.tp-inline-auth {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transform: translateY(-10px);
    transition: max-height .42s ease, opacity .34s ease, transform .34s ease, margin-top .28s ease;
    will-change: max-height, opacity, transform;
}

.tp-inline-auth-trigger {
    margin-bottom: .25rem;
}

.tp-inline-auth.is-open {
    max-height: 1800px;
    opacity: 1;
    transform: translateY(0);
    overflow: visible;
}

.tp-inline-auth-form {
    padding: 1rem 0 2rem;
}

.tp-inline-auth-email-title {
    font-size: 1rem;
    color: #111827;
    font-weight: 600;
    margin-bottom: 1.5rem !important;
}

.tp-inline-auth-social {
    border-top: 1px solid rgb(18 137 207 / 47%);
    padding-top: .95rem;
    overflow: visible;
}

.tp-inline-auth-social-label {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #1289cf;
    margin-bottom: .70rem;
}

.tp-inline-auth-social-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .5rem;
    overflow: visible;
    padding-bottom: 0;
}

.tp-inline-auth-social-grid .tp-inline-auth-social-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    width: 100%;
    margin-top: 0;
    border-radius: .35rem !important;
    box-shadow: none !important;
    border: 1px solid #e5e7eb !important;
    background: #f8fafc !important;
    color: #1f2937 !important;
    transition: background-color .15s ease, border-color .15s ease, transform .15s ease, box-shadow .15s ease !important;
}

.tp-inline-auth-social-btn {
    box-shadow: none !important;
}

.tp-inline-auth-social-grid .tp-inline-auth-social-btn:hover,
.tp-inline-auth-social-grid .tp-inline-auth-social-btn:focus,
.tp-inline-auth-social-grid .tp-inline-auth-social-btn:active {
    background: #ffffff !important;
    border-color: #cdd6e1 !important;
    box-shadow: 0 2px 6px rgba(15, 23, 42, .08) !important;
    transform: translateY(-1px) !important;
}

.tp-inline-auth-submit {
    margin-top: 1.5rem !important;
}

.tp-hero #upload_main_dropzone.tp-inline-auth-active {
    background-color: #e9f6fe;
    box-shadow:
        0 14px 34px rgba(0, 67, 138, .22),
        0 0 0 1px rgba(16, 110, 180, .18) inset;
    transition: background-color .34s ease, box-shadow .34s ease;
}

[data-theme-style="dark"] .tp-hero #upload_main_dropzone.tp-inline-auth-active {
    background-color: rgba(6, 30, 58, .95);
    box-shadow:
        0 14px 34px rgba(0, 0, 0, .42),
        0 0 0 1px rgba(79, 162, 235, .24) inset;
}

.tp-inline-auth-social-grid img {
    width: 16px;
    height: 16px;
}

.tp-inline-auth-captcha-wrap,
.tp-inline-auth-form,
.tp-inline-auth-social,
.tp-inline-auth-social-grid {
    overflow: visible !important;
}

[data-theme-style="dark"] .tp-inline-auth-form {
    background: rgba(9, 16, 30, .88);
    border-color: rgba(115, 176, 237, .24);
}

[data-theme-style="dark"] .tp-inline-auth-social {
    border-top-color: rgba(115, 176, 237, .24);
}

[data-theme-style="dark"] .tp-inline-auth-social-label {
    color: #a8c8e8;
}

[data-theme-style="dark"] .tp-inline-auth-social-grid .tp-inline-auth-social-btn {
    background: #111a28 !important;
    border-color: #263246 !important;
    color: #dbe7f5 !important;
}

[data-theme-style="dark"] .tp-inline-auth-social-grid .tp-inline-auth-social-btn:hover,
[data-theme-style="dark"] .tp-inline-auth-social-grid .tp-inline-auth-social-btn:focus,
[data-theme-style="dark"] .tp-inline-auth-social-grid .tp-inline-auth-social-btn:active {
    background: #172235 !important;
    border-color: #3a4b66 !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .35) !important;
}

@media (max-width: 575.98px) {
    .tp-inline-auth-form {
        padding: 0 0.5rem 2rem;
    }

    .tp-inline-auth-social-grid {
        grid-template-columns: 1fr;
    }
}

/* ------------------------------------------------------------------
   Uploader simplification (no pause/resume, no stage chips)
   ------------------------------------------------------------------ */
#upload_form .tp-upload-status-strip,
#upload_form .tp-upload-file-card-status,
#upload_form .tp-upload-file-card-actions,
#upload_form [data-altum-pause],
#upload_form [data-altum-resume],
#upload_form [data-altum-retry] {
    display: none !important;
}

#upload_form #upload_previews_files .bg-gray-100 {
    height: 60px;
}

#upload_form .tp-upload-summary {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: .62rem !important;
    width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    padding: .64rem .72rem !important;
    border-radius: 1rem !important;
    background: linear-gradient(180deg, rgba(239, 248, 255, .98), rgba(222, 241, 255, .96)) !important;
    box-shadow: 0 4px 10px rgba(6, 16, 34, .08), inset 0 1px 0 rgba(255, 255, 255, .84);
    border: 1px solid rgba(15, 165, 235, .16);
}

#upload_form .tp-upload-summary-files {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 1.03rem !important;
    font-weight: 800 !important;
    color: rgba(15, 23, 42, .9) !important;
    letter-spacing: .01em !important;
}

#upload_form .tp-upload-summary-size {
    flex: 0 0 auto !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    font-size: .99rem !important;
    font-weight: 800 !important;
    color: rgba(15, 23, 42, .86) !important;
}

#upload_form .tp-upload-summary-actions {
    flex: 0 0 auto !important;
    margin-left: auto !important;
}

#upload_form .tp-upload-summary-actions .tp-upload-remove-btn {
    min-width: 34px !important;
    width: 34px !important;
    height: 34px !important;
    padding: .2rem !important;
    border-radius: .68rem !important;
    border: 1px solid rgba(239, 68, 68, .46) !important;
    color: #dc2626 !important;
    background: linear-gradient(180deg, rgba(255, 241, 242, .98), rgba(254, 226, 226, .96)) !important;
    box-shadow: 0 3px 10px rgba(220, 38, 38, .2), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
}

#upload_form .tp-upload-summary-actions .tp-upload-remove-btn:hover,
#upload_form .tp-upload-summary-actions .tp-upload-remove-btn:focus {
    border-color: rgba(220, 38, 38, .58) !important;
    color: #b91c1c !important;
    background: linear-gradient(180deg, rgba(254, 226, 226, .99), rgba(254, 202, 202, .97)) !important;
    box-shadow: 0 4px 12px rgba(220, 38, 38, .28), inset 0 1px 0 rgba(255, 255, 255, .92) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-summary {
    background: linear-gradient(180deg, rgba(19, 34, 56, .96), rgba(16, 30, 49, .94)) !important;
    box-shadow: 0 6px 14px rgba(6, 14, 28, .52), inset 0 1px 0 rgba(134, 180, 230, .14) !important;
}

[data-theme-style="dark"] #upload_form .tp-upload-summary-files,
[data-theme-style="dark"] #upload_form .tp-upload-summary-size {
    color: rgba(230, 240, 255, .94) !important;
}

#upload_form .tp-upload-file-card-header-meta {
    display: inline-flex !important;
    align-items: center !important;
    flex: 0 0 auto !important;
}

#upload_form .tp-upload-file-card .tp-upload-remove-btn-file {
    min-width: 32px !important;
    width: 32px !important;
    height: 32px !important;
    padding: .2rem !important;
    border-radius: .68rem !important;
    border: 1px solid rgba(148, 163, 184, .34) !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(241, 247, 255, .92)) !important;
    color: rgba(71, 85, 105, .88) !important;
    box-shadow: 0 1px 4px rgba(11, 18, 32, .08), inset 0 1px 0 rgba(255, 255, 255, .88) !important;
}

#upload_form .tp-upload-file-card .tp-upload-remove-btn-file:hover,
#upload_form .tp-upload-file-card .tp-upload-remove-btn-file:focus {
    border-color: rgba(239, 68, 68, .46) !important;
    background: linear-gradient(180deg, rgba(255, 241, 242, .98), rgba(254, 226, 226, .96)) !important;
    color: #dc2626 !important;
    box-shadow: 0 3px 10px rgba(220, 38, 38, .2), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
    transform: none;
}

#upload_form .tp-upload-file-card-meta {
    margin-top: .35rem !important;
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: .25rem !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    font-size: .79rem !important;
}

#upload_form .tp-upload-file-card-meta [data-altum-size-meta] {
    flex: 0 0 auto !important;
    font-weight: 600 !important;
    color: rgba(11, 18, 32, .68) !important;
}

#upload_form .tp-upload-file-card-meta [data-altum-speed],
#upload_form .tp-upload-file-card-meta [data-altum-remaining] {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#upload_form .tp-upload-file-card-dot {
    flex: 0 0 auto !important;
}

@media (max-width: 575.98px) {
    #upload_form .tp-upload-summary {
        gap: .35rem !important;
        padding: .52rem .7rem !important;
    }

    #upload_form .tp-upload-summary-files,
    #upload_form .tp-upload-summary-size {
        font-size: .9rem !important;
    }

    #upload_form .tp-upload-file-card-meta {
        font-size: .74rem !important;
    }
}

/* ------------------------------------------------------------------
   Uploader typography contrast harmonization
   ------------------------------------------------------------------ */
#upload_form {
    --tp-u-text-strong: rgba(11, 22, 32, .96);
    --tp-u-text-main: rgba(11, 22, 32, .88);
    --tp-u-text-soft: rgba(11, 22, 32, .72);
    --tp-u-text-muted: rgba(11, 22, 32, .58);
}

#upload_form .tp-transfer-settings-title,
#upload_form .tp-upload-summary-files,
#upload_form .tp-upload-summary-size,
#upload_form .tp-upload-file-card-title,
#upload_form .upload-previews .text-body,
#upload_form .upload-previews a.text-body {
    color: var(--tp-u-text-strong) !important;
}

#upload_form .col-form-label-sm,
#upload_form label,
#upload_form .tp-upload-file-card-meta,
#upload_form .tp-upload-file-card-meta [data-altum-speed],
#upload_form .tp-upload-file-card-meta [data-altum-remaining],
#upload_form .tp-upload-file-card-meta [data-altum-size-meta],
#upload_form #upload_previews_files .bg-gray-100 .text-muted {
    color: var(--tp-u-text-soft) !important;
}

#upload_form .tp-upload-empty-hint-title {
    color: var(--tp-u-text-main) !important;
}

[data-theme-style="dark"] #upload_form {
    --tp-u-text-strong: rgba(241, 247, 255, .96);
    --tp-u-text-main: rgba(231, 241, 255, .9);
    --tp-u-text-soft: rgba(207, 223, 243, .78);
    --tp-u-text-muted: rgba(181, 201, 224, .66);
}

/* ------------------------------------------------------------------
   Uploader fine tuning (buttons, panel seam, files width sync)
   ------------------------------------------------------------------ */
#upload_form #upload_previews_settings .btn-group-toggle .btn {
    line-height: 1.16 !important;
    padding-top: 0.9rem !important;
    padding-bottom: .9rem !important;
    box-shadow: 0 2px 7px rgba(2, 6, 23, .08), inset 0 1px 0 rgba(255, 255, 255, .74) !important;
}

#upload_form #upload_previews_settings .btn-group-toggle .btn svg {
    margin-bottom: .60rem !important;
}

#upload_form #upload_previews_settings .nav.nav-pills .nav-link {
    box-shadow: 0 1px 4px rgba(16, 24, 40, .08), inset 0 1px 0 rgba(255, 255, 255, .66) !important;
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .btn-group-toggle .btn {
    box-shadow: 0 2px 8px rgba(0, 0, 0, .30), inset 0 1px 0 rgba(255, 255, 255, .06) !important;
}

[data-theme-style="dark"] #upload_form #upload_previews_settings .nav.nav-pills .nav-link {
    box-shadow: 0 2px 8px rgba(0, 0, 0, .30), inset 0 1px 0 rgba(255, 255, 255, .06) !important;
}

#upload_form #upload_previews_files {
    position: relative;
    border-radius: 1.125rem;
    padding: 1.9rem 0.0rem 2.05rem 2.3rem;
    box-shadow: -20px 0px 20px -23px rgba(6, 16, 34, .29), 0 0px 8px -7px rgba(6, 16, 34, .09);
}

#upload_form #upload_previews_settings {
    position: relative;
    border-radius: 1.125rem;
    padding: 1.9rem 2.3rem 2.05rem 0rem;
    box-shadow: 20px 0px 20px -23px rgba(6, 16, 34, .29), 0 0px 8px -7px rgba(6, 16, 34, .09);
}

#upload_form .upload-previews {
    width: 100% !important;
    margin-right: 0 !important;
    padding: .42rem 0 1.0rem 0 !important;
    overflow-x: visible !important;
    scrollbar-gutter: auto;
}

#upload_form .upload-previews .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    box-shadow: 0 4px 10px rgba(6, 16, 34, .11), inset 0 1px 0 rgba(255, 255, 255, .82) !important;
}

#upload_form .upload-previews .row:hover {
    box-shadow: 0 6px 14px rgba(6, 16, 34, .14), inset 0 1px 0 rgba(255, 255, 255, .85) !important;
}

#upload_form .tp-upload-summary {
    padding: .68rem .92rem !important;
}

#upload_form .tp-transfer-settings-title {
    font-size: .86rem !important;
    font-weight: 700 !important;
    letter-spacing: -.02em !important;
    color: var(--tp-u-text-soft) !important;
}

@media (min-width: 992px) {
    #upload_form #upload_previews_wrapper {
        padding-left: 1.15rem !important;
        padding-right: 1.15rem !important;
    }

    #upload_form #upload_previews_wrapper > .row {
        align-items: flex-start !important;
        justify-content: center;
        column-gap: 1.35rem;
    }

    #upload_form #upload_previews_settings {
        margin-left: 0 !important;
        margin-right: 0 !important;
        flex: 0 0 calc(50% - 2.15rem);
        max-width: calc(50% - 2.15rem);
        display: flex !important;
        flex-direction: column !important;
    }

    #upload_form #upload_previews_files {
        margin-left: 0 !important;
        margin-right: 0 !important;
        flex: 0 0 calc(50% - 2.15rem);
        max-width: calc(50% - 2.15rem);
        display: flex !important;
        flex-direction: column !important;
    }

    /* pravý seznam souborů nesmí mít fixní max-height, jinak panel vypadá useknutě */
    #upload_form #upload_previews_files .upload-previews {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        height: auto !important;
        max-height: none !important;
        overflow-y: auto !important;
    }
}

#upload_form .row.mt-5 {
    justify-content: center !important;
}

#upload_form .row.mt-5 > .col-12.col-lg-6.offset-lg-3 {
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
}

#upload_form #upload_submit {
    margin-right: 0 !important;
}

/* =========================================================
   FOOTER – clean reference layout
   ========================================================= */
.tp-footer .footer.card {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.tp-footer .footer.card .card-body {
    padding: 1.85rem 0 1rem !important;
}

.tp-footer-modern {
    --tp-footer-text: rgba(9, 20, 36, .92);
    --tp-footer-muted: rgba(9, 20, 36, .62);
    --tp-footer-line: rgba(15, 23, 42, .12);
    --tp-footer-accent: #0fa5eb;
}

.tp-footer-modern-top {
    display: grid;
    grid-template-columns: minmax(220px, .9fr) minmax(0, 2.1fr);
    gap: 1.5rem 1.8rem;
    align-items: start;
}

.tp-footer-brand {
    display: inline-flex;
    align-items: center;
    min-width: 0;
}

.tp-footer-brand-logo {
    width: auto;
    max-height: 36px;
}

.tp-footer-brand-text {
    font-size: 1.56rem;
    font-weight: 900;
    letter-spacing: -.03em;
    color: var(--tp-footer-text);
}

.tp-footer-seo-text {
    margin: .72rem 0 0;
    color: var(--tp-footer-muted);
    font-size: .95rem;
    line-height: 1.58;
    max-width: 20rem;
}

.tp-footer-modern-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .9rem 1.15rem;
}

.tp-footer-modern-column-title {
    margin: 0 0 1rem;
    font-size: .90rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .02em;
    color: hsl(221, 39%, 11%);
}
[data-theme-style="dark"] .tp-footer-modern-column-title {
    color: #fff;
}

.tp-footer-modern-links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: .42rem;
}

.tp-footer-modern-links li a {
    display: inline-flex;
    align-items: center;
    min-width: 0;
    gap: .22rem;
    color: var(--tp-footer-text);
    font-size: 0.9rem;
}

.tp-footer-modern-links li a:hover {
    color: #0fa5eb !important;
    text-decoration: none;
}

.tp-footer-modern-links li a:focus-visible {
    color: #0fa5eb !important;
    text-decoration: none;
}

.tp-footer-modern-divider {
    display: block;
    margin-top: 2rem;
    height: 1px;
    background: linear-gradient(90deg, rgba(15, 23, 42, 0), var(--tp-footer-line) 12%, var(--tp-footer-line) 88%, rgba(15, 23, 42, 0));
}

.tp-footer-modern-utility {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: .95rem 1.15rem;
    margin-top: 1.68rem;
    padding: .22rem 0 0;
}

.tp-footer-socials {
    display: inline-flex;
    flex-wrap: wrap;
    gap: .52rem;
}

.tp-footer-social-item {
    width: 40px;
    height: 40px;
    border-radius: 999px;
    border: 1px solid var(--tp-footer-line);
    color: var(--tp-social-color, #0f172a) !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 11px rgba(6, 16, 34, .09), inset 0 1px 0 rgba(255, 255, 255, .18);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, filter .2s ease, background .2s ease, color .2s ease;
}

.tp-footer-social-item:hover {
    text-decoration: none;
    transform: translateY(-1px);
    border-color: rgba(15, 165, 235, .34);
    box-shadow: 0 8px 16px rgba(6, 16, 34, .14), inset 0 1px 0 rgba(255, 255, 255, .24);
    filter: saturate(1.1) brightness(1.03);
}

.tp-footer-tools {
    display: inline-flex;
    align-items: center;
    gap: .52rem;
}

.tp-footer-tool-btn {
    min-width: 40px;
    width: 40px;
    height: 40px;
    border-radius: 999px !important;
    border: 1px solid var(--tp-footer-line) !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(246, 250, 255, .95)) !important;
    color: rgba(9, 20, 36, .58) !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 11px rgba(6, 16, 34, .09), inset 0 1px 0 rgba(255, 255, 255, .92);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}

.tp-footer-tool-btn:hover,
.tp-footer-tool-btn:focus-visible {
    text-decoration: none !important;
    transform: translateY(-1px);
    border-color: rgba(15, 165, 235, .56) !important;
    background: linear-gradient(180deg, rgba(26, 185, 245, 1), rgba(15, 165, 235, 1)) !important;
    color: #ffffff !important;
    box-shadow: 0 8px 16px rgba(15, 165, 235, .32), inset 0 1px 0 rgba(255, 255, 255, .2);
}

.tp-footer-tool-btn:focus:not(:hover):not(:focus-visible),
.tp-footer-tool-btn.focus:not(:hover):not(:focus-visible) {
    text-decoration: none !important;
    transform: none;
    border-color: var(--tp-footer-line) !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(246, 250, 255, .95)) !important;
    color: rgba(9, 20, 36, .58) !important;
    box-shadow: 0 4px 11px rgba(6, 16, 34, .09), inset 0 1px 0 rgba(255, 255, 255, .92);
}

.tp-footer-copyright {
    margin-top: 1.1rem;
    padding-top: .95rem;
    border-top: 0;
    color: rgb(151 157 164);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .9rem 1.2rem;
    text-align: left;
}

.tp-footer-copyright-left,
.tp-footer-copyright-right {
    display: inline-block;
}

.tp-footer-copyright-right {
    text-align: right;
}

[data-theme-style="dark"] .tp-footer-copyright {
    color: rgb(144 160 177);

}


[data-theme-style="dark"] .tp-footer .footer.card {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

[data-theme-style="dark"] .tp-footer-modern {
    --tp-footer-text: rgba(241, 247, 255, .95);
    --tp-footer-muted: rgba(186, 206, 229, .77);
    --tp-footer-line: rgba(95, 170, 227, .24);
}

[data-theme-style="dark"] .tp-footer-modern-links li a:hover,
[data-theme-style="dark"] .tp-footer-modern-links li a:focus-visible {
    color: #0fa5eb !important;
}

[data-theme-style="dark"] .tp-footer-modern-divider {
    background: linear-gradient(90deg, rgba(95, 170, 227, 0), #2a2a2a 12%, #2a2a2a 88% 88%, rgba(95, 170, 227, 0));
}

[data-theme-style="dark"] .tp-footer-social-item {
    border-color: rgba(95, 170, 227, .28);
    background: var(--tp-social-bg, linear-gradient(180deg, rgba(31, 46, 67, .88), rgba(21, 34, 52, .84)));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
}

[data-theme-style="dark"] .tp-footer-social-item:hover {
    border-color: rgba(95, 170, 227, .46);
    box-shadow: 0 7px 15px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255, 255, 255, .12);
    filter: saturate(1.08) brightness(1.05);
}

[data-theme-style="dark"] .tp-footer-tool-btn {
    background: linear-gradient(180deg, rgba(31, 46, 67, .88), rgb(21 34 52 / 0%)) !important;
    color: rgba(205, 221, 241, .86) !important;
    border-color: rgba(95, 170, 227, .28) !important;
}

[data-theme-style="dark"] .tp-footer-tool-btn:hover,
[data-theme-style="dark"] .tp-footer-tool-btn:focus-visible {
    border-color: rgba(15, 165, 235, .62) !important;
    background: linear-gradient(180deg, rgba(26, 185, 245, 1), rgba(15, 165, 235, 1)) !important;
    color: #ffffff !important;
}

[data-theme-style="dark"] .tp-footer-tool-btn:focus:not(:hover):not(:focus-visible),
[data-theme-style="dark"] .tp-footer-tool-btn.focus:not(:hover):not(:focus-visible) {
    background: linear-gradient(180deg, rgba(31, 46, 67, .88), rgba(21, 34, 52, .84)) !important;
    color: rgba(205, 221, 241, .86) !important;
    border-color: rgba(95, 170, 227, .28) !important;
    box-shadow: 0 4px 11px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .08);
}


@media (max-width: 991.98px) {
    .tp-footer .footer.card .card-body {
        padding: 1.5rem 0 .9rem !important;
    }

    .tp-footer-modern-top {
        grid-template-columns: 1fr;
        gap: 1.15rem;
    }

    .tp-footer-modern-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .tp-footer-modern-grid {
        grid-template-columns: 1fr;
        gap: .85rem;
    }

    .tp-footer-modern-links li a {
        font-size: 0.9rem;
    }

    .tp-footer-copyright {
        flex-direction: column;
        align-items: flex-start;
        gap: .35rem;
    }

    .tp-footer-copyright-right {
        text-align: left;
    }
}

.tp-account-delete-guard {
    display: grid;
    gap: .7rem;
}

.tp-account-delete-guard-text {
    font-size: .94rem;
    line-height: 1.45;
}

.tp-account-delete-reveal-btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: .45rem .9rem;
    border-radius: .7rem !important;
    font-weight: 600;
    font-size: .92rem;
    color: #0FA5EB !important;
    background: #fff !important;
    border: 1px solid rgba(15, 165, 235, .42) !important;
    box-shadow: 0 2px 6px rgba(6, 16, 34, .04), inset 0 1px 0 rgba(255, 255, 255, .92) !important;
    transition: background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.tp-account-delete-reveal-btn:hover,
.tp-account-delete-reveal-btn:focus-visible {
    color: #0b95d4 !important;
    border-color: rgba(15, 165, 235, .62) !important;
    background: #f2fbff !important;
    box-shadow: 0 4px 10px rgba(15, 165, 235, .12), inset 0 1px 0 rgba(255, 255, 255, .92) !important;
}

.tp-account-delete-submit-btn {
    min-height: 50px;
    border-radius: 999px !important;
    font-weight: 700;
    font-size: .98rem;
    display: flex !important;
    align-items: center;
    justify-content: center;
    transition: background .16s ease, border-color .16s ease, box-shadow .16s ease, transform .16s ease;
    color: #fff !important;
    background: linear-gradient(180deg, #ef4444 0%, #dc2626 55%, #b91c1c 100%) !important;
    border: 1px solid rgba(185, 28, 28, .44) !important;
    box-shadow: 0 4px 10px rgba(220, 38, 38, .16), inset 0 1px 0 rgba(255, 255, 255, .2) !important;
}

.tp-account-delete-submit-btn:hover,
.tp-account-delete-submit-btn:focus-visible {
    color: #fff !important;
    background: linear-gradient(180deg, #f05555 0%, #e33434 55%, #c51e1e 100%) !important;
    border-color: rgba(185, 28, 28, .58) !important;
    box-shadow: 0 6px 14px rgba(220, 38, 38, .22), inset 0 1px 0 rgba(255, 255, 255, .24) !important;
    transform: translateY(-1px);
}

[data-theme-style="dark"] .tp-account-delete-guard-text {
    color: rgba(208, 220, 236, .72) !important;
}

[data-theme-style="dark"] .tp-account-delete-reveal-btn {
    color: #c6dbff !important;
    background: rgba(17, 31, 54, .92) !important;
    border-color: rgba(99, 154, 255, .28) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .05) !important;
}

[data-theme-style="dark"] .tp-account-delete-reveal-btn:hover,
[data-theme-style="dark"] .tp-account-delete-reveal-btn:focus-visible {
    color: #e1ecff !important;
    border-color: rgba(99, 154, 255, .44) !important;
    background: rgba(21, 39, 67, .96) !important;
}

[data-theme-style="dark"] .tp-account-delete-submit-btn {
    border-color: rgba(248, 113, 113, .34) !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255, 255, 255, .12) !important;
}

.tp-transfers-toolbar {
    align-items: center;
}

.tp-transfers-toolbar .tp-transfers-toolbar-utility {
    display: inline-flex;
}

.tp-transfers-toolbar .dropdown-menu,
.tp-transfers-toolbar-menu,
.tp-transfers-toolbar .filters-dropdown {
    margin-top: .5rem !important;
    border-radius: 1rem !important;
    border: 1px solid rgba(15, 165, 235, .14) !important;
    box-shadow: 0 8px 18px rgba(6, 16, 34, .12), inset 0 1px 0 rgba(255, 255, 255, .88) !important;
    z-index: 1080;
}

.tp-transfers-utility-btn {
    min-height: 40px;
    border-radius: .85rem !important;
    padding: .45rem .75rem !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    border: 1px solid rgba(15, 165, 235, .16) !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(247, 250, 253, .96)) !important;
    color: #10253f !important;
    box-shadow: 0 2px 6px rgba(6, 16, 34, .05), inset 0 1px 0 rgba(255, 255, 255, .92) !important;
}

.tp-transfers-utility-btn.d-none {
    display: none !important;
}

.tp-transfers-utility-btn i {
    color: #10253f !important;
}

.tp-transfers-utility-label {
    font-weight: 650;
    font-size: .92rem;
    line-height: 1;
    white-space: nowrap;
}

.tp-transfers-toolbar .tp-transfers-utility-label {
    display: none !important;
}

.tp-transfers-utility-btn {
    min-width: 40px;
    width: 40px;
    padding: .45rem !important;
    gap: 0;
}

.tp-transfers-utility-btn:hover,
.tp-transfers-utility-btn:focus-visible {
    border-color: rgba(18, 52, 124, .28) !important;
    background: linear-gradient(180deg, rgba(240, 248, 255, .99), rgba(231, 244, 255, .97)) !important;
    box-shadow: 0 4px 10px rgba(6, 16, 34, .08), inset 0 1px 0 rgba(255, 255, 255, .92) !important;
    color: #12347c !important;
    transform: none !important;
}

.tp-transfers-utility-btn:hover i,
.tp-transfers-utility-btn:focus-visible i {
    color: #12347c !important;
}

.tp-transfers-toolbar .filters-button.tp-transfers-utility-btn.btn-dark {
    color: #ffffff !important;
    border-color: rgba(18, 52, 124, .26) !important;
    background: linear-gradient(180deg, #1f4aa7 0%, #12347c 100%) !important;
    box-shadow: 0 3px 8px rgba(18, 52, 124, .16), inset 0 1px 0 rgba(255, 255, 255, .18) !important;
}

.tp-transfers-toolbar .filters-button.tp-transfers-utility-btn.btn-dark i,
.tp-transfers-toolbar .filters-button.tp-transfers-utility-btn.btn-dark .tp-transfers-utility-label {
    color: #ffffff !important;
}

.tp-transfers-bulk-group {
    align-items: center;
    gap: .55rem;
}

.tp-transfers-bulk-group .btn-group.dropdown {
    display: inline-flex;
}

.tp-transfers-bulk-actions-btn {
    border-radius: .85rem !important;
    padding-inline: .85rem !important;
}

.tp-transfers-bulk-close-btn {
    min-width: 40px;
    width: 40px;
    padding: .45rem !important;
}

.tp-transfers-bulk-close-btn .fa-times {
    color: #b91c1c !important;
}

.tp-transfers-toolbar .filters-dropdown .form-group.px-4.mt-4 {
    margin-top: .4rem !important;
    padding-top: .2rem;
}

.tp-transfers-toolbar .filters-dropdown .form-group.px-4.mt-4 .btn.btn-sm.btn-primary.btn-block {
    min-height: 42px;
    border-radius: .95rem !important;
    padding: .45rem .85rem !important;
    font-size: .95rem;
    font-weight: 700;
    box-shadow: 0 2px 6px rgba(15, 165, 235, .14), inset 0 1px 0 rgba(255, 255, 255, .2) !important;
}

/* Active bulk mode should look like a normal dropdown action (text + caret), not icon-only */
.tp-transfers-bulk-actions-btn {
    width: auto !important;
    min-width: 0 !important;
    gap: .45rem !important;
    padding: .45rem .85rem !important;
}

.tp-transfers-bulk-actions-btn .tp-transfers-utility-label {
    display: inline-block !important;
}

.tp-transfers-bulk-actions-btn.dropdown-toggle::after {
    display: inline-block !important;
    margin-left: .4rem;
    vertical-align: .1em;
}

.tp-transfers-bulk-actions-btn #bulk_counter {
    margin-left: .1rem;
}

[data-theme-style="dark"] .tp-transfers-toolbar .dropdown-menu,
[data-theme-style="dark"] .tp-transfers-toolbar-menu,
[data-theme-style="dark"] .tp-transfers-toolbar .filters-dropdown {
    border-color: rgba(95, 170, 227, .2) !important;
    box-shadow: 0 10px 20px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255, 255, 255, .05) !important;
}

[data-theme-style="dark"] .tp-transfers-utility-btn {
    border-color: rgba(95, 170, 227, .24) !important;
    background: linear-gradient(180deg, rgba(31, 46, 67, .92), rgba(21, 34, 52, .9)) !important;
    color: rgba(224, 236, 250, .94) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .06) !important;
}

[data-theme-style="dark"] .tp-transfers-utility-btn i {
    color: rgba(224, 236, 250, .9) !important;
}

[data-theme-style="dark"] .tp-transfers-utility-btn:hover,
[data-theme-style="dark"] .tp-transfers-utility-btn:focus-visible {
    border-color: rgba(15, 165, 235, .42) !important;
    background: linear-gradient(180deg, rgba(28, 60, 120, .95), rgba(18, 52, 124, .95)) !important;
    color: #ffffff !important;
    box-shadow: 0 5px 12px rgba(0, 0, 0, .28), inset 0 1px 0 rgba(255, 255, 255, .1) !important;
    transform: none !important;
}

[data-theme-style="dark"] .tp-transfers-utility-btn:hover i,
[data-theme-style="dark"] .tp-transfers-utility-btn:focus-visible i {
    color: #ffffff !important;
}

[data-theme-style="dark"] .tp-transfers-bulk-close-btn .fa-times {
    color: #fca5a5 !important;
}

/* Transfer detail file actions: keep delete visually aligned with the other row icons. */
.tp-transfer-files-actions {
    gap: .18rem;
}

.tp-transfer-files-actions .tp-transfer-file-action {
    width: 2.1rem;
    height: 2.1rem;
    padding: .35rem !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border-radius: .7rem;
    text-decoration: none !important;
    transition: transform .14s ease, background-color .14s ease, color .14s ease;
}

.tp-transfer-files-actions .tp-transfer-file-action:hover,
.tp-transfer-files-actions .tp-transfer-file-action:focus-visible {
    background: rgba(15, 165, 235, .08);
    transform: scale(1.08);
    outline: none;
}

.tp-transfer-files-actions .tp-transfer-file-action.text-danger:hover,
.tp-transfer-files-actions .tp-transfer-file-action.text-danger:focus-visible {
    background: rgba(239, 68, 68, .08);
}

[data-theme-style="dark"] .tp-transfer-files-actions .tp-transfer-file-action:hover,
[data-theme-style="dark"] .tp-transfer-files-actions .tp-transfer-file-action:focus-visible {
    background: rgba(123, 212, 255, .1);
}

[data-theme-style="dark"] .tp-transfer-files-actions .tp-transfer-file-action.text-danger:hover,
[data-theme-style="dark"] .tp-transfer-files-actions .tp-transfer-file-action.text-danger:focus-visible {
    background: rgba(252, 165, 165, .1);
}

/* Unified primary CTA buttons (Transfers + Footer selfpromo) */
.tp-selfpromo-btn,
.tp-transfers-primary-btn {
    --tp-btn-border: rgba(15, 165, 235, .24);
    --tp-btn-bg-from: #39b4f3;
    --tp-btn-bg-mid: #20a0ea;
    --tp-btn-bg-to: #1491dd;
    --tp-btn-text: #10253f;
    --tp-btn-shadow: var(--tp-dashboard-card-shadow);
    --tp-btn-hover-border: rgba(18, 52, 124, .38);
    --tp-btn-hover-bg-from: #39b4f3;
    --tp-btn-hover-bg-mid: #20a0ea;
    --tp-btn-hover-bg-to: #1491dd;
    --tp-btn-hover-shadow: 0 6px 14px rgba(18, 52, 124, .2), inset 0 1px 0 rgba(255, 255, 255, .2);
    --tp-btn-hover-text: #ffffff;
    --tp-btn-focus-ring: 0 0 0 3px rgba(15, 165, 235, .24);
    min-height: 42px !important;
    border-radius: 999px !important;
    padding: 1rem 1.5rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: .38rem !important;
    border: 1px solid var(--tp-btn-border) !important;
    background: var(--tp-dashboard-card-bg, linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(245, 250, 255, .92))) !important;
    color: var(--tp-btn-text) !important;
    font-weight: 800 !important;
    font-size: 1.02rem !important;
    line-height: 1 !important;
    white-space: nowrap;
    box-shadow: var(--tp-btn-shadow) !important;
    transform: none !important;
    transition: background .15s ease, box-shadow .15s ease, color .15s ease, border-color .15s ease !important;
}

.tp-selfpromo-btn:hover,
.tp-selfpromo-btn:focus-visible {
    border-color: var(--tp-btn-hover-border) !important;
    background: linear-gradient(180deg, var(--tp-btn-hover-bg-from) 0%, var(--tp-btn-hover-bg-mid) 52%, var(--tp-btn-hover-bg-to) 100%) !important;
    color: var(--tp-btn-hover-text, var(--tp-btn-text)) !important;
    transform: none !important;
    outline: none;
}

/* Keep selfpromo CTA readable on mobile tap/active state */
.tp-selfpromo .tp-selfpromo-btn:active,
.tp-selfpromo .tp-selfpromo-btn:focus:active {
    border-color: var(--tp-btn-hover-border) !important;
    background: linear-gradient(180deg, var(--tp-btn-hover-bg-from) 0%, var(--tp-btn-hover-bg-mid) 52%, var(--tp-btn-hover-bg-to) 100%) !important;
    color: #ffffff !important;
}

.tp-selfpromo-btn:focus,
.tp-selfpromo-btn:focus-visible,
.tp-transfers-primary-btn:focus,
.tp-transfers-primary-btn:focus-visible {
    outline: 0;
    box-shadow: var(--tp-btn-focus-ring), var(--tp-btn-hover-shadow) !important;
}

.tp-selfpromo-btn.disabled,
.tp-selfpromo-btn:disabled,
.tp-transfers-primary-btn.disabled,
.tp-transfers-primary-btn:disabled {
    opacity: .7;
    cursor: not-allowed !important;
    transform: none !important;
    box-shadow: 0 2px 6px rgba(6, 16, 34, .1), inset 0 1px 0 rgba(255, 255, 255, .16) !important;
}

[data-theme-style="dark"] .tp-selfpromo-btn,
[data-theme-style="dark"] .tp-transfers-primary-btn {
    --tp-btn-border: rgba(95, 170, 227, .42);
    --tp-btn-bg-from: #1aa4ec;
    --tp-btn-bg-mid: #1186cf;
    --tp-btn-bg-to: #0e73b8;
    --tp-btn-text: #e8f5ff;
    --tp-btn-shadow: 0 5px 12px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .16);
    --tp-btn-hover-border: rgba(123, 212, 255, .52);
    --tp-btn-hover-bg-from: #2c68d3;
    --tp-btn-hover-bg-mid: #1e4ea8;
    --tp-btn-hover-bg-to: #173f8d;
    --tp-btn-hover-shadow: 0 8px 18px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255, 255, 255, .14);
    --tp-btn-hover-text: #e8f5ff;
    --tp-btn-focus-ring: 0 0 0 3px rgba(123, 212, 255, .28);
}

[data-theme-style="dark"] .tp-selfpromo-btn:hover,
[data-theme-style="dark"] .tp-selfpromo-btn:focus-visible,
[data-theme-style="dark"] .tp-transfers-primary-btn:hover,
[data-theme-style="dark"] .tp-transfers-primary-btn:focus-visible {
    border-color: var(--tp-btn-hover-border) !important;
    background: linear-gradient(180deg, var(--tp-btn-hover-bg-from) 0%, var(--tp-btn-hover-bg-mid) 52%, var(--tp-btn-hover-bg-to) 100%) !important;
    color: var(--tp-btn-hover-text, var(--tp-btn-text)) !important;
    box-shadow: var(--tp-btn-hover-shadow) !important;
    transform: none !important;
}

/* Selfpromo CTA: stronger dark-blue hover for clear contrast on promo background */
.tp-selfpromo .tp-selfpromo-btn {
    --tp-btn-hover-border: rgba(18, 52, 124, .58);
    --tp-btn-hover-bg-from: #1a59c1;
    --tp-btn-hover-bg-mid: #15489d;
    --tp-btn-hover-bg-to: #123d83;
    --tp-btn-hover-shadow: 0 9px 20px rgba(3, 22, 47, .3), inset 0 1px 0 rgba(255, 255, 255, .16);
    --tp-btn-hover-text: #ffffff;
}

[data-theme-style="dark"] .tp-selfpromo .tp-selfpromo-btn {
    --tp-btn-border: rgba(210, 230, 247, .56);
    --tp-btn-text: #10253f;
    --tp-btn-shadow: 0 8px 18px rgba(0, 0, 0, .32), inset 0 1px 0 rgba(255, 255, 255, .92);
    --tp-btn-hover-border: rgba(166, 224, 255, .62);
    --tp-btn-hover-bg-from: #2a78ee;
    --tp-btn-hover-bg-mid: #2269d8;
    --tp-btn-hover-bg-to: #1b56b5;
    --tp-btn-hover-shadow: 0 11px 24px rgba(0, 0, 0, .44), inset 0 1px 0 rgba(255, 255, 255, .16);
    --tp-btn-hover-text: #ffffff;
    background: linear-gradient(180deg, rgba(255, 255, 255, .99), rgba(243, 249, 255, .95)) !important;
    color: #10253f !important;
}

/* Transfers primary CTA: inverse palette against selfpromo button */
.tp-transfers-primary-btn {
    border-color: rgba(18, 52, 124, .38) !important;
    background: linear-gradient(180deg, #39b4f3 0%, #20a0ea 52%, #1491dd 100%) !important;
    color: #ffffff !important;
    --tp-btn-hover-border: rgba(18, 52, 124, .58);
    --tp-btn-hover-bg-from: #1a59c1;
    --tp-btn-hover-bg-mid: #15489d;
    --tp-btn-hover-bg-to: #123d83;
    --tp-btn-hover-text: #ffffff;
}

.tp-transfers-primary-btn:hover,
.tp-transfers-primary-btn:focus-visible {
    border-color: var(--tp-btn-hover-border) !important;
    background: linear-gradient(180deg, var(--tp-btn-hover-bg-from) 0%, var(--tp-btn-hover-bg-mid) 52%, var(--tp-btn-hover-bg-to) 100%) !important;
    color: var(--tp-btn-hover-text, var(--tp-btn-text)) !important;
    transform: none !important;
    outline: none;
}

[data-theme-style="dark"] .tp-transfers-primary-btn {
    border-color: rgba(123, 212, 255, .52) !important;
    background: linear-gradient(180deg, #2c68d3 0%, #1e4ea8 52%, #173f8d 100%) !important;
    color: #f3f8ff !important;
    box-shadow: 0 8px 18px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255, 255, 255, .14) !important;
}

[data-theme-style="dark"] .tp-transfers-primary-btn:hover,
[data-theme-style="dark"] .tp-transfers-primary-btn:focus-visible {
    border-color: rgba(95, 170, 227, .42) !important;
    background: var(--tp-dashboard-card-bg, linear-gradient(180deg, rgba(26, 34, 50, .95), rgba(18, 26, 39, .95))) !important;
    color: #e8f5ff !important;
    box-shadow: 0 5px 12px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .16) !important;
}

@media (max-width: 767.98px) {
    .tp-selfpromo-btn,
    .tp-transfers-primary-btn {
        --tp-btn-border: rgba(15, 165, 235, .24);
        --tp-btn-bg-from: #39b4f3;
        --tp-btn-bg-mid: #20a0ea;
        --tp-btn-bg-to: #1491dd;
        --tp-btn-text: #10253f;
        --tp-btn-shadow: var(--tp-dashboard-card-shadow);
        --tp-btn-hover-border: rgba(18, 52, 124, .38);
        --tp-btn-hover-bg-from: #39b4f3;
        --tp-btn-hover-bg-mid: #20a0ea;
        --tp-btn-hover-bg-to: #1491dd;
        --tp-btn-hover-shadow: 0 6px 14px rgba(18, 52, 124, .2), inset 0 1px 0 rgba(255, 255, 255, .2);
        --tp-btn-hover-text: #ffffff;
        --tp-btn-focus-ring: 0 0 0 3px rgba(15, 165, 235, .24);
        min-height: 42px !important;
        border-radius: 999px !important;
        padding: .4rem 1.2rem !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: .38rem !important;
        border: 1px solid var(--tp-btn-border) !important;
        background: var(--tp-dashboard-card-bg, linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(245, 250, 255, .92))) !important;
        color: var(--tp-btn-text) !important;
        font-weight: 800 !important;
        font-size: 1.02rem !important;
        line-height: 1 !important;
        white-space: nowrap;
        box-shadow: var(--tp-btn-shadow) !important;
        transform: none !important;
        transition: background .15s ease, box-shadow .15s ease, color .15s ease, border-color .15s ease !important;
    }

    .tp-transfers-toolbar {
        gap: .55rem !important;
    }

    .tp-transfers-utility-btn {
        min-width: 40px;
        width: 40px;
        padding: .45rem !important;
        gap: 0;
    }
}

/* =========================================================
   TP CONTACT HUB
   ========================================================= */

.tp-contact-page .tp-contact-hero {
  padding: .2rem 0;
}

.tp-contact-page .tp-contact-hero h1 {
  font-size: clamp(1.42rem, 2vw, 1.86rem);
  font-weight: 850;
  letter-spacing: -0.01em;
}

.tp-contact-page .tp-contact-hero-cta {
  display: flex;
  gap: .65rem;
  flex-wrap: wrap;
}

.tp-contact-page .tp-contact-form-card,
.tp-contact-page .tp-contact-side-card {
  border-radius: 18px !important;
  border: 0 !important;
  box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
  background: #ffffff !important;
}

.tp-contact-page .tp-contact-form-card .card-body,
.tp-contact-page .tp-contact-side-card .card-body {
  padding: 1.5rem;
}

.tp-contact-page .tp-contact-section-title {
  font-size: clamp(1.22rem, 1.35vw, 1.42rem);
  line-height: 1.18;
  font-weight: 840;
  letter-spacing: -0.012em;
  margin: 0 0 .9rem;
  color: #101b32;
}

.tp-contact-page .tp-contact-form-card textarea {
  min-height: 160px;
}

.tp-contact-page .tp-contact-side-stack {
  position: sticky;
  top: 1rem;
}

.tp-contact-page .tp-contact-side-illustration {
  display: flex;
  justify-content: center;
  margin: 0 0 1rem;
}

.tp-contact-page .tp-contact-side-illustration img {
  width: min(100%, 370px);
  height: auto;
  filter: drop-shadow(0 14px 24px rgba(7, 36, 64, .2));
}

.tp-contact-page .tp-contact-side-panel {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.tp-contact-page .tp-contact-faq-section {
  margin-top: 2.2rem !important;
}

.tp-contact-page .tp-contact-quick-grid {
  display: grid;
  gap: 1.5rem;
}

.tp-contact-page .tp-contact-quick-item {
  position: relative;
  border-radius: 14px;
  border: 1px solid rgba(14, 84, 136, .16);
  background: linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(246, 251, 255, .95));
  box-shadow: 0 10px 22px -20px rgba(6, 29, 53, .34), inset 0 1px 0 rgba(255, 255, 255, .92);
  padding: 1.5rem;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.tp-contact-page .tp-contact-quick-item:hover {
  transform: translateY(-1px);
  border-color: rgba(15, 165, 235, .48);
  box-shadow: 0 12px 22px -16px rgba(7, 36, 64, .34), 0 0 0 1px rgba(15, 165, 235, .18), inset 0 1px 0 rgba(255, 255, 255, .95);
}

.tp-contact-page .tp-contact-quick-item:focus-visible {
  outline: 0;
  border-color: rgba(15, 165, 235, .64);
  box-shadow: 0 0 0 3px rgba(15, 165, 235, .26), 0 12px 24px -16px rgba(7, 36, 64, .32);
}

.tp-contact-page .tp-contact-quick-item.is-active {
  border-color: rgba(18, 52, 124, .42);
  background: linear-gradient(180deg, rgba(231, 244, 255, .98), rgba(220, 237, 252, .96));
  box-shadow: 0 0 0 2px rgba(18, 52, 124, .2), 0 14px 24px -18px rgba(7, 36, 64, .36), inset 0 1px 0 rgba(255, 255, 255, .95);
}

.tp-contact-page .tp-contact-quick-icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .38rem;
  color: #fff;
  border: 1px solid rgba(18, 52, 124, .88);
  background: linear-gradient(180deg, #0f84cd, rgb(18, 52, 124));
  box-shadow: 0 8px 14px -10px rgba(18, 52, 124, .62);
}

.tp-contact-page .tp-contact-quick-item h3 {
  font-size: .98rem;
  margin: 0 0 .22rem;
  font-weight: 790;
  color: #0f377f;
}

.tp-contact-page .tp-contact-quick-item p {
  margin: 0;
  font-size: .9rem;
  line-height: 1.48;
  color: #445d80;
}

.tp-contact-page .tp-contact-faq-list {
  display: grid;
  gap: .55rem;
}

.tp-contact-page #contact_faq_accordion .card {
  border-radius: 18px !important;
  border: 0 !important;
  box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
  background: #ffffff !important;
}

[data-theme-style="dark"] .tp-contact-page .tp-contact-form-card,
[data-theme-style="dark"] .tp-contact-page .tp-contact-side-card {
  background: linear-gradient(180deg, hsl(218deg 23.65% 16.68%), rgb(0 0 0 / 92%)) !important;
  border-color: rgba(123, 212, 255, .1) !important;
  box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .1), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

[data-theme-style="dark"] .tp-contact-page .tp-contact-quick-item {
  border-color: rgba(99, 170, 231, .24);
  background: linear-gradient(180deg, rgba(16, 33, 56, .92), rgba(10, 22, 38, .92));
  box-shadow: 0 10px 22px -14px rgba(0, 0, 0, .52), inset 0 1px 0 rgba(255, 255, 255, .07);
}

[data-theme-style="dark"] .tp-contact-page .tp-contact-quick-item:hover {
  border-color: rgba(125, 197, 255, .48);
  box-shadow: 0 0 0 1px rgba(86, 177, 245, .26), 0 12px 24px -14px rgba(0, 0, 0, .58), inset 0 1px 0 rgba(255, 255, 255, .08);
}

[data-theme-style="dark"] .tp-contact-page .tp-contact-quick-item.is-active {
  border-color: rgba(125, 197, 255, .58);
  background: linear-gradient(180deg, rgba(23, 51, 83, .95), rgba(15, 36, 60, .95));
  box-shadow: 0 0 0 2px rgba(72, 178, 247, .24), 0 14px 28px -16px rgba(0, 0, 0, .62), inset 0 1px 0 rgba(255, 255, 255, .09);
}

[data-theme-style="dark"] .tp-contact-page .tp-contact-quick-item h3 {
  color: #e6f0ff;
}

[data-theme-style="dark"] .tp-contact-page .tp-contact-section-title {
  color: #eaf2ff;
}

[data-theme-style="dark"] .tp-contact-page .tp-contact-side-illustration img {
  filter: drop-shadow(0 16px 28px rgba(0, 0, 0, .45));
}

[data-theme-style="dark"] .tp-contact-page .tp-contact-quick-item p {
  color: rgba(208, 224, 248, .86);
}

[data-theme-style="dark"] .tp-contact-page #contact_faq_accordion .card {
  background: linear-gradient(180deg, hsl(218deg 23.65% 16.68%), rgb(0 0 0 / 92%)) !important;
  border: 0 !important;
  box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .1), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

@media (max-width: 991.98px) {
  .tp-contact-page .tp-contact-main-col,
  .tp-contact-page .tp-contact-side-col {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .tp-contact-page .tp-contact-side-stack {
    position: static;
    top: auto;
  }

  .tp-contact-page .tp-contact-side-illustration {
    margin: .15rem 0 .95rem;
  }

  .tp-contact-page .tp-contact-side-illustration img {
    width: min(100%, 320px);
  }

  .tp-contact-page .tp-contact-side-panel {
    padding: 0;
  }
}

@media (min-width: 992px) {
  .tp-contact-page .tp-contact-main-col {
    flex: 0 0 60%;
    max-width: 60%;
  }

  .tp-contact-page .tp-contact-side-col {
    flex: 0 0 40%;
    max-width: 40%;
  }
}

@media (max-width: 767.98px) {
  .tp-contact-page .tp-contact-hero .card-body,
  .tp-contact-page .tp-contact-form-card .card-body,
  .tp-contact-page .tp-contact-side-card .card-body {
    padding: 1rem .95rem;
  }

  .tp-contact-page .tp-contact-hero-cta .btn {
    width: 100%;
    justify-content: center;
  }

  .tp-contact-page .tp-contact-side-panel {
    display: none;
  }

  .tp-contact-page .tp-contact-side-illustration img {
    width: min(100%, 260px);
  }
}

/* ============================================
   SPEEDTEST PAGE
============================================ */
.tp-speedtest-page {
  --tp-speed-bg-1: #e9f6ff;
  --tp-speed-bg-2: #f5fbff;
  --tp-speed-card: rgba(255, 255, 255, 0.92);
  --tp-speed-border: rgba(8, 68, 122, 0.16);
  --tp-speed-shadow: 0 22px 48px rgba(3, 31, 66, 0.12);
  --tp-speed-primary: #0ea5e9;
  --tp-speed-primary-dark: #0369a1;
  --tp-speed-upload: #f97316;
}

.tp-speedtest-hero {
  border: 0;
  border-radius: 0;
  padding: .1rem 0 1rem;
  background: transparent;
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.tp-speedtest-hero-actions .tp-transfers-primary-btn {
  min-height: 46px;
  padding: .58rem 1.08rem !important;
  border-radius: .68rem !important;
}

.tp-speedtest-title {
  font-weight: 900 !important;
  font-size: 2rem !important;
  line-height: 1.15;
  color: hsl(221, 39%, 11%) !important;
  letter-spacing: -0.02em;
}

.tp-ip-page-subtitle {
  max-width: 980px;
  line-height: 1.55;
}

.tp-speedtest-ip-only-page .tp-speedtest-hero {
  margin-bottom: 2.4rem !important;
}

.tp-speedtest-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

.tp-speedtest-main .card-body {
  position: relative;
}

.tp-speedtest-main {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

:root {
  --tp-speed-condensed-font: "Bahnschrift SemiCondensed", "Bahnschrift Condensed", "Bahnschrift", "Roboto Condensed", "DIN Condensed", "Arial Narrow", "Trebuchet MS", sans-serif;
}

.tp-speedtest-control-panel-wrap {
  position: relative;
  width: 100%;
  margin: .35rem 0 0;
  filter: drop-shadow(0 10px 14px rgba(8, 28, 56, .1));
  isolation: isolate;
}

.tp-speedtest-control-panel-wrap::before {
    content: "";
    position: absolute;
    left: 2%;
    right: 2%;
    top: -46px;
    height: 118px;
    border-radius: 999px;
    background: radial-gradient(ellipse at 50% 100%, rgba(10, 45, 92, .42) 0%, rgb(10 45 92 / 19%) 42%, rgba(10, 45, 92, 0) 78%);
    filter: blur(14px);
    pointer-events: none;
    z-index: 1;
    opacity: .95;
}

.tp-speedtest-control-panel-art {
  position: relative;
  z-index: 1;
}

.tp-speedtest-control-panel-art {
  width: 100%;
  height: auto;
  display: block;
  user-select: none;
  pointer-events: none;
}

.tp-speedtest-control-panel-content {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}

.tp-speedtest-panel-knob-indicator {
  position: absolute;
  width: 98px;
  height: 98px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  border-radius: 999px;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  text-shadow: 0 2px 5px rgba(4, 18, 40, .42);
  z-index: 8;
  pointer-events: auto;
}

.tp-speedtest-panel-knob-indicator i {
  font-size: 2.25rem;
  line-height: 1;
}

.tp-speedtest-panel-knob-indicator .svg-inline--fa {
  display: var(--fa-display, inline-block);
  height: 3em;
  overflow: visible;
  vertical-align: -.125em;
}

.tp-speedtest-panel-knob-start {
  left: 67px;
  bottom: 157px;
}

.tp-speedtest-panel-knob-restart {
  right: 46px;
  bottom: 155px;
}

.tp-speedtest-panel-knob-start i {
  filter: drop-shadow(0 0 8px rgba(90, 214, 255, .35));
}

.tp-speedtest-panel-knob-restart i {
  filter: drop-shadow(0 0 8px rgba(255, 184, 76, .38));
}

.tp-speedtest-panel-knob-indicator:hover,
.tp-speedtest-panel-knob-indicator:focus {
  transform: translateY(-1px) scale(1.02);
  outline: none;
}

.tp-speedtest-panel-knob-indicator:active {
  transform: translateY(1px) scale(.98);
}

/* CTA motion: subtle pulse for play, continuous rotate for restart */
.tp-speedtest-panel-knob-start:not(.d-none) i,
.tp-speedtest-panel-knob-start:not(.d-none) .svg-inline--fa {
  animation: tp-speedtest-play-pulse 1.7s ease-in-out infinite;
}

.tp-speedtest-page:not(.is-running) .tp-speedtest-panel-knob-restart:not(.d-none) i,
.tp-speedtest-page:not(.is-running) .tp-speedtest-panel-knob-restart:not(.d-none) .svg-inline--fa {
  animation: tp-speedtest-restart-spin 1.85s ease-in-out infinite;
}

@keyframes tp-speedtest-play-pulse {
  0%, 100% { transform: scale(1); filter: drop-shadow(0 0 8px rgba(90, 214, 255, .35)); }
  50% { transform: scale(1.13); filter: drop-shadow(0 0 12px rgba(90, 214, 255, .58)); }
}

@keyframes tp-speedtest-restart-spin {
  0% { transform: rotate(0deg); }
  38% { transform: rotate(360deg); }
  100% { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
  .tp-speedtest-panel-knob-start:not(.d-none) i,
  .tp-speedtest-panel-knob-start:not(.d-none) .svg-inline--fa,
  .tp-speedtest-panel-knob-restart:not(.d-none) i,
  .tp-speedtest-panel-knob-restart:not(.d-none) .svg-inline--fa {
    animation: none !important;
  }
}

.tp-speedtest-control-panel-content .tp-speedtest-gauge,
.tp-speedtest-control-panel-content .tp-speedtest-metric,
.tp-speedtest-control-panel-content .tp-speedtest-stage,
.tp-speedtest-control-panel-content .tp-speedtest-progress {
  pointer-events: auto;
}

.tp-speedtest-control-panel-title {
  position: absolute;
  top: 12.2%;
  left: 8.3%;
  width: 17.5%;
  color: #e5f5ff;
  font-family: var(--tp-speed-condensed-font);
  font-stretch: condensed;
  font-size: clamp(1.18rem, .98rem + 1.1vw, 2.35rem);
  line-height: 1.05;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.tp-speedtest-control-panel-metric {
  position: absolute;
  top: 24.6%;
  width: 17.6%;
  min-height: 33%;
  display: grid;
  gap: 1.08rem;
  align-content: center;
}

.tp-speedtest-control-panel-metric-left {
  left: 2.9%;
}

.tp-speedtest-control-panel-metric-right {
  right: .7%;
}

.tp-speedtest-control-panel-content .tp-speedtest-metric {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: .2rem .1rem;
}

.tp-speedtest-control-panel-content .tp-speedtest-metric-label {
  color: #2fc7ff;
  font-size: clamp(1.14rem, .92rem + .52vw, 1.58rem);
  font-weight: 700;
  margin-bottom: .22rem;
  font-family: var(--tp-speed-condensed-font);
  font-stretch: condensed;
  letter-spacing: .02em;
}

.tp-speedtest-control-panel-content .tp-speedtest-metric-value {
  color: #f2fbff;
  font-size: clamp(1.72rem, 1.36rem + .82vw, 2.55rem);
  font-family: var(--tp-speed-condensed-font);
  font-stretch: condensed;
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: 0;
  text-shadow: 0 1px 0 rgba(10, 20, 40, .36);
  display: inline-flex;
  align-items: baseline;
  gap: .18em;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.tp-speedtest-control-panel-content .tp-speedtest-metric-value small {
  color: #d7ebff;
  font-size: .62em;
  font-weight: 700;
  margin-left: 0rem;
}

.tp-speedtest-control-panel-content .tp-speedtest-metric-download .tp-speedtest-metric-value,
.tp-speedtest-control-panel-content .tp-speedtest-metric-upload .tp-speedtest-metric-value,
.tp-speedtest-control-panel-content .tp-speedtest-metric-ping .tp-speedtest-metric-value,
.tp-speedtest-control-panel-content .tp-speedtest-metric-jitter .tp-speedtest-metric-value {
  color: #f3fbff;
}

.tp-speedtest-control-panel-content .tp-speedtest-gauge {
  position: absolute;
  left: 50%;
  top: 41.5%;
  width: min(49%, 590px);
  transform: translate(-50%, -50%);
  filter: drop-shadow(0 10px 20px rgba(2, 14, 36, .32));
}

.tp-speedtest-control-panel-status {
  position: absolute;
  left: 20.5%;
  right: 20.5%;
  bottom: 5.9%;
  display: grid;
  gap: .26rem;
}

.tp-speedtest-control-panel-status .tp-speedtest-stage {
  color: #eff9ff;
  font-family: var(--tp-speed-condensed-font);
  font-stretch: condensed;
  font-weight: 700;
  font-size: clamp(.98rem, .88rem + .32vw, 1.24rem);
  line-height: 1.05;
  margin: 0;
}

.tp-speedtest-control-panel-status .tp-speedtest-progress {
  height: 13px;
  border-radius: 999px;
  background: rgb(7 20 40 / 0%);
  box-shadow: inset 0 1px 0 rgba(174, 225, 255, .18), inset 0 -2px 4px rgba(0, 0, 0, .46);
}

.tp-speedtest-control-panel-status .tp-speedtest-progress > span {
  background: linear-gradient(90deg, #1588c847, #24ace6);
  box-shadow: 0 0 0 1px rgba(68, 162, 214, .22), inset 0 1px 0 rgba(188, 229, 251, .26);
}

@media (min-width: 1200px) {
  .tp-speedtest-control-panel-wrap {
    max-width: 994px;
    margin: .35rem auto 0;
  }

  .tp-speedtest-control-panel-title {
    top: 79px;
    left: 77px;
    width: 188px;
    font-size: 35px;
    line-height: 1.04;
  }

  .tp-speedtest-control-panel-metric {
    top: 245px;
    width: 176px;
    min-height: 290px;
    gap: 30px;
  }

  .tp-speedtest-control-panel-metric-left {
    left: 50px;
  }

  .tp-speedtest-control-panel-metric-right {
    right: -40px;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-label {
    font-size: 20px;
    margin-bottom: 4px;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-value {
    font-size: 29px;
    line-height: .95;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-value small {
    font-size: 14px;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge {
    top: 360px;
    width: 536px;
  }

  .tp-speedtest-control-panel-status {
    left: 204px;
    right: 204px;
    bottom: 52px;
    height: 62px;
    display: block;
    z-index: 6;
    pointer-events: none;
  }

  .tp-speedtest-control-panel-status .tp-speedtest-stage {
    position: absolute;
    left: 73px;
    right: 64px;
    top: -42px;
    z-index: 3;
    font-size: 26px;
    line-height: .95;
    padding: 0 2px;
    color: #ffffff;
  }

  .tp-speedtest-control-panel-status .tp-speedtest-progress {
    position: absolute;
    left: 58px;
    right: 0;
    bottom: 77px;
    height: 36px;
    z-index: 1;
    width: 477px;
  }
}


.tp-speedtest-post-panel {
  max-width: 100%;
  margin-top: 3rem !important;
  margin-bottom: 1rem;
}

.tp-speedtest-stage {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .75rem;
  color: #0f3d63;
  font-weight: 700;
}

.tp-speedtest-progress {
  width: 100%;
  height: 12px;
  border-radius: 999px;
  background: #dcefff;
  overflow: hidden;
}

.tp-speedtest-progress > span {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #0ea5e9, #22d3ee);
  transition: width .2s ease;
}

.tp-speedtest-preflight {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
  padding: 0;
}

.tp-speedtest-analysis-heading {
  padding: .35rem .12rem 0;
  margin-top: 2.6rem;
  display: flex;
  align-items: center;
  gap: .85rem;
}

.tp-speedtest-analysis-heading:not(.tp-speedtest-measurement-heading) {
  margin-bottom: 3rem !important;
}

.tp-speedtest-measurement-heading h2 {
  display: inline-flex;
  align-items: center;
  line-height: 1.05;
  transform: translateY(-6px);
}

.tp-speedtest-control-panel-content .tp-speedtest-gauge-ring {
  background:
    conic-gradient(
      from 240deg,
      #0ea5e9 0deg,
      #22d3ee var(--tp-speed-angle),
      #10274300 var(--tp-speed-angle),
      #10274300 240deg,
      transparent 240deg,
      transparent 360deg
    );
}

.tp-speedtest-control-panel-content .tp-speedtest-live-value {
  position: absolute;
  top: 84px;
  left: 50%;
  transform: translateX(-50%);
  margin-top: 0;
  line-height: 1;
  z-index: 4;
}

.tp-speedtest-control-panel-content .tp-speedtest-live-unit {
  position: absolute;
  top: 126px;
  left: 50%;
  transform: translateX(-50%);
  margin-top: 0;
  margin-bottom: 0;
  z-index: 4;
}

.tp-speedtest-control-panel-content .tp-speedtest-gauge-center {
  justify-content: center;
  padding-top: 0;
}

.tp-speedtest-control-panel-content .tp-speedtest-live-context {
  position: absolute;
  top: 230px;
  left: 0;
  right: 0;
  margin-top: 0;
  z-index: 4;
}

.tp-speedtest-control-panel-content .tp-speedtest-live-max {
  position: absolute;
  bottom: 42px;
  left: 50%;
  transform: translateX(-50%);
  margin-top: 0;
  z-index: 4;
}

.tp-speedtest-analysis-heading::after {
  content: "";
  flex: 1 1 auto;
  min-width: 0;
  height: 1px;
  background: #e7edf4;
}

[data-theme-style="dark"] .tp-speedtest-analysis-heading::after {
  background: rgba(95, 170, 227, .18);
}

[data-theme-style="dark"] .tp-speedtest-title {
  color: #e8f4ff !important;
}

[data-theme-style="dark"] .tp-speedtest-subtitle {
  color: #c6deef !important;
}

[data-theme-style="dark"] .tp-speedtest-quality {
  border-color: rgba(95, 170, 227, .24);
  background: linear-gradient(180deg, rgba(24, 43, 67, .95), rgba(19, 33, 53, .95));
  box-shadow: 0 10px 24px rgba(4, 12, 26, .36), inset 0 1px 0 rgba(170, 220, 255, .08);
}

[data-theme-style="dark"] .tp-speedtest-quality-head {
  color: #e8f6ff;
}

[data-theme-style="dark"] .tp-speedtest-quality-hint {
  color: #a6c8e3;
}

[data-theme-style="dark"] .tp-speedtest-quality-arrow {
  color: #66c3ff;
}

[data-theme-style="dark"] .tp-speedtest-transfer-estimate-item {
  background: linear-gradient(180deg, rgba(30, 51, 77, .96), rgba(23, 41, 64, .96));
  border-color: rgba(95, 170, 227, .24);
  box-shadow: inset 0 1px 0 rgba(184, 229, 255, .08);
}

[data-theme-style="dark"] .tp-speedtest-transfer-estimate-item span {
  color: #9cc8e6;
}

[data-theme-style="dark"] .tp-speedtest-transfer-estimate-item strong {
  color: #eef8ff;
}

[data-theme-style="dark"] .tp-speedtest-month-item {
  border-color: rgba(95, 170, 227, .24);
  background: linear-gradient(180deg, rgba(30, 51, 77, .96), rgba(23, 41, 64, .96));
  box-shadow: inset 0 1px 0 rgba(184, 229, 255, .08);
}

[data-theme-style="dark"] .tp-speedtest-month-item span {
  color: #9cc8e6;
}

[data-theme-style="dark"] .tp-speedtest-month-item strong {
  color: #eef8ff;
}

[data-theme-style="dark"] .tp-speedtest-month-item-meter {
  background: rgba(146, 203, 240, .18);
}

[data-theme-style="dark"] .tp-speedtest-month-count {
  color: #9edbff;
  background: rgba(14, 165, 233, .12);
  border-color: rgba(95, 170, 227, .26);
}

[data-theme-style="dark"] .tp-speedtest-provider-pill {
  background: rgba(14, 165, 233, .12);
  border-color: rgba(95, 170, 227, .26);
  color: #aee1ff;
}

[data-theme-style="dark"] .tp-speedtest-provider-pill strong {
  color: #eaf8ff;
}

.tp-speedtest-preflight-status {
  display: inline;
  margin: 0;
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  color: inherit;
}

.tp-speedtest-preflight-grid {
  margin-top: 3rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .82rem .82rem;
}

.tp-speedtest-preflight-machine {
  position: relative;
  max-width: 860px;
  margin: .85rem auto 0;
}

.tp-speedtest-preflight-machine-art {
  width: 100%;
  height: auto;
  display: block;
  user-select: none;
  pointer-events: none;
  filter: drop-shadow(0 14px 22px rgba(11, 48, 91, .18));
}

.tp-speedtest-preflight-machine-content {
  position: absolute;
  left: 6.2%;
  right: 6.2%;
  top: 29%;
  bottom: 11.8%;
  display: flex;
  flex-direction: column;
  --tp-ip-row-offset-y: -14px;
}

.tp-speedtest-copy-ip-box {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgb(255 255 255 / 42%);
  background: linear-gradient(180deg, rgb(31 70 141), rgb(1 27 86));
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 44px;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(202, 240, 255, .44), inset 0 -5px 10px rgba(5, 34, 69, .32), 0 8px 14px rgba(9, 37, 76, .2);
  transition: transform .14s ease, filter .16s ease, box-shadow .16s ease, background .16s ease;
  margin-top: -18px;
}

.tp-speedtest-copy-ip-box i {
  font-size: 1.18rem;
  text-shadow: 0 1px 0 rgba(255, 255, 255, .3), 0 3px 6px rgba(7, 34, 67, .26);
}

.tp-speedtest-copy-ip-box:hover,
.tp-speedtest-copy-ip-box:focus {
  transform: translateY(-1px);
  filter: brightness(1.07);
  box-shadow: inset 0 1px 0 rgba(208, 244, 255, .54), inset 0 -5px 10px rgba(5, 34, 69, .34), 0 10px 16px rgba(9, 37, 76, .22);
  outline: none;
}

.tp-speedtest-copy-ip-box:active {
  transform: translateY(1px) scale(.98);
  filter: brightness(.97);
  box-shadow: inset 0 2px 7px rgba(6, 32, 64, .5), inset 0 -1px 6px rgba(170, 223, 255, .16), 0 4px 8px rgba(9, 37, 76, .18);
}

.tp-speedtest-preflight-machine-head {
  min-height: 48%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  padding: 0 1.15rem 0 4rem;
}

.tp-speedtest-preflight-ip-label {
  color: #ffffff;
  font-family: var(--tp-speed-condensed-font);
  font-stretch: condensed;
  font-size: 2.2rem;
  text-transform: uppercase;
  letter-spacing: .02em;
  font-weight: 800;
  transform: translate(46px, -5px);
}

.tp-speedtest-preflight-ip-row {
  min-height: 52%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 .65rem 0;
  transform: translateY(var(--tp-ip-row-offset-y));
}

.tp-speedtest-preflight-grid > div {
  background: linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(245, 250, 255, .9));
  border: 1px solid rgba(15, 165, 235, .2);
  border-radius: 16px;
  padding: 1.5rem;
  box-shadow: var(--tp-dashboard-card-shadow);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .34s ease, transform .34s ease;
  cursor: help;
}

.tp-speedtest-preflight-grid > div.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.tp-speedtest-preflight-grid span {
  display: block;
  color: #3f84ba;
  font-size: 0.80rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 700;
}

.tp-speedtest-preflight-grid strong {
  display: block;
  /* color: #163f68; */
  font-size: 1.15rem;
  margin-top: .18rem;
  letter-spacing: .02em;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  min-height: 1.2em;
}

.tp-speedtest-preflight-actions {
  margin-top: 1rem;
  display: flex;
  justify-content: center;
  gap: .75rem;
  flex-wrap: wrap;
}

.tp-speedtest-preflight-actions .btn {
  min-width: 220px;
  min-height: 56px;
  border-radius: 14px !important;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: .01em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.tp-speedtest-start-btn,
.tp-speedtest-restart-btn {
  border: 0 !important;
  color: #ffffff !important;
  font-weight: 800;
  letter-spacing: .01em;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.34), inset 0 -8px 14px rgba(6, 24, 52, .2), 0 8px 16px rgba(7, 37, 76, .16);
  transition: transform .14s ease, filter .16s ease, box-shadow .16s ease;
}

.tp-speedtest-start-btn {
  background: linear-gradient(180deg, #2cbcff 0%, #0fa5eb 60%, #0a88cb 100%) !important;
}

.tp-speedtest-restart-btn {
  background: linear-gradient(180deg, #ffac3d 0%, #ff8503 62%, #e36f00 100%) !important;
  box-shadow: inset 0 1px 0 rgba(255, 241, 219, .45), inset 0 -8px 14px rgba(106, 50, 0, .24), 0 8px 16px rgba(111, 59, 5, .16);
}

.tp-speedtest-start-btn:hover,
.tp-speedtest-restart-btn:hover,
.tp-speedtest-start-btn:focus,
.tp-speedtest-restart-btn:focus {
  transform: translateY(-1px);
  filter: brightness(1.04);
  outline: none;
}

.tp-speedtest-start-btn:active,
.tp-speedtest-restart-btn:active {
  transform: translateY(1px) scale(.99);
  filter: brightness(.98);
}

.tp-speedtest-btn-icon {
  color: #ffffff !important;
  font-size: .98rem;
  text-shadow: 0 1px 0 rgba(0,0,0,.2);
}

.tp-speedtest-preflight-display {
  display: flex;
  flex-wrap: nowrap;
  gap: 0;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 94px;
  overflow-x: hidden;
  overflow-y: hidden;
  padding: .08rem 0;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.tp-speedtest-preflight-display::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
}

.tp-speedtest-preflight-display-large {
  font-size: 0;
  line-height: 0;
  gap: 0;
  margin-inline: auto;
  width: 100%;
  max-width: 100%;
  --tp-flap-gap: 2px;
  --tp-flap-cell-size: 42px;
  --tp-flap-cell-height: 70px;
  --tp-flap-glyph-size: 2.56rem;
  --tp-flap-glyph-y: 10px;
  border-radius: 14px;
  position: relative;
  z-index: 1;
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: .2rem .08rem;
}

.tp-speedtest-preflight-display-large[data-tp-ip-mode="compact"] {
  --tp-flap-cell-size: 30px;
  --tp-flap-cell-height: 50px;
  --tp-flap-glyph-size: 1.75rem;
  --tp-flap-glyph-y: 6px;
  --tp-flap-gap: 1px;
}

.tp-speedtest-preflight-display-large[data-tp-ip-mode="tiny"] {
  --tp-flap-cell-size: 24px;
  --tp-flap-cell-height: 40px;
  --tp-flap-glyph-size: 1.35rem;
  --tp-flap-glyph-y: 4px;
  --tp-flap-gap: 1px;
}

.tp-speedtest-preflight-display-large::after {
  display: none;
}

.tp-flap-char {
  position: relative;
  flex: 0 0 var(--tp-flap-cell-size);
  width: var(--tp-flap-cell-size);
  min-width: var(--tp-flap-cell-size);
  height: var(--tp-flap-cell-height);
  border-radius: 10px;
  background: linear-gradient(180deg, #83dcff 0%, #58c9f8 56%, #34acdf 100%);
  border: 1px solid rgba(24, 126, 173, .62);
  box-shadow: inset 0 1px 0 rgba(237, 252, 255, .9), inset 0 -5px 10px rgba(20, 112, 150, .25), 0 0 0 1px rgba(4, 21, 52, .32), 0 3px 0 rgba(2, 9, 24, .36), 0 9px 11px -7px rgba(2, 9, 22, .62);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  isolation: isolate;
  transform-origin: 50% 90%;
}

.tp-flap-char:not(.is-space) {
  margin-right: var(--tp-flap-gap);
}

.tp-flap-char.tp-flap-tone-0:not(.is-space),
.tp-flap-char.tp-flap-dot:not(.is-space),
.tp-flap-char.tp-flap-tone-1:not(.is-space),
.tp-flap-char.tp-flap-tone-2:not(.is-space),
.tp-flap-char.tp-flap-tone-3:not(.is-space) {
  background: linear-gradient(180deg, #12377d 0%, #0d2e6d 46%, #08245e 100%);
  border-color: rgba(156, 199, 238, .34);
  box-shadow: inset 0 1px 0 rgba(222, 243, 255, .22), inset 0 -4px 8px rgba(5, 16, 40, .46), 0 0 0 1px rgba(4, 21, 52, .36), 0 3px 0 rgba(2, 9, 24, .42), 0 10px 12px -8px rgba(2, 9, 22, .68);
}

.tp-flap-char::after {
  content: "";
  position: absolute;
  left: 1px;
  right: 1px;
  top: 50%;
  margin-top: -1px;
  height: 1px;
  background: linear-gradient(90deg, rgba(8, 16, 33, .92), rgba(190, 213, 238, .42) 50%, rgba(8, 16, 33, .92));
  box-shadow: 0 1px 0 rgba(255, 255, 255, .07);
  z-index: 4;
  pointer-events: none;
}

.tp-flap-char::before {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  top: 3px;
  height: 9px;
  border-radius: 8px 8px 10px 10px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .26), rgba(255, 255, 255, .05) 56%, rgba(255, 255, 255, 0) 100%);
  z-index: 2;
  pointer-events: none;
}

.tp-flap-char[data-target-char="."] .tp-flap-glyph,
.tp-flap-char[data-target-char=":"] .tp-flap-glyph {
  opacity: 1;
}

.tp-flap-image {
  display: none !important;
}

.tp-flap-glyph {
  position: relative;
  z-index: 3;
  display: inline-block !important;
  font-family: var(--tp-speed-condensed-font);
  font-stretch: condensed;
  font-size: var(--tp-flap-glyph-size);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.035em;
  color: #eef7ff;
  -webkit-text-stroke: .36px rgba(7, 32, 73, .45);
  text-shadow: 0 1px 0 rgba(255, 255, 255, .2), 0 2px 2px rgba(2, 10, 24, .46);
  font-variant-numeric: tabular-nums lining-nums;
  transform: translateY(var(--tp-flap-glyph-y)) scaleX(.82) scaleY(1);
}

.tp-flap-char.is-space {
  flex: 0 0 4px;
  width: 4px;
  min-width: 4px;
  height: 68px;
  border: 0;
  background: transparent;
  box-shadow: none;
  margin-right: 0;
}

.tp-flap-char.is-space::after {
  display: none;
}

.tp-speedtest-preflight-display.is-flipping .tp-flap-char:not(.is-space) {
  transform: none;
}

.tp-flap-char.is-ticking .tp-flap-image {
  animation: none;
}

.tp-flap-char.is-ticking .tp-flap-glyph {
  animation: tp-flap-tick-glyph .15s cubic-bezier(.2,.7,.18,1) 1;
}

@keyframes tp-flap-tick-glyph {
  0% { transform: perspective(560px) rotateX(-72deg) scaleY(.62) translateY(var(--tp-flap-glyph-y)); opacity: .65; }
  60% { transform: perspective(560px) rotateX(14deg) scaleY(1.02) translateY(var(--tp-flap-glyph-y)); opacity: .95; }
  100% { transform: perspective(560px) rotateX(0deg) scaleY(1) translateY(var(--tp-flap-glyph-y)); opacity: 1; }
}

.tp-speedtest-preflight-swallow {
  display: none;
}

[data-theme-style="dark"] .tp-speedtest-preflight-ip-row {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

[data-theme-style="dark"] .tp-speedtest-preflight-ip-label {
  color: #b4e7ff;
}

[data-theme-style="dark"] .tp-speedtest-preflight-grid > div {
  background: linear-gradient(180deg, rgba(24, 43, 67, .95), rgba(19, 33, 53, .95));
  border-color: rgba(95, 170, 227, .22);
}

[data-theme-style="dark"] .tp-speedtest-preflight-grid span {
  color: #8bcdfb;
}

[data-theme-style="dark"] .tp-speedtest-preflight-grid strong {
  color: #e8f6ff;
}

[data-theme-style="dark"] .tp-speedtest-preflight-display-large {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

[data-theme-style="dark"] .tp-speedtest-copy-ip-box {
  background: linear-gradient(180deg, rgba(31, 124, 204, .95), rgba(16, 78, 147, .95));
  border-color: rgba(95, 170, 227, .32);
  box-shadow: inset 0 1px 0 rgba(230, 248, 255, .12), inset 0 -6px 12px rgba(3, 11, 24, .34);
}

[data-theme-style="dark"] .tp-flap-glyph {
  color: #eef8ff;
  text-shadow: 0 2px 0 rgba(4, 31, 61, .34), 0 4px 8px rgba(0, 0, 0, .36);
}

.tp-speedtest-preflight.is-done .tp-speedtest-preflight-status { color: inherit; }

.tp-speedtest-gauge-wrap {
  display: grid;
  grid-template-columns: minmax(320px, 1fr) minmax(320px, 1fr);
  gap: 1.25rem;
  align-items: start;
  transition: opacity .28s ease, transform .28s ease, filter .28s ease;
}

.tp-speedtest-gauge {
  position: relative;
  width: min(100%, 340px);
  margin: 0 auto;
  aspect-ratio: 1 / 0.975;
  --tp-gauge-tick-distance: 162px;
  --tp-gauge-label-distance: 144px;
  filter: drop-shadow(0 8px 18px rgba(8, 50, 92, .12));
}

.tp-speedtest-gauge-ring {
  --tp-speed-angle: 0deg;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background:
    conic-gradient(
      from 240deg,
      #0ea5e9 0deg,
      #22d3ee var(--tp-speed-angle),
      #d4eefe var(--tp-speed-angle),
      #d4eefe 240deg,
      transparent 240deg,
      transparent 360deg
    );
  mask: radial-gradient(circle at center, transparent 54%, #000 55%);
  -webkit-mask: radial-gradient(circle at center, transparent 54%, #000 55%);
  transition: background .22s linear, filter .24s ease;
}

.tp-speedtest-page.is-running .tp-speedtest-gauge-ring {
  filter: saturate(1.2) brightness(1.03);
}

.tp-speedtest-control-panel-content .tp-speedtest-gauge-ring {
  width: calc(100% - 36px);
  height: calc(100% - 36px);
  margin: 20px auto 0;
}

.tp-speedtest-gauge-ticks {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}

.tp-speedtest-gauge-tick {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(var(--tp-tick-angle)) translateY(calc(-1 * var(--tp-gauge-tick-distance)));
  transform-origin: center;
  border-radius: 999px;
}

.tp-speedtest-gauge-tick.is-minor {
  width: 2px;
  height: 8px;
  background: rgba(63, 103, 138, .42);
}

.tp-speedtest-gauge-tick.is-major {
  width: 2px;
  height: 14px;
  background: rgba(24, 71, 108, .65);
}

.tp-speedtest-gauge-center {
  position: absolute;
  inset: 15%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 25%, rgba(255, 255, 255, 0.95), rgba(232, 246, 255, 0.9)),
    linear-gradient(180deg, #ffffff, #e8f6ff);
  border: 1px solid rgba(14, 165, 233, 0.25);
  box-shadow: inset 0 0 0 10px rgba(255, 255, 255, 0.55), inset 0 -20px 32px rgba(14, 165, 233, 0.08);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
}

.tp-speedtest-gauge-center::after {
  content: "";
  position: absolute;
  inset: -20%;
  background: conic-gradient(from 200deg, transparent 0deg, rgba(14, 165, 233, .08) 80deg, transparent 160deg);
  animation: tp-speedtest-center-sheen 4.6s linear infinite;
  pointer-events: none;
}

.tp-speedtest-gauge-center > * {
  position: relative;
  z-index: 1;
}

@keyframes tp-speedtest-center-sheen {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.tp-speedtest-live-value {
  font-size: clamp(1.7rem, 1.4rem + 1.2vw, 2.6rem);
  font-weight: 800;
  color: #05345d;
  line-height: 1;
  margin-top: .34rem;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
}

.tp-speedtest-live-unit {
  margin-top: -.42rem;
  margin-bottom: .12rem;
  color: #0a4c74;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .76rem;
  opacity: .88;
}

.tp-speedtest-live-context {
  margin-top: .55rem;
  color: #0d4c75;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.tp-speedtest-live-max {
  margin-top: .38rem;
  color: #49708e;
  font-size: .68rem;
  font-weight: 600;
  line-height: 1.1;
}

.tp-speedtest-live-max span,
.tp-speedtest-live-max strong {
  display: block;
}

.tp-speedtest-live-max strong {
  color: #265578;
  font-weight: 800;
  margin-top: .08rem;
}

.tp-speedtest-gauge-scale {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.tp-speedtest-gauge-scale span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(var(--tp-gauge-angle)) translateY(calc(-1 * var(--tp-gauge-label-distance))) rotate(calc(var(--tp-gauge-angle) * -1));
  transform-origin: center;
  color: #62809b;
  font-size: .74rem;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.tp-speedtest-gauge-needle {
  --tp-speed-needle-angle: -120deg;
  position: absolute;
  left: 50%;
  top: 50%;
  width: 4px;
  height: 39%;
  border-radius: 999px;
  transform-origin: 50% 100%;
  transform: translate(-50%, -100%) rotate(var(--tp-speed-needle-angle));
  background: linear-gradient(180deg, #f97316 0%, #c2410c 100%);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .5), 0 6px 16px rgba(194, 65, 12, .35);
  transition: transform .2s cubic-bezier(.2,.8,.2,1);
  z-index: 3;
}

.tp-speedtest-gauge-needle::before {
  content: none;
}

.tp-speedtest-page.is-running .tp-speedtest-gauge-needle::before {
  animation: tp-speedtest-needle-pulse 1.15s ease-in-out infinite;
}

.tp-speedtest-gauge-needle::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 14px;
  height: 14px;
  transform: translate(-50%, 50%);
  border-radius: 50%;
  background: #0f355a;
  box-shadow: 0 0 0 2px rgba(255,255,255,.8);
}

@keyframes tp-speedtest-needle-pulse {
  0% { box-shadow: 0 0 0 2px rgba(255,255,255,.7), 0 0 0 0 rgba(249,115,22,.35); }
  100% { box-shadow: 0 0 0 2px rgba(255,255,255,.7), 0 0 0 9px rgba(249,115,22,0); }
}

.tp-speedtest-results {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
}

.tp-speedtest-quality-standalone {
  grid-column: auto;
}

.tp-speedtest-phase {
  grid-column: 1 / -1;
  border: 1px solid rgba(8, 68, 122, 0.14);
  border-radius: 14px;
  background: linear-gradient(180deg, #fbfeff, #edf8ff);
  padding: .72rem .84rem;
}

.tp-speedtest-phase-title {
  color: #305f86;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 800;
}

.tp-speedtest-phase-subtitle {
  color: #0a4c74;
  font-size: .95rem;
  font-weight: 700;
  margin-top: .24rem;
}

.tp-speedtest-checklist {
  list-style: none;
  margin: .54rem 0 0;
  padding: 0;
  display: grid;
  gap: .34rem;
}

.tp-speedtest-checklist li {
  display: flex;
  align-items: center;
  gap: .46rem;
  color: #4d6f8b;
  font-size: .84rem;
  font-weight: 600;
}

.tp-speedtest-checklist li i {
  width: 15px;
  text-align: center;
  color: #80a6c3;
  font-size: .84rem;
}

.tp-speedtest-checklist li.is-pending i::before {
  content: "\f111";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
}

.tp-speedtest-checklist li.is-running i {
  color: #0ea5e9;
  animation: tp-speedtest-check-spin 1s linear infinite;
}

.tp-speedtest-checklist li.is-running i::before {
  content: "\f1ce";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
}

.tp-speedtest-checklist li.is-running span {
  color: #0d4f77;
}

.tp-speedtest-checklist li.is-done i {
  color: #0f766e;
}

.tp-speedtest-checklist li.is-done i::before {
  content: "\f00c";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
}

@keyframes tp-speedtest-check-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.tp-speedtest-plane-track {
  position: relative;
  margin-top: .58rem;
  height: 34px;
  border-radius: 999px;
  background: linear-gradient(180deg, #f8fdff, #eaf7ff);
  border: 1px solid rgba(8, 68, 122, 0.14);
  overflow: hidden;
}

.tp-speedtest-plane-track::before {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  top: 50%;
  height: 2px;
  transform: translateY(-50%);
  background: repeating-linear-gradient(90deg, rgba(14, 165, 233, .36) 0 12px, transparent 12px 20px);
}

.tp-speedtest-plane {
  --tp-plane-progress: 0;
  position: absolute;
  left: calc(8px + (var(--tp-plane-progress) * (100% - 30px)));
  top: 50%;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  color: #ffffff;
  background: linear-gradient(180deg, #0ea5e9, #0369a1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: translate(0, -50%);
  transition: left .16s linear;
  box-shadow: 0 4px 12px rgba(3, 105, 161, .3);
}

.tp-speedtest-plane i {
  font-size: .63rem;
}

.tp-speedtest-transfer-estimate-item {
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(15, 165, 235, .24);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .85);
  padding: .5rem .6rem;
  text-align: center;
}

.tp-speedtest-transfer-estimate-item span {
  display: block;
  color: #537490;
  font-size: .76rem;
  font-weight: 700;
}

.tp-speedtest-transfer-estimate-item strong {
  display: block;
  color: #083f67;
  font-size: .92rem;
  font-weight: 800;
  margin-top: .08rem;
}

.tp-speedtest-quality {
    grid-column: 1 / -1;
    border: 1px solid rgba(15, 165, 235, .34);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(211, 236, 252, .92), rgba(236, 248, 255, .96));
    box-shadow: var(--tp-dashboard-card-shadow), 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9);
    padding: 1.5rem;
}

.tp-speedtest-quality-head {
    font-size: 1.4rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.tp-speedtest-quality-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 1rem;
  align-items: stretch;
}

.tp-speedtest-quality-left {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 100%;
  padding-right: 3.2rem;
}

.tp-speedtest-quality-right {
  display: grid;
  grid-template-columns: 1fr;
  gap: .58rem;
}

.tp-speedtest-quality-hint {
  color: #2a5678;
  font-size: .98rem;
  line-height: 1.45;
  max-width: 95%;
}

.tp-speedtest-quality-arrow {
  position: absolute;
  top: 50%;
  right: .45rem;
  transform: translateY(-50%);
  color: #0e7dbe;
  opacity: .88;
  font-size: 2.25rem;
  text-shadow: 0 2px 10px rgba(14, 125, 190, .22);
  pointer-events: none;
}

.tp-speedtest-quality-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: .34rem .64rem;
  font-size: .82rem;
  font-weight: 800;
  border: 1px solid transparent;
  margin-bottom: .95rem;
}

.tp-speedtest-quality-badge.is-pending {
    color: #0a4c74;
    background: rgba(14, 165, 233, .12);
    border-color: rgba(14, 165, 233, .25);
    margin-bottom: 0.9rem;
}

.tp-speedtest-quality-badge.is-weak {
  color: #9a3412;
  background: rgba(249, 115, 22, .14);
  border-color: rgba(194, 65, 12, .3);
}

.tp-speedtest-quality-badge.is-basic {
  color: #854d0e;
  background: rgba(234, 179, 8, .16);
  border-color: rgba(161, 98, 7, .28);
}

.tp-speedtest-quality-badge.is-good {
  color: #1d4ed8;
  background: rgba(59, 130, 246, .14);
  border-color: rgba(29, 78, 216, .25);
}

.tp-speedtest-quality-badge.is-very-good {
  color: #065f46;
  background: rgba(16, 185, 129, .15);
  border-color: rgba(6, 95, 70, .25);
}

.tp-speedtest-quality-badge.is-excellent {
  color: #14532d;
  background: rgba(34, 197, 94, .16);
  border-color: rgba(22, 101, 52, .3);
}

.tp-speedtest-metric {
  border: 1px solid rgba(8, 68, 122, 0.12);
  border-radius: 14px;
  background: #ffffff;
  padding: .82rem .9rem;
}

.tp-speedtest-metric-label {
  color: #52718d;
  font-size: .84rem;
  font-weight: 600;
  margin-bottom: .35rem;
}

.tp-speedtest-metric-value {
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1.15;
  color: #083f67;
  font-variant-numeric: tabular-nums;
}

.tp-speedtest-metric-download .tp-speedtest-metric-value { color: #0369a1; }
.tp-speedtest-metric-upload .tp-speedtest-metric-value { color: #c2410c; }
.tp-speedtest-metric-ping .tp-speedtest-metric-value { color: #0f766e; }
.tp-speedtest-metric-jitter .tp-speedtest-metric-value { color: #7c2d12; }
.tp-speedtest-metric-datacenter {
  grid-column: 1 / -1;
}

.tp-speedtest-metric-value small {
  font-size: .8rem;
  font-weight: 600;
  color: #4a6b88;
}

.tp-speedtest-metric-datacenter .tp-speedtest-metric-value {
  font-size: 1.05rem;
  color: #0b4f78;
}

.tp-speedtest-connection-list {
  margin: 0;
  display: grid;
  grid-template-columns: minmax(120px, 45%) minmax(0, 1fr);
  row-gap: .65rem;
  column-gap: .75rem;
  font-size: .95rem;
}

.tp-speedtest-connection-list dt {
  margin: 0;
  color: #5b7892;
  font-weight: 600;
}

.tp-speedtest-connection-list dd {
  margin: 0;
  color: #063a63;
  font-weight: 700;
  word-break: break-word;
}

.tp-speedtest-month-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .7rem;
}

.tp-speedtest-month-arcade {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .7rem;
}

.tp-speedtest-month-arcade-card {
  border-radius: 15px;
  border: 1px solid rgba(15, 165, 235, .26);
  background: linear-gradient(160deg, rgba(9, 33, 76, .96), rgba(8, 56, 108, .95));
  box-shadow: inset 0 1px 0 rgba(160, 218, 255, .2), 0 8px 22px rgba(3, 28, 60, .14);
  padding: .82rem .86rem;
}

.tp-speedtest-month-arcade-label {
  display: block;
  color: #9eddff;
  font-size: .78rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-weight: 700;
}

.tp-speedtest-month-arcade-value {
  display: block;
  color: #ffffff;
  font-weight: 900;
  font-size: 1.52rem;
  line-height: 1.08;
  margin-top: .26rem;
}

.tp-speedtest-month-arcade-value small {
  font-size: .58em;
  font-weight: 700;
  color: #b4e8ff;
}

.tp-speedtest-month-arcade-track {
  position: relative;
  margin-top: .62rem;
  border-radius: 999px;
  height: 10px;
  background: rgba(148, 210, 245, .2);
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, .24);
}

.tp-speedtest-month-arcade-track > span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #13a8ef, #66ddff);
  box-shadow: 0 0 10px rgba(84, 208, 255, .45);
}

.tp-speedtest-month-arcade-card.is-upload .tp-speedtest-month-arcade-track > span {
  background: linear-gradient(90deg, #ff8f23, #ffbf52);
  box-shadow: 0 0 10px rgba(255, 165, 70, .44);
}

.tp-speedtest-month-arcade-card.is-ping .tp-speedtest-month-arcade-track > span,
.tp-speedtest-month-arcade-track.is-inverse > span {
  background: linear-gradient(90deg, #40e1a8, #8af7ca);
  box-shadow: 0 0 10px rgba(79, 227, 175, .4);
}

.tp-speedtest-month-item {
  border: 1px solid rgba(15, 165, 235, .24);
  border-radius: 14px;
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .86);
  padding: .72rem .8rem;
}

.tp-speedtest-month-item span {
  display: block;
  color: #5b7892;
  font-size: .82rem;
  margin-bottom: .2rem;
}

.tp-speedtest-month-item strong {
  color: #053a62;
  font-size: 1rem;
  font-weight: 800;
}

.tp-speedtest-month-item-meter {
  margin-top: .5rem;
  height: 7px;
  border-radius: 999px;
  background: rgba(15, 165, 235, .13);
  overflow: hidden;
}

.tp-speedtest-month-item-meter > span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #0da4ea, #4bd4ff);
}

.tp-speedtest-month-item-meter.is-upload > span {
  background: linear-gradient(90deg, #ff9f35, #ffd17c);
}

.tp-speedtest-month-item-meter.is-inverse > span {
  background: linear-gradient(90deg, #2fcf9d, #7af2c2);
}

.tp-speedtest-month-count {
  color: #0a4c74;
  background: rgba(14, 165, 233, 0.14);
  border: 1px solid rgba(14, 165, 233, 0.24);
  border-radius: 999px;
  padding: .3rem .68rem;
  font-size: .82rem;
  font-weight: 700;
}

.tp-speedtest-provider-list {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}

.tp-speedtest-provider-pill {
  border-radius: 999px;
  background: rgba(14, 165, 233, 0.12);
  border: 1px solid rgba(15, 165, 235, .28);
  color: #0a4d75;
  font-size: .8rem;
  font-weight: 600;
  padding: .3rem .6rem;
}

.tp-speedtest-provider-pill strong {
  margin-left: .32rem;
  color: #04426a;
}

@media (max-width: 1100px) {
  .tp-speedtest-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 880px) {
  .tp-speedtest-gauge-wrap {
    grid-template-columns: 1fr;
  }

  .tp-speedtest-preflight-machine {
    max-width: 760px;
  }

  .tp-speedtest-preflight-machine-content {
    left: 7.2%;
    right: 7.2%;
    top: 29.6%;
    bottom: 11.8%;
    --tp-ip-row-offset-y: -11px;
  }

  .tp-speedtest-preflight-machine-head {
    padding: 0 1.05rem 0 1.35rem;
  }

  .tp-speedtest-preflight-ip-label {
    font-size: 1.55rem;
    transform: translate(24px, -5px);
  }

  .tp-speedtest-preflight-actions .btn {
    min-width: 190px;
    min-height: 52px;
  }

  .tp-speedtest-preflight-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tp-speedtest-month-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tp-speedtest-month-arcade {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 561px) and (max-width: 1199px) {
  .tp-speedtest-control-panel-wrap {
    max-width: 994px;
    margin: .3rem auto 0;
    container-type: inline-size;
  }

  .tp-speedtest-control-panel-title {
    top: 7.95cqw;
    left: 7.75cqw;
    width: 18.91cqw;
    font-size: clamp(1rem, 3.52cqw, 2.15rem);
    line-height: 1.04;
  }

  .tp-speedtest-control-panel-metric {
    top: 24.65cqw;
    width: 17.71cqw;
    min-height: 29.17cqw;
    gap: 3.02cqw;
  }

  .tp-speedtest-control-panel-metric-left { left: 5.03cqw; }
  .tp-speedtest-control-panel-metric-right { right: -4.02cqw; }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-label {
    font-size: clamp(.66rem, 2.01cqw, 1.15rem);
    margin-bottom: .25cqw;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-value {
    font-size: clamp(1rem, 3.22cqw, 1.9rem);
    line-height: .95;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-value small {
    font-size: clamp(.5rem, 1.41cqw, .82rem);
    margin-left: 0;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge {
    top: 36.22cqw;
    width: 53.92cqw;
    --tp-gauge-tick-distance: 16.3cqw;
    --tp-gauge-label-distance: 14.5cqw;
  }

  .tp-speedtest-gauge-scale span {
    font-size: clamp(.52rem, 1.02cqw, .9rem);
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-value {
    top: 8.45cqw;
    font-size: clamp(1.5rem, 4.3cqw, 2.8rem);
    line-height: .95;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-unit {
    top: 12.68cqw;
    font-size: clamp(.58rem, 1.1cqw, .92rem);
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-context {
    top: 23.14cqw;
    font-size: clamp(.52rem, .95cqw, .82rem);
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-max {
    bottom: 4.22cqw;
    font-size: clamp(.5rem, .85cqw, .78rem);
  }

  .tp-speedtest-panel-knob-indicator {
    width: 9.86cqw;
    height: 9.86cqw;
  }

  .tp-speedtest-panel-knob-indicator .svg-inline--fa {
    height: clamp(1.2em, 2.45cqw, 2.5em);
    width: clamp(1.2em, 2.45cqw, 2.5em);
  }

  .tp-speedtest-panel-knob-indicator i {
    font-size: clamp(1.2rem, 2.3cqw, 2.1rem);
  }

  .tp-speedtest-panel-knob-start { left: 6.74cqw; bottom: 15.79cqw; }
  .tp-speedtest-panel-knob-restart { right: 4.63cqw; bottom: 15.59cqw; }

  .tp-speedtest-control-panel-status {
    left: 20.52cqw;
    right: 20.52cqw;
    bottom: 5.23cqw;
    height: 6.24cqw;
    display: block;
    z-index: 6;
    pointer-events: none;
  }

  .tp-speedtest-control-panel-status .tp-speedtest-stage {
    position: absolute;
    left: 7.34cqw;
    right: 6.44cqw;
    top: -4.23cqw;
    z-index: 3;
    font-size: clamp(.82rem, 2.62cqw, 1.45rem);
    line-height: .95;
    padding: 0;
    color: #fff;
  }

  .tp-speedtest-control-panel-status .tp-speedtest-progress {
    position: absolute;
    left: 5.83cqw;
    bottom: 7.75cqw;
    height: 3.62cqw;
    z-index: 1;
    width: 47.99cqw;
    right: auto;
  }
}

@media (max-width: 560px) {
  .tp-speedtest-gauge-needle {
    width: 3px;
    height: 36%;
  }

  .tp-speedtest-control-panel-wrap {
    margin-top: .15rem;
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
  }

  .tp-speedtest-control-panel-wrap::before {
    left: 8px;
    right: 8px;
    top: -28px;
    height: 82px;
    filter: blur(10px);
  }

  .tp-speedtest-control-panel-title {
    top: 27px;
    left: 24px;
    width: 66px;
    font-size: 0.90rem;
    line-height: 1.02;
  }

  .tp-speedtest-control-panel-metric {
    top: 84px;
    width: 55px;
    min-height: 116px;
    gap: .34rem;
  }

  .tp-speedtest-control-panel-metric-left {
    left: 18px;
  }

  .tp-speedtest-control-panel-metric-right {
    right: -5px;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric {
    padding: 0;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-label {
    font-size: .56rem;
    margin-bottom: .05rem;
    line-height: 1;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-value {
    font-size: 1rem;
    line-height: .86;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-value small {
    font-size: .34em;
    margin-left: 0;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge {
    top: 128px;
    width: 188px;
    height: 188px;
    aspect-ratio: 1 / 1 !important;
    --tp-gauge-tick-distance: 78px;
    --tp-gauge-label-distance: 68px;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge-ring {
    width: 160px;
    height: 160px;
    margin: 14px auto 0;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge-center {
    inset: 42px;
    box-shadow: inset 0 0 0 7px rgba(255, 255, 255, .56), inset 0 -14px 24px rgba(14, 165, 233, .08);
  }

  .tp-speedtest-gauge-scale span {
    font-size: .5rem;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-value {
    top: 60px;
    font-size: 1.28rem;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-unit {
    top: 81px;
    font-size: .3rem;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-context {
    display: none;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-max {
    display: none;
  }

  .tp-speedtest-control-panel-status {
    left: 93px;
    right: 90px;
    bottom: 44px;
    height: 11px;
    display: block;
    z-index: 9;
  }

  .tp-speedtest-control-panel-status .tp-speedtest-stage {
    position: absolute;
    left: 6px;
    right: 6px;
    top: -1px;
    font-size: .68rem;
    line-height: .95;
    padding: 0;
    text-shadow: 0 1px 2px rgba(7, 18, 38, .35);
    z-index: 10;
  }

  .tp-speedtest-control-panel-status .tp-speedtest-progress {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 2px;
    height: 14px;
  }

  .tp-speedtest-panel-knob-indicator {
    width: 50px;
    height: 50px;
  }

  .tp-speedtest-panel-knob-indicator .svg-inline--fa {
    height: 1em;
    width: 1em;
  }

  .tp-speedtest-panel-knob-indicator i {
    font-size: 1.26rem;
  }

  .tp-speedtest-panel-knob-start {
    left: 17px;
    bottom: 50px;
  }

  .tp-speedtest-panel-knob-restart {
    right: 9px;
    bottom: 50px;
  }

  .tp-speedtest-month-grid,
  .tp-speedtest-results {
    grid-template-columns: 1fr;
  }

  .tp-speedtest-preflight-grid {
    grid-template-columns: 1fr;
  }

  .tp-speedtest-preflight-machine {
    max-width: 100%;
  }

  .tp-speedtest-preflight-machine-content {
    left: 6.6%;
    right: 6.6%;
    top: 30.5%;
    bottom: 11.5%;
    --tp-ip-row-offset-y: -9px;
  }

  .tp-speedtest-preflight-machine-head {
    padding: 0 .72rem 0 2.9rem;
  }

  .tp-speedtest-preflight-ip-label {
    font-size: 1.2rem;
    transform: translate(8px, -3px);
  }

  .tp-speedtest-copy-ip-box {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    flex-basis: 30px;
    margin-top: -10px;
  }

  .tp-speedtest-copy-ip-box i {
    font-size: .88rem;
  }

  .tp-speedtest-preflight-display {
    min-height: 62px;
    padding: 0;
  }

  .tp-flap-char {
    flex-basis: 18px;
    width: 18px;
    min-width: 18px;
    height: 34px;
    border-radius: 6px;
  }

  .tp-flap-char:not(.is-space) {
    margin-right: 1px;
  }

  .tp-flap-glyph {
    font-size: 1.28rem;
    transform: translateY(4px) scaleX(.82) scaleY(1);
  }

  @keyframes tp-flap-tick-glyph {
    0% { transform: perspective(560px) rotateX(-72deg) scaleY(.62) translateY(4px); opacity: .65; }
    60% { transform: perspective(560px) rotateX(14deg) scaleY(1.02) translateY(4px); opacity: .95; }
    100% { transform: perspective(560px) rotateX(0deg) scaleY(1) translateY(4px); opacity: 1; }
  }

  .tp-speedtest-preflight-actions {
    margin-top: .85rem;
    gap: .55rem;
  }

  .tp-speedtest-preflight-actions .btn {
    min-width: 100%;
    min-height: 48px;
    font-size: .98rem;
  }

  .tp-speedtest-quality-layout {
    grid-template-columns: 1fr;
    gap: .8rem;
  }

  .tp-speedtest-quality-left {
    padding-right: 0;
  }

  .tp-speedtest-quality-arrow {
    display: none;
  }

  .tp-speedtest-quality-right {
    gap: .5rem;
  }

  .tp-speedtest-title {
    font-size: 1.6rem !important;
    line-height: 1.18;
  }

  .tp-speedtest-connection-list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 400px) {
  .tp-speedtest-gauge-needle {
    width: 3px;
    height: 35%;
  }

  .tp-speedtest-control-panel-wrap {
    max-width: 340px;
  }

  .tp-speedtest-control-panel-wrap::before {
    left: 6px;
    right: 6px;
  }

  .tp-speedtest-control-panel-title {
    font-size: .9rem;
    top: 44px;
    left: 27px;
    width: 58px;
  }

  .tp-speedtest-control-panel-metric {
    top: 104px;
    width: 50px;
    min-height: 108px;
  }

  .tp-speedtest-control-panel-metric-left {
    left: 9px;
  }

  .tp-speedtest-control-panel-metric-right {
    right: 9px;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-label {
    font-size: .5rem;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-metric-value {
    font-size: 1.18rem;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge {
    top: 158px;
    width: 176px;
    height: 176px;
    aspect-ratio: 1 / 1 !important;
    --tp-gauge-tick-distance: 72px;
    --tp-gauge-label-distance: 62px;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge-center {
    inset: 39px;
    box-shadow: inset 0 0 0 6px rgba(255, 255, 255, .56), inset 0 -12px 20px rgba(14, 165, 233, .08);
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge-ring {
    width: 148px;
    height: 148px;
    margin: 13px auto 0;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-gauge-ring {
    width: 170px;
    height: 170px;
    margin: 13px auto 0;
  }

  .tp-speedtest-gauge-scale span {
    font-size: .46rem;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-value {
    top: 66px;
    font-size: 1.42rem;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-unit {
    top: 90px;
    font-size: .54rem;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-context {
    display: none;
  }

  .tp-speedtest-control-panel-content .tp-speedtest-live-max {
    display: none;
  }

  .tp-speedtest-control-panel-status {
    left: 78px;
    right: 78px;
    bottom: 34px;
    height: 26px;
  }

  .tp-speedtest-control-panel-status .tp-speedtest-stage {
    top: -16px;
    font-size: .62rem;
    padding: 0;
  }

  .tp-speedtest-control-panel-status .tp-speedtest-progress {
    height: 6px;
    bottom: 2px;
  }

  .tp-speedtest-panel-knob-indicator {
    width: 46px;
    height: 46px;
  }

  .tp-speedtest-panel-knob-indicator i {
    font-size: 1.14rem;
  }

  .tp-speedtest-panel-knob-start {
    left: 18px;
    bottom: 46px;
  }

  .tp-speedtest-panel-knob-restart {
    right: 17px;
    bottom: 46px;
  }

  .tp-speedtest-preflight-machine-content {
    left: 6%;
    right: 6%;
    top: 31.2%;
    bottom: 11.2%;
    --tp-ip-row-offset-y: -8px;
  }

  .tp-speedtest-preflight-machine-head {
    padding: 0 .55rem 0 .65rem;
  }

  .tp-speedtest-preflight-ip-label {
    font-size: .82rem;
    transform: translate(6px, -1px);
  }

  .tp-speedtest-preflight-display {
    min-height: 58px;
  }

  .tp-flap-char {
    flex-basis: 16px;
    width: 16px;
    min-width: 16px;
    height: 30px;
    border-radius: 5px;
  }

  .tp-flap-char:not(.is-space) {
    margin-right: 1px;
  }

  .tp-flap-glyph {
    font-size: 1.08rem;
    transform: translateY(3px) scaleX(.82) scaleY(1);
  }

  @keyframes tp-flap-tick-glyph {
    0% { transform: perspective(560px) rotateX(-72deg) scaleY(.62) translateY(3px); opacity: .65; }
    60% { transform: perspective(560px) rotateX(14deg) scaleY(1.02) translateY(3px); opacity: .95; }
    100% { transform: perspective(560px) rotateX(0deg) scaleY(1) translateY(3px); opacity: 1; }
  }
}

/* =========================================================
   MERGED LEGACY DASHBOARD CSS
   Keep active custom CSS in this single file only.
   ========================================================= */
/* =========================================================
   DASHBOARD - CONVERSION CARDS (PLAN + GAUGE)
   ========================================================= */

.tp-dashboard-summary-row {
  margin-top: 1rem;
  margin-bottom: 0;
}

.tp-dashboard-conversion-row {
  margin-top: .2rem;
  margin-bottom: .6rem;
}

.tp-dashboard-analytics-row {
  margin-top: .2rem;
  margin-bottom: .2rem;
}

.tp-dashboard-account-heading {
  padding: .35rem .12rem 0;
  margin-top: 2.6rem;
  display: flex;
  align-items: center;
  gap: .85rem;
}

.tp-dashboard-account-heading::after {
  content: "";
  flex: 1 1 auto;
  min-width: 0;
  height: 1px;
  background: #e7edf4;
}

[data-theme-style="dark"] .tp-dashboard-account-heading::after {
  background: rgba(95, 170, 227, .18);
}

.tp-dashboard-shortcuts-row {
  margin-top: 2.1rem;
  margin-bottom: .35rem;
}

.tp-dashboard-upload-resume-row {
    margin-top: 2.2rem;
    margin-bottom: -0.6rem;
}

.tp-dashboard-upload-resume-card {
  border-radius: 18px !important;
  border: 1px solid rgba(235, 128, 15, .65) !important;
    background: linear-gradient(135deg, #ff9500 0%, #ff8a00 56%, #f67f00 100%) !important;
    box-shadow: var(--tp-dashboard-card-shadow);
}

.tp-dashboard-upload-resume-card .card-body {
  padding: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .95rem;
}

.tp-dashboard-upload-resume-content {
  min-width: 0;
}

.tp-dashboard-upload-resume-title {
  font-size: 1.2rem;
  line-height: 1.2;
  font-weight: 730;
  color: hsl(221,39%,11%);
  margin-bottom: .50rem;
}

.tp-dashboard-upload-resume-meta {
  display: flex;
  align-items: center;
  gap: .4rem;
  min-width: 0;
  flex-wrap: wrap;
  font-size: .90rem;
    color: hsl(221,39%,11%);
    line-height: 0.9rem;
}

.tp-dashboard-upload-resume-file {
  max-width: min(42vw, 460px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tp-dashboard-upload-resume-separator {
  opacity: .52;
}

.tp-dashboard-upload-resume-countdown strong {
  color: hsl(221,39%,11%);
}

.btn-outline-danger {
    color: #dc3545;
    border-color: #ffffff;
    background: #ffffff;
}

.tp-dashboard-upload-resume-actions {
  display: inline-flex;
  align-items: center;
  gap: .46rem;
  flex: 0 0 auto;
}

.tp-dashboard-upload-resume-actions .btn {
    border-radius: 999px;
    font-weight: 650;
    padding-inline: .88rem;
    padding: 0.5rem 1rem;
}

[data-theme-style="dark"] .tp-dashboard-upload-resume-card {
  border-color: rgba(210, 136, 62, .55) !important;
  background: linear-gradient(135deg, #d08631 0%, #be7527 58%, #ae6b1f 100%) !important;
  box-shadow: 0 3px 8px rgb(0 0 0 / 28%), inset 0 1px 0 rgba(255, 255, 255, .08);
}

[data-theme-style="dark"] .tp-dashboard-upload-resume-actions .btn-outline-danger:hover,
[data-theme-style="dark"] .tp-dashboard-upload-resume-actions .btn-outline-danger:focus {
  color: #fff;
  border-color: rgba(255, 120, 120, .88);
  background: rgba(164, 25, 25, .42);
}

.tp-dashboard-shortcuts-row .p-3 {
  padding: .82rem !important;
}

.tp-dashboard-shortcuts-row .row {
  align-items: stretch;
}

.tp-dashboard-shortcuts-row + .tp-dashboard-account-heading {
  margin-top: 1.55rem;
}

.tp-dashboard-shortcut-link,
.tp-dashboard-shortcut-link:hover,
.tp-dashboard-shortcut-link:focus,
.tp-dashboard-shortcut-link:active,
.tp-dashboard-shortcut-link:visited {
  height: 100%;
  text-decoration: none !important;
  color: inherit !important;
}

.tp-dashboard-shortcut-card .tp-dashboard-files-count-headline {
  align-items: center;
  width: 100%;
  min-height: 100%;
}

.tp-dashboard-shortcut-card {
  height: 100%;
  min-height: 86px;
  display: flex;
  border-color: rgba(15, 165, 235, .24) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(245, 250, 255, .92)) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9)) !important;
  transition: box-shadow .16s ease, background .16s ease, border-color .16s ease, color .16s ease;
}

.tp-dashboard-shortcut-card .card-body {
  width: 100%;
  min-height: inherit;
  display: flex;
  align-items: center;
  position: relative;
}

.tp-dashboard-shortcut-card .tp-dashboard-files-count-headline .tp-dashboard-performance-title {
  flex: 1 1 auto;
  max-width: none;
}

.tp-dashboard-shortcut-label {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
}

.tp-dashboard-shortcut-icon {
  font-size: .88rem;
  color: #0f84cd;
}

.tp-dashboard-shortcut-card--dsa-alert .tp-dashboard-shortcut-icon {
  color: #0f84cd !important;
}

.tp-dashboard-dsa-badge {
  position: absolute;
  top: 8px;
  right: 10px;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e11d48;
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  line-height: 1;
  box-shadow: 0 0 0 0 rgba(225, 29, 72, .52);
  animation: tp-dashboard-dsa-badge-pulse 1.5s ease-out infinite;
}

@keyframes tp-dashboard-dsa-badge-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(225, 29, 72, .52);
  }
  70% {
    box-shadow: 0 0 0 10px rgba(225, 29, 72, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(225, 29, 72, 0);
  }
}

.tp-dashboard-shortcut-chevron {
  font-size: .88rem;
  color: rgba(16, 37, 63, .58);
  opacity: .92;
  flex: 0 0 auto;
}

.tp-dashboard-shortcut-card .tp-dashboard-performance-title,
.tp-dashboard-shortcut-card .tp-dashboard-shortcut-icon,
.tp-dashboard-shortcut-card .tp-dashboard-shortcut-chevron {
  color: #10253f !important;
}

.tp-dashboard-shortcut-link:hover .tp-dashboard-shortcut-card,
.tp-dashboard-shortcut-link:focus .tp-dashboard-shortcut-card,
.tp-dashboard-shortcut-link:active .tp-dashboard-shortcut-card {
  background: linear-gradient(180deg, rgba(239, 248, 255, .98), rgba(222, 241, 255, .96)) !important;
  border-color: rgba(15, 165, 235, .46) !important;
  transform: none !important;
  box-shadow: 0 8px 18px rgba(7, 31, 56, .11), inset 0 1px 0 rgba(255, 255, 255, .96) !important;
}

.tp-dashboard-shortcut-link:hover .tp-dashboard-shortcut-card .tp-dashboard-performance-title,
.tp-dashboard-shortcut-link:hover .tp-dashboard-shortcut-card .tp-dashboard-shortcut-icon,
.tp-dashboard-shortcut-link:hover .tp-dashboard-shortcut-chevron,
.tp-dashboard-shortcut-link:focus .tp-dashboard-shortcut-card .tp-dashboard-performance-title,
.tp-dashboard-shortcut-link:focus .tp-dashboard-shortcut-card .tp-dashboard-shortcut-icon,
.tp-dashboard-shortcut-link:focus .tp-dashboard-shortcut-chevron,
.tp-dashboard-shortcut-link:active .tp-dashboard-shortcut-card .tp-dashboard-performance-title,
.tp-dashboard-shortcut-link:active .tp-dashboard-shortcut-card .tp-dashboard-shortcut-icon,
.tp-dashboard-shortcut-link:active .tp-dashboard-shortcut-chevron {
  color: #0f84cd !important;
}

.tp-dashboard-upload-heading {
  padding: .35rem .12rem 0;
}

.tp-dashboard-overview-section {
  --tp-blue-dark: #04101a;
  --tp-blue-deep: #1f3f93;
  --tp-blue-mid: #238ec8;
  --tp-blue-light: #0fa5eb;
  --tp-orange: #ff8503;
  --tp-orange-light: #ff9b2f;
  --tp-neutral-soft: #d2d2d2;
  --tp-dashboard-card-radius: 18px;
  --tp-dashboard-card-border: 1px solid rgba(15, 165, 235, .24);
  --tp-dashboard-card-bg: linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(245, 250, 255, .92));
  --tp-dashboard-card-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9);
}

.tp-dashboard-conversion-card,
.tp-dashboard-insights-card {
  border-radius: var(--tp-dashboard-card-radius, 18px) !important;
  border: var(--tp-dashboard-card-border, 1px solid rgba(15, 165, 235, .24)) !important;
  background: var(--tp-dashboard-card-bg, linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(245, 250, 255, .92))) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 4px 10px rgba(6, 16, 34, .05), inset 0 1px 0 rgba(255, 255, 255, .9));
}

.tp-dashboard-performance-card .card-body {
  padding: 1.5rem;
}

.tp-dashboard-performance-title {
  font-size: 1.2rem;
  line-height: 1.2;
  font-weight: 700;
  color: #10253f;
  margin-bottom: 1.2rem;
}

.tp-dashboard-performance-heading {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: .7rem;
  margin-bottom: .86rem;
}

.tp-dashboard-performance-heading .tp-dashboard-performance-title {
  margin-bottom: 0;
}

.tp-dashboard-transfer-reset-note {
  margin: 0;
  font-size: .76rem;
  line-height: 1.2;
  color: rgb(80 93 102 / 78%);
  font-weight: 640;
  white-space: normal;
  text-align: right;
  margin-left: auto;
  max-width: 40%;
  min-width: 0;
}

.tp-dashboard-card-note {
  margin-top: -.78rem;
  margin-bottom: .78rem;
  font-size: .82rem;
  line-height: 1.3;
  color: rgba(10, 34, 70, .64);
  font-weight: 600;
}

.tp-dashboard-performance-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 0;
  max-height: 230px;
  overflow: hidden;
}

.tp-dashboard-donut-wrap {
  position: relative;
  width: 210px;
  min-width: 210px;
  max-width: 100%;
  height: 210px;
  max-height: 210px;
  flex: 0 0 auto;
  overflow: hidden;
}

.tp-dashboard-donut-wrap canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
}

.tp-dashboard-donut-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  width: 74%;
  pointer-events: none;
}

.tp-dashboard-donut-center-value {
  font-size: 1.42rem;
  line-height: 1.02;
  font-weight: 800;
  color: #102c6f;
}

.tp-dashboard-donut-center-label {
  margin-top: .16rem;
  font-size: .72rem;
  line-height: 1.2;
  font-weight: 700;
  color: rgba(16, 44, 111, .72);
}

.tp-dashboard-performance-stats {
  margin-top: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: .34rem;
}

.tp-dashboard-limit-notice {
  margin-top: .45rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .92rem;
  border-radius: var(--tp-dashboard-card-radius, 18px);
  padding: 1.5rem;
  border: 1px solid transparent;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9));
}

.tp-dashboard-limit-notice-text {
  font-size: .79rem;
  line-height: 1.28;
  font-weight: 640;
  min-width: 0;
}

.tp-dashboard-limit-notice-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border-radius: 999px;
    padding: 0.84rem 1.78rem;
    font-size: 0.95rem;
    line-height: 1;
    font-weight: 760;
    text-decoration: none !important;
    border: 1px solid transparent;
    transition: filter .16s ease, background-color .16s ease, border-color .16s ease, color .16s ease;
}

.tp-dashboard-limit-notice-cta:hover {
  filter: brightness(1.04);
}

.tp-dashboard-limit-notice-warning {
  border-color: rgba(249, 165, 43, .42);
  background: linear-gradient(180deg, rgba(255, 196, 95, .2), rgba(255, 196, 95, .08));
}

.tp-dashboard-limit-notice-warning .tp-dashboard-limit-notice-text {
  color: rgba(110, 62, 8, .9);
}

.tp-dashboard-limit-notice-warning .tp-dashboard-limit-notice-cta {
  color: #995000;
  background: rgba(255, 255, 255, .7);
  border-color: rgba(249, 165, 43, .55);
}

.tp-dashboard-limit-notice-critical {
  border-color: rgba(231, 93, 77, .42);
  background: linear-gradient(180deg, rgba(255, 137, 120, .2), rgba(255, 137, 120, .08));
}

.tp-dashboard-limit-notice-critical .tp-dashboard-limit-notice-text {
  color: rgba(125, 26, 18, .94);
}

.tp-dashboard-limit-notice-critical .tp-dashboard-limit-notice-cta {
  color: #fff;
  background: linear-gradient(180deg, #ff8b2c, #ff7a00);
  border-color: rgba(228, 100, 0, .7);
}

.tp-dashboard-performance-stat-item {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr) auto;
  align-items: center;
  gap: .42rem;
}

.tp-dashboard-performance-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

.tp-dashboard-performance-dot-transfers {
  background: var(--tp-blue-deep);
}

.tp-dashboard-performance-dot-transfers-remaining {
  background: #7ac8f5;
}

.tp-dashboard-performance-dot-downloads {
  background: var(--tp-blue-mid);
}

.tp-dashboard-performance-dot-success {
  background: var(--tp-orange);
}

.tp-dashboard-performance-dot-uploads {
  background: var(--tp-blue-light);
}

.tp-dashboard-performance-dot-storage-used {
  background: var(--tp-orange);
}

.tp-dashboard-performance-dot-storage-free {
  background: #b9dff7;
}

.tp-dashboard-performance-stat-label {
  font-size: .77rem;
  line-height: 1.2;
  color: rgba(10, 34, 70, .78);
  font-weight: 640;
}

.tp-dashboard-performance-stat-value {
  font-size: .84rem;
  line-height: 1;
  font-weight: 780;
  color: #0a2246;
}


.tp-dashboard-overview-section .tp-dashboard-summary-row .p-3 {
  padding: .82rem !important;
  overflow: visible !important;
}

.tp-dashboard-overview-section .tp-dashboard-conversion-row .p-3 {
  padding: .82rem !important;
}

.tp-dashboard-summary-card {
  position: relative;
  overflow: visible !important;
}

.tp-dashboard-summary-card-transfers {
  background: linear-gradient(180deg, rgba(214, 237, 255, .78), rgba(244, 250, 255, .94)) !important;
}

.tp-dashboard-summary-card-files {
  background: linear-gradient(180deg, rgba(225, 243, 255, .76), rgba(246, 251, 255, .96)) !important;
}

.tp-dashboard-summary-card-storage,
.tp-dashboard-summary-card-datacenter {
  background: linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(245, 250, 255, .92)) !important;
}

.tp-dashboard-summary-card .index-widget-icon {
  border-radius: 12px !important;
}

.tp-dashboard-summary-card-transfers .index-widget-icon {
  background: rgba(14, 165, 233, .14) !important;
}

.tp-dashboard-summary-card-transfers .index-widget-icon i {
  color: var(--tp-blue-light) !important;
}

.tp-dashboard-summary-card-files .index-widget-icon {
  background: rgba(39, 153, 214, .16) !important;
}

.tp-dashboard-summary-card-files .index-widget-icon i {
  color: var(--tp-blue-mid) !important;
}

.tp-dashboard-summary-card-storage .index-widget-icon,
.tp-dashboard-summary-card-datacenter .index-widget-icon {
  background: rgba(37, 99, 235, .14) !important;
}

.tp-dashboard-summary-card-storage .index-widget-icon i,
.tp-dashboard-summary-card-datacenter .index-widget-icon i {
  color: var(--tp-blue-deep) !important;
}

.tp-dashboard-summary-card .card-body {
  overflow: visible;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: .4rem;
  padding: .9rem 1.05rem .9rem .92rem;
  color: #11233f;
}

.tp-dashboard-summary-line {
  font-size: 1rem;
  line-height: 1.24;
  font-weight: 620;
  color: #1a304d;
}

.tp-dashboard-summary-line .h6 {
  margin: 0;
  color: #112844;
  font-size: 1rem;
  line-height: 1.24;
  font-weight: 760;
}

.tp-dashboard-summary-card .text-muted {
  color: #446283 !important;
}

.tp-dashboard-summary-meta {
  font-size: .8rem;
  line-height: 1.24;
}

.tp-dashboard-summary-progress {
  height: .32rem !important;
  border-radius: 999px;
  overflow: hidden;
}

.tp-dashboard-summary-progress .progress-bar {
  border-radius: inherit;
}

.tp-dashboard-summary-progress-transfers {
  background: #d8ebfb;
}

.tp-dashboard-summary-progress-transfers .progress-bar:not(.bg-success) {
  background: linear-gradient(90deg, var(--tp-blue-light), var(--tp-blue-mid));
}

.tp-dashboard-summary-progress-transfers .progress-bar.bg-success {
  background: linear-gradient(90deg, var(--tp-blue-deep), var(--tp-blue-mid)) !important;
}

.tp-dashboard-summary-progress-files {
  background: #d8edf8;
}

.tp-dashboard-summary-progress-files .progress-bar {
  background: linear-gradient(90deg, var(--tp-blue-mid), var(--tp-blue-light));
}

.tp-dashboard-summary-progress-storage {
  background: #dce7ff;
}

.tp-dashboard-summary-progress-storage .progress-bar {
  background: linear-gradient(90deg, var(--tp-blue-mid), var(--tp-blue-deep));
}

.tp-dashboard-summary-progress-datacenter {
  background: #dce7ff;
}

.tp-dashboard-summary-progress-datacenter .progress-bar {
  background: linear-gradient(90deg, var(--tp-blue-mid), var(--tp-blue-deep));
}

.tp-dashboard-recent-transfers-header {
  flex-wrap: nowrap;
}

.tp-dashboard-recent-transfers-divider {
  min-width: 0;
}

.tp-dashboard-recent-transfers-action {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
}

.tp-dashboard-transfers-table {
  border: 0 !important;
  border-radius: 18px !important;
  box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9);
  background: #ffffff !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch;
  touch-action: auto;
}

.tp-dashboard-health-card {
  border-color: #0fa5eb !important;
  background: linear-gradient(145deg, #0fa5eb 0%, #0fa5eb 48%, var(--tp-blue-mid) 100%) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9));
}

.tp-dashboard-health-card .card-body {
  position: relative;
  border-radius: 18px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden;
}

.tp-dashboard-health-card .card-body > * {
  position: relative;
  z-index: 1;
}

.tp-dashboard-health-visual {
  order: 2;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  margin-top: .15rem;
  margin-bottom: .65rem;
  pointer-events: none;
}

.tp-dashboard-health-image {
  width: 198px;
  max-width: 100%;
  height: auto;
  filter: none;
}

.tp-dashboard-health-title {
  order: 1;
  margin-top: .2rem;
  margin-bottom: .8rem;
  color: #ffffff;
  text-shadow: 0 1px 0 rgba(8, 26, 55, .32);
  font-size: 1.16rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: .01em;
  text-align: center;
  width: 100%;
  align-self: center;
}

.tp-dashboard-storage-card .card-body,
.tp-dashboard-activity-summary-card .card-body {
  padding: 1.5rem;
}

.tp-dashboard-activity-summary-stats {
  padding-top: .2rem;
}

.tp-dashboard-storage-card .tp-dashboard-donut-center-value {
  color: #0a2f6f;
}

.tp-dashboard-storage-card .tp-dashboard-donut-center-label {
  color: rgba(10, 47, 111, .74);
}

.tp-dashboard-actions-card .card-body {
  padding: 1.5rem;
}

.tp-dashboard-actions-list {
  margin-top: .1rem;
  display: flex;
  flex-direction: column;
  gap: .72rem;
}

.tp-dashboard-action-btn {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: .5rem;
  font-size: .95rem;
  font-weight: 650;
  border-radius: 14px;
  padding: .72rem .95rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tp-dashboard-quick-kpi-stack {
  display: flex;
  flex-direction: column;
  gap: 2.1rem;
  height: 100%;
}

.tp-dashboard-quick-kpi-stack > .tp-dashboard-files-count-link {
  flex: 0 0 auto;
}

.tp-dashboard-quick-kpi-stack > .tp-dashboard-lifetime-chart-card {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
}

.tp-dashboard-mini-kpi-card {
  min-height: 0;
}

.tp-dashboard-mini-kpi-card .card-body {
  padding: 1.5rem;
}

.tp-dashboard-files-count-card:not(.tp-dashboard-shortcut-card) {
  border-color: rgba(15, 165, 235, .34) !important;
  background: linear-gradient(180deg, rgba(211, 236, 252, .92), rgba(236, 248, 255, .96)) !important;
}

.tp-dashboard-files-count-card:not(.tp-dashboard-shortcut-card) .tp-dashboard-performance-title,
.tp-dashboard-files-count-card:not(.tp-dashboard-shortcut-card) .tp-dashboard-files-count-value {
  color: #10253f;
}

.tp-dashboard-files-count-link,
.tp-dashboard-files-count-link:hover,
.tp-dashboard-files-count-link:focus,
.tp-dashboard-files-count-link:active,
.tp-dashboard-files-count-link:visited {
  text-decoration: none !important;
  color: inherit !important;
}

.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link) .tp-dashboard-files-count-card,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):active .tp-dashboard-files-count-card,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):visited .tp-dashboard-files-count-card {
  transform: none !important;
  filter: none !important;
  transition: none !important;
  border-color: rgba(15, 165, 235, .34) !important;
  background: linear-gradient(180deg, rgba(211, 236, 252, .92), rgba(236, 248, 255, .96)) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9)) !important;
}

.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card .tp-dashboard-performance-title,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card .tp-dashboard-files-count-value,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card .tp-dashboard-performance-title,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card .tp-dashboard-files-count-value,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):active .tp-dashboard-files-count-card .tp-dashboard-performance-title,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):active .tp-dashboard-files-count-card .tp-dashboard-files-count-value {
  color: #10253f !important;
}

.tp-dashboard-quick-kpi-stack > .tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link) .tp-dashboard-files-count-headline {
  align-items: center;
}

.tp-dashboard-info-trigger,
.tp-dashboard-info-trigger:hover,
.tp-dashboard-info-trigger:focus,
.tp-dashboard-info-trigger:active {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  cursor: default !important;
  transform: none !important;
  filter: none !important;
  text-decoration: none !important;
  transition: none !important;
  animation: none !important;
}

.tp-dashboard-info-trigger i,
.tp-dashboard-info-trigger svg,
.tp-dashboard-info-trigger .svg-inline--fa,
.tp-dashboard-info-trigger:hover i,
.tp-dashboard-info-trigger:hover svg,
.tp-dashboard-info-trigger:hover .svg-inline--fa,
.tp-dashboard-info-trigger:focus i,
.tp-dashboard-info-trigger:focus svg,
.tp-dashboard-info-trigger:focus .svg-inline--fa,
.tp-dashboard-info-trigger:active i,
.tp-dashboard-info-trigger:active svg,
.tp-dashboard-info-trigger:active .svg-inline--fa {
  font-size: .62rem;
  color: rgba(78, 91, 108, .78) !important;
  transform: none !important;
  filter: none !important;
  animation: none !important;
  transition: none !important;
}

.tp-dashboard-info-trigger-static,
.tp-dashboard-info-trigger-static:hover,
.tp-dashboard-info-trigger-static:focus,
.tp-dashboard-info-trigger-static:active {
  cursor: default !important;
  transform: none !important;
  filter: none !important;
  animation: none !important;
  text-decoration: none !important;
}

.tp-dashboard-info-trigger-static i,
.tp-dashboard-info-trigger-static svg,
.tp-dashboard-info-trigger-static .svg-inline--fa,
.tp-dashboard-info-trigger-static:hover i,
.tp-dashboard-info-trigger-static:hover svg,
.tp-dashboard-info-trigger-static:hover .svg-inline--fa,
.tp-dashboard-info-trigger-static:focus i,
.tp-dashboard-info-trigger-static:focus svg,
.tp-dashboard-info-trigger-static:focus .svg-inline--fa,
.tp-dashboard-info-trigger-static:active i,
.tp-dashboard-info-trigger-static:active svg,
.tp-dashboard-info-trigger-static:active .svg-inline--fa {
  transform: none !important;
  filter: none !important;
  animation: none !important;
  transition: none !important;
}

.tp-dashboard-files-count-link:hover .tp-dashboard-info-trigger i,
.tp-dashboard-files-count-link:hover .tp-dashboard-info-trigger svg,
.tp-dashboard-files-count-link:hover .tp-dashboard-info-trigger .svg-inline--fa,
.tp-dashboard-files-count-link:focus .tp-dashboard-info-trigger i,
.tp-dashboard-files-count-link:focus .tp-dashboard-info-trigger svg,
.tp-dashboard-files-count-link:focus .tp-dashboard-info-trigger .svg-inline--fa {
  color: rgba(78, 91, 108, .78) !important;
  transform: none !important;
  filter: none !important;
  animation: none !important;
  transition: none !important;
}

.tp-dashboard-files-count-headline .tp-dashboard-info-trigger i,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger svg,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger .svg-inline--fa {
  font-size: .62rem !important;
  color: rgba(78, 91, 108, .82) !important;
}

.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:hover,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:focus,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:active,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:hover i,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:hover svg,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:hover .svg-inline--fa,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:focus i,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:focus svg,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:focus .svg-inline--fa,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:active i,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:active svg,
.tp-dashboard-files-count-headline .tp-dashboard-info-trigger:active .svg-inline--fa
{
  transform: none !important;
  filter: none !important;
  animation: none !important;
  transition: none !important;
}

.tp-dashboard-files-count-headline .tp-dashboard-info-trigger {
  cursor: default !important;
}

.tp-dashboard-files-count-headline [data-toggle="tooltip"],
.tp-dashboard-files-count-headline [data-toggle="tooltip"]:hover,
.tp-dashboard-files-count-headline [data-toggle="tooltip"]:focus,
.tp-dashboard-files-count-headline [data-toggle="tooltip"]:active {
  cursor: default !important;
  transform: none !important;
  filter: none !important;
  animation: none !important;
  transition: none !important;
  text-decoration: none !important;
}

.tp-dashboard-downloadability-card {
  border-color: rgba(15, 165, 235, .34) !important;
  background: linear-gradient(180deg, rgba(211, 236, 252, .92), rgba(236, 248, 255, .96)) !important;
}

.tp-dashboard-lifetime-chart-card {
  position: relative;
  overflow: visible !important;
  border-color: #0fa5eb !important;
  background: linear-gradient(145deg, #0fa5eb 0%, #0fa5eb 48%, var(--tp-blue-mid) 100%) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9));
}

.tp-dashboard-mini-kpi-card .tp-dashboard-performance-title {
  margin-bottom: 1.2rem;
  font-size: 1rem;
  line-height: 1.2;
  font-weight: 600;
}

.tp-dashboard-lifetime-chart-card .card-body {
  position: relative;
  overflow: visible;
  flex: 1 1 auto;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding-right: 1.5rem;
}

.tp-dashboard-lifetime-illustration {
  position: absolute;
  top: -1.70rem;
  right: -1.45rem;
  width: 132px;
  height: auto;
  pointer-events: none;
  z-index: 2;
}

.tp-dashboard-lifetime-chart-card .tp-dashboard-performance-title {
  position: relative;
  z-index: 3;
  padding-right: 5.15rem;
}

.tp-dashboard-files-count-headline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
}

.tp-dashboard-files-count-headline .tp-dashboard-performance-title {
  margin-bottom: 0;
  flex: 0 1 65%;
  max-width: 65%;
  white-space: normal;
}

.tp-dashboard-files-count-value {
  font-size: 2.1rem;
  line-height: 1;
  font-weight: 800;
  color: #10253f;
  text-align: right;
  flex: 0 0 auto;
  margin-left: auto;
}

.tp-dashboard-files-count-caption {
  margin-top: .38rem;
  font-size: .82rem;
  line-height: 1.3;
  color: rgba(255, 244, 230, .96);
  font-weight: 600;
}

.tp-dashboard-lifetime-chart-card .tp-dashboard-performance-title,
.tp-dashboard-lifetime-chart-card .tp-dashboard-performance-title i {
  color: #ffffff !important;
}

.tp-dashboard-lifetime-chart-card .tp-dashboard-info-trigger i,
.tp-dashboard-lifetime-chart-card .tp-dashboard-info-trigger svg,
.tp-dashboard-lifetime-chart-card .tp-dashboard-info-trigger .svg-inline--fa {
  color: rgba(255, 255, 255, .94) !important;
  font-size: .62rem !important;
}

.tp-dashboard-lifetime-summary {
  margin-top: .38rem;
  display: grid;
  gap: .68rem;
}

.tp-dashboard-lifetime-summary-item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  border-radius: 999px;
  padding: .62rem .82rem;
  border: 1px solid rgba(255, 255, 255, .28);
  overflow: hidden;
}

.tp-dashboard-lifetime-summary-item::after {
  content: '';
  position: absolute;
  top: 0;
  left: -140%;
  width: 80%;
  height: 100%;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .34) 52%, rgba(255, 255, 255, 0) 100%);
  opacity: 0;
}

.tp-dashboard-lifetime-summary.tp-dashboard-lifetime-summary-animate .tp-dashboard-lifetime-summary-item::after {
  animation: tp-dashboard-summary-sweep 1.05s ease-out forwards;
}

.tp-dashboard-lifetime-summary.tp-dashboard-lifetime-summary-animate .tp-dashboard-lifetime-summary-item:nth-child(2)::after {
  animation-delay: .16s;
}

.tp-dashboard-lifetime-summary.tp-dashboard-lifetime-summary-animate .tp-dashboard-lifetime-summary-item:nth-child(3)::after {
  animation-delay: .32s;
}

@keyframes tp-dashboard-summary-sweep {
  0% {
    left: -140%;
    opacity: 0;
  }
  22% {
    opacity: .62;
  }
  100% {
    left: 160%;
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .tp-dashboard-lifetime-summary.tp-dashboard-lifetime-summary-animate .tp-dashboard-lifetime-summary-item::after {
    animation: none;
  }
}

.tp-dashboard-lifetime-summary-item:nth-child(1),
.tp-dashboard-lifetime-summary-item:nth-child(2),
.tp-dashboard-lifetime-summary-item:nth-child(3) {
  background: transparent !important;
}

.tp-dashboard-lifetime-summary-label {
  font-size: .82rem;
  line-height: 1.2;
  font-weight: 650;
  color: rgba(246, 251, 255, .97);
}

.tp-dashboard-lifetime-summary-value {
  font-size: 1.14rem;
  line-height: 1;
  font-weight: 800;
  color: #ffffff;
  white-space: nowrap;
  margin-left: auto;
  text-align: right;
}

.tp-dashboard-transfers-limit-card .tp-dashboard-performance-heading .tp-dashboard-performance-title {
  white-space: nowrap;
}

.tp-dashboard-downloadability-rate-wrap {
  display: flex;
  align-items: baseline;
  gap: .45rem;
}

.tp-dashboard-downloadability-rate-value {
  font-size: 1.62rem;
  line-height: 1;
  font-weight: 800;
  color: #0c2c5e;
}

.tp-dashboard-downloadability-rate-label {
  font-size: .86rem;
  line-height: 1.2;
  font-weight: 700;
  color: rgba(10, 34, 70, .66);
}

.tp-dashboard-downloadability-progress {
  margin-top: .7rem;
  margin-bottom: .52rem;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(15, 165, 235, .18);
}

.tp-dashboard-downloadability-progress .progress-bar {
  border-radius: inherit;
  background: linear-gradient(90deg, #1d3f93, #2799d6);
}

.tp-dashboard-downloadability-caption {
  font-size: .82rem;
  line-height: 1.35;
  color: rgba(10, 34, 70, .72);
  font-weight: 600;
}

.tp-dashboard-health-status {
  order: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  width: 100%;
  border-radius: 999px !important;
  padding: .58rem .9rem;
  margin-top: auto;
  margin-bottom: .08rem;
  font-size: .95rem;
  font-weight: 600;
  color: #ffffff;
  background: linear-gradient(180deg, rgba(16, 62, 140, .82), rgba(14, 53, 122, .9));
  text-align: center;
  white-space: normal;
}

.tp-dashboard-limit-notice-row {
  margin-top: -.28rem;
  margin-bottom: .45rem;
}

.tp-dashboard-limit-notice-row-uploader {
  margin-top: .38rem;
  margin-bottom: .62rem;
}

.tp-dashboard-limit-notice-global {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .92rem;
  margin-top: 0;
  padding: 1.5rem;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9));
}

.tp-dashboard-limit-notice-global .tp-dashboard-limit-notice-text {
  margin: 0;
  font-size: 1.2rem;
  line-height: 1.2;
  font-weight: 700;
  display: flex;
  flex-direction: column;
  gap: .18rem;
}

/* Unified alerts: keep all dashboard/home warnings in top alert zone only. */
.tp-dashboard-limit-notice-row,
.tp-dashboard-limit-notice-row-uploader,
.tp-dashboard-limit-notice-global {
  display: none !important;
}

#upload_main_dropzone.tp-dashboard-uploader-locked {
  position: relative;
  overflow: hidden;
}

#upload_main_dropzone.tp-dashboard-uploader-locked::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(11, 23, 42, .18);
  pointer-events: none;
  z-index: 3;
}

#upload_main_dropzone.tp-dashboard-uploader-locked .notification-container {
  position: relative;
  z-index: 4;
}

#upload_main_dropzone.tp-dashboard-uploader-locked #upload_select_files,
#upload_main_dropzone.tp-dashboard-uploader-locked #upload_select_folders {
  opacity: .42 !important;
}

.tp-dashboard-health-pulse {
  width: .56rem;
  height: .56rem;
  border-radius: 50%;
  background: #22c55e;
  animation: tp-dashboard-pulse-dot 1.8s ease-in-out infinite;
}

@keyframes tp-dashboard-pulse-dot {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: .5;
    transform: scale(.82);
  }
}

.tp-dashboard-mini-stack {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  height: 100%;
}

.tp-dashboard-mini-card {
  min-height: 122px;
  transition: none;
}

.tp-dashboard-mini-card:hover {
  transform: none;
  border-color: rgba(15, 165, 235, .24) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9));
}

.tp-dashboard-mini-card .card-body {
  padding-top: .95rem;
  padding-bottom: .95rem;
}

.tp-dashboard-mini-card .fa-chevron-right {
  opacity: .55;
  transition: none;
}

.tp-dashboard-mini-card:hover .fa-chevron-right {
  transform: none;
  opacity: .82;
}

.tp-dashboard-plan-mini-card .h6 {
  font-size: 1.15rem;
}

.tp-dashboard-plan-callout {
  position: relative;
  overflow: visible !important;
  border-color: rgba(29, 84, 180, .86) !important;
  background: linear-gradient(145deg, #163f96 0%, #133a8a 56%, #12347c 100%) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9));
  min-height: 130px;
}

.tp-dashboard-plan-callout.tp-dashboard-mini-card:hover {
  transform: none !important;
  border-color: rgba(29, 84, 180, .86) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9)) !important;
}

.tp-dashboard-plan-callout .card-body {
  position: relative;
  padding: 1.9rem 8rem 1.9rem 1.9rem !important;
  color: #fff;
}

.tp-dashboard-plan-mainline {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: .36rem;
  margin-bottom: .80rem;
  line-height: 1.1;
}

.tp-dashboard-plan-mainline-label,
.tp-dashboard-plan-mainline-name {
  color: #fff;
  font-size: 1.16rem;
  font-weight: 700;
}

.tp-dashboard-plan-subline {
  color: rgba(240, 248, 255, .98);
  font-size: .95rem;
  line-height: 1.35;
  margin-bottom: .1rem;
}

.tp-dashboard-plan-subline strong {
  color: #fff;
  font-weight: 780;
}

.tp-dashboard-plan-marketing {
  color: rgba(162, 209, 255, .98);
  font-size: .95rem;
  line-height: 1.35;
}

.tp-dashboard-plan-thumb-image {
  position: absolute;
  right: 0.75rem;
  top: 40%;
  transform: translateY(-50%);
  width: 108px;
  max-width: 42%;
  height: auto;
  pointer-events: none;
  z-index: 3;
  filter: none;
}

.tp-dashboard-plan-callout-free .card-body {
  padding-right: 9.2rem !important;
}

.tp-dashboard-plan-callout-free .tp-dashboard-plan-subline {
  font-size: .95rem;
  max-width: calc(100% - 7.8rem);
}

.tp-dashboard-plan-callout-free .tp-dashboard-plan-marketing {
  font-size: .95rem;
  max-width: 88%;
}

.tp-dashboard-plan-unlock-image {
  position: absolute;
  right: 1.55rem;
  top: -1.28rem;
  width: 129px;
  max-width: 44%;
  height: auto;
  pointer-events: none;
  z-index: 3;
  filter: none;
}

.tp-dashboard-plan-button-label {
  position: absolute;
  right: 6rem;
  top: 50%;
  transform: translateY(-56%);
  z-index: 4;
  color: rgb(255 255 255);
  font-size: 1.2rem;
  line-height: 1;
  font-weight: 800;
  white-space: nowrap;
  pointer-events: none;
  text-shadow: 0 2px 15px rgb(19 57 135);
}

.tp-dashboard-plan-cta-image {
  position: absolute;
  right: -1.3rem;
  top: 51%;
  transform: translateY(-50%);
  width: 260px;
  max-width: 52%;
  min-width: 172px;
  height: auto;
  pointer-events: none;
  z-index: 3;
  filter: none;
}

.tp-dashboard-notification-callout {
  position: relative;
  overflow: visible !important;
  border-color: rgba(235, 128, 15, .65) !important;
  background: linear-gradient(135deg, #ff9500 0%, #ff8a00 56%, #f67f00 100%) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9));
}

.tp-dashboard-notification-callout.tp-dashboard-mini-card {
  transition: none !important;
}

.tp-dashboard-notification-callout.tp-dashboard-mini-card:hover {
  transform: none !important;
  border-color: rgba(235, 128, 15, .65) !important;
  box-shadow: var(--tp-dashboard-card-shadow, 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9)) !important;
}

.tp-dashboard-notification-callout.tp-dashboard-mini-card .fa-chevron-right,
.tp-dashboard-notification-callout.tp-dashboard-mini-card:hover .fa-chevron-right {
  color: hsl(221, 39%, 11%);
}

.tp-dashboard-notification-callout .card-body {
  padding: 1.9rem 1rem 1.9rem 10rem !important;
  color: #fff;
}

.tp-dashboard-notification-illustration {
  position: absolute;
  left: -1.05rem;
  top: 50%;
  width: 9rem;
  height: auto;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 2;
}

[data-theme-style="dark"] .tp-dashboard-transfers-table {
  background: linear-gradient(180deg, #161a23 0%, #101319 100%) !important;
  box-shadow: 0 5px 16px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

[data-theme-style="dark"] .tp-dashboard-action-btn {
  color: rgba(236, 245, 255, .95) !important;
}

[data-theme-style="dark"] .tp-dashboard-action-btn:hover {
  color: rgba(236, 245, 255, .95) !important;
}

[data-theme-style="dark"] .tp-dashboard-action-btn i {
  color: rgba(95, 175, 235, .92) !important;
}

[data-theme-style="dark"] .tp-dashboard-performance-dot-storage-free {
  background: #63b5e4;
}

.tp-dashboard-notification-title {
  color: hsl(221, 39%, 11%);
  line-height: 1.2;
  margin-bottom: .3rem;
  font-size: 1.16rem;
  font-weight: 700;
}

.tp-dashboard-notification-text {
  color: hsl(221, 39%, 11%);
  font-size: .95rem;
  line-height: 1.36;
  margin-bottom: .26rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.tp-dashboard-notification-time {
  color: hsl(221deg 39% 11% / 49%);
  font-size: .82rem;
  font-weight: 600;
}

.tp-dashboard-notification-arrow {
  padding-right: .95rem !important;
}

.tp-dashboard-notification-arrow i {
  width: 1.95rem;
  height: 1.95rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  color: rgba(255, 255, 255, .94);
  background: rgba(136, 72, 0, .22);
}

.tp-dashboard-upload-resume-card,
.tp-dashboard-upload-resume-card *,
.tp-dashboard-notification-callout,
.tp-dashboard-notification-callout * {
  color: #000 !important;
}

[data-theme-style="dark"] .tp-dashboard-conversion-card {
  border-color: rgba(95, 175, 235, .24) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .065), rgba(255, 255, 255, .025)) !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .06);
}

[data-theme-style="dark"] .tp-dashboard-conversion-card:not(.tp-dashboard-plan-callout):not(.tp-dashboard-notification-callout):not(.tp-dashboard-lifetime-chart-card):not(.tp-dashboard-health-card) {
  background: linear-gradient(180deg, hsl(218deg 23.65% 16.68%), rgb(0 0 0 / 92%)) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  border-radius: 22px !important;
  box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
  transition: transform .18s ease, box-shadow .18s ease;
}

[data-theme-style="dark"] .tp-dashboard-performance-title,
[data-theme-style="dark"] .tp-dashboard-donut-center-value,
[data-theme-style="dark"] .tp-dashboard-performance-stat-value {
  color: rgba(237, 245, 255, .96);
}

[data-theme-style="dark"] .tp-dashboard-card-note,
[data-theme-style="dark"] .tp-dashboard-transfer-reset-note,
[data-theme-style="dark"] .tp-dashboard-files-count-caption,
[data-theme-style="dark"] .tp-dashboard-downloadability-rate-label,
[data-theme-style="dark"] .tp-dashboard-downloadability-caption {
  color: rgba(215, 231, 250, .74);
}

[data-theme-style="dark"] .tp-dashboard-files-count-card:not(.tp-dashboard-shortcut-card) {
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  background: linear-gradient(180deg, hsl(218deg 23.65% 16.68%), rgb(0 0 0 / 92%)) !important;
  box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

[data-theme-style="dark"] .tp-dashboard-downloadability-card {
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  background: linear-gradient(180deg, hsl(218deg 23.65% 16.68%), rgb(0 0 0 / 92%)) !important;
  box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

[data-theme-style="dark"] .tp-dashboard-lifetime-chart-card {
  border-color: rgba(73, 166, 235, .52) !important;
  background: linear-gradient(150deg, rgba(15, 165, 235, .54), rgba(12, 76, 132, .96)) !important;
}

[data-theme-style="dark"] .tp-dashboard-files-count-value,
[data-theme-style="dark"] .tp-dashboard-downloadability-rate-value {
  color: rgba(237, 245, 255, .96);
}

[data-theme-style="dark"] .tp-dashboard-info-trigger i,
[data-theme-style="dark"] .tp-dashboard-info-trigger svg,
[data-theme-style="dark"] .tp-dashboard-info-trigger .svg-inline--fa {
  color: rgba(198, 219, 242, .76) !important;
}

[data-theme-style="dark"] .tp-dashboard-lifetime-chart-card .tp-dashboard-info-trigger i,
[data-theme-style="dark"] .tp-dashboard-lifetime-chart-card .tp-dashboard-info-trigger svg,
[data-theme-style="dark"] .tp-dashboard-lifetime-chart-card .tp-dashboard-info-trigger .svg-inline--fa {
  color: rgba(244, 251, 255, .95) !important;
}

[data-theme-style="dark"] .tp-dashboard-lifetime-summary-item {
  border-color: rgba(178, 226, 255, .26);
}

[data-theme-style="dark"] .tp-dashboard-lifetime-summary-item:nth-child(1) {
  background: transparent !important;
}

[data-theme-style="dark"] .tp-dashboard-lifetime-summary-item:nth-child(2) {
  background: transparent !important;
}

[data-theme-style="dark"] .tp-dashboard-lifetime-summary-item:nth-child(3) {
  background: transparent !important;
}

[data-theme-style="dark"] .tp-dashboard-lifetime-summary-item::after {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(196, 232, 255, .34) 52%, rgba(255, 255, 255, 0) 100%);
}

[data-theme-style="dark"] .tp-dashboard-lifetime-summary-label {
  color: rgba(221, 242, 255, .9);
}

[data-theme-style="dark"] .tp-dashboard-lifetime-summary-value {
  color: rgba(244, 251, 255, .98);
}

[data-theme-style="dark"] .tp-dashboard-downloadability-progress {
  background: rgba(95, 175, 235, .2);
}

[data-theme-style="dark"] .tp-dashboard-donut-center-label,
[data-theme-style="dark"] .tp-dashboard-performance-stat-label {
  color: rgba(215, 231, 250, .74);
}

[data-theme-style="dark"] .tp-dashboard-limit-notice-warning {
  border-color: rgba(235, 177, 88, .48);
  background: linear-gradient(180deg, rgba(185, 130, 41, .34), rgba(185, 130, 41, .16));
}

[data-theme-style="dark"] .tp-dashboard-limit-notice-warning .tp-dashboard-limit-notice-text {
  color: rgba(255, 230, 189, .95);
}

[data-theme-style="dark"] .tp-dashboard-limit-notice-warning .tp-dashboard-limit-notice-cta {
  color: rgba(255, 237, 203, .98);
  background: rgba(21, 27, 38, .44);
  border-color: rgba(235, 177, 88, .52);
}

[data-theme-style="dark"] .tp-dashboard-limit-notice-critical {
  border-color: rgba(235, 119, 102, .48);
  background: linear-gradient(180deg, rgba(150, 60, 49, .4), rgba(150, 60, 49, .2));
}

[data-theme-style="dark"] .tp-dashboard-limit-notice-critical .tp-dashboard-limit-notice-text {
  color: rgba(255, 214, 208, .96);
}

[data-theme-style="dark"] .tp-dashboard-limit-notice-critical .tp-dashboard-limit-notice-cta {
  color: #fff;
  background: linear-gradient(180deg, #ff8e3c, #ff7a14);
  border-color: rgba(248, 136, 64, .62);
}

[data-theme-style="dark"] .tp-dashboard-summary-card-transfers {
  background: linear-gradient(180deg, rgba(255, 255, 255, .065), rgba(255, 255, 255, .025)) !important;
}

[data-theme-style="dark"] .tp-dashboard-summary-card-files {
  background: linear-gradient(180deg, rgba(255, 255, 255, .065), rgba(255, 255, 255, .025)) !important;
}

[data-theme-style="dark"] .tp-dashboard-summary-card-storage,
[data-theme-style="dark"] .tp-dashboard-summary-card-datacenter {
  background: linear-gradient(180deg, rgba(255, 255, 255, .065), rgba(255, 255, 255, .025)) !important;
}

[data-theme-style="dark"] .tp-dashboard-notification-callout {
  border-color: rgba(210, 136, 62, .55) !important;
  background: linear-gradient(135deg, #d08631 0%, #be7527 58%, #ae6b1f 100%) !important;
  box-shadow: 0 3px 8px rgb(0 0 0 / 28%), inset 0 1px 0 rgba(255, 255, 255, .08);
}

[data-theme-style="dark"] .tp-dashboard-notification-callout.tp-dashboard-mini-card:hover {
  transform: none !important;
  border-color: rgba(210, 136, 62, .55) !important;
  box-shadow: 0 3px 8px rgb(0 0 0 / 28%), inset 0 1px 0 rgba(255, 255, 255, .08) !important;
}

[data-theme-style="dark"] .tp-dashboard-plan-callout {
  border-color: rgba(50, 116, 226, .86) !important;
  background: linear-gradient(145deg, #143882 0%, #10306f 56%, #0f285b 100%) !important;
  box-shadow: 0 3px 8px rgb(0 0 0 / 28%), inset 0 1px 0 rgba(255, 255, 255, .1);
}

[data-theme-style="dark"] .tp-dashboard-plan-callout.tp-dashboard-mini-card:hover {
  border-color: rgba(50, 116, 226, .86) !important;
  box-shadow: 0 3px 8px rgb(0 0 0 / 28%), inset 0 1px 0 rgba(255, 255, 255, .1) !important;
}

[data-theme-style="dark"] .tp-dashboard-notification-arrow i {
  background: rgba(44, 18, 0, .36);
}

body[data-theme-style="dark"] .tp-dashboard-overview-section .tp-dashboard-health-card .card-body {
  background: transparent !important;
  border: 0 !important;
  border-radius: var(--tp-dashboard-card-radius, 18px) !important;
  box-shadow: none !important;
}

body[data-theme-style="dark"] .tp-dashboard-overview-section .tp-dashboard-health-card {
  border-color: rgba(73, 166, 235, .52) !important;
  background: linear-gradient(150deg, rgba(15, 165, 235, .54), rgba(12, 76, 132, .96)) !important;
}

body[data-theme-style="dark"] .tp-dashboard-overview-section .tp-dashboard-health-title {
  color: rgba(238, 247, 255, .98);
}

body[data-theme-style="dark"] .tp-dashboard-overview-section .tp-dashboard-health-status {
  background: linear-gradient(180deg, rgba(27, 82, 170, .78), rgba(17, 56, 122, .88));
  color: rgba(235, 248, 255, .98);
  border: 1px solid rgba(144, 207, 255, .2);
}

[data-theme-style="dark"] .tp-dashboard-mini-card:hover {
  border-color: rgba(95, 175, 235, .24) !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .06);
}

@media (max-width: 1199.98px) {
  .tp-dashboard-mini-card {
    min-height: 0;
    margin-bottom: 0.95rem;
  }

  .tp-dashboard-plan-callout-free .card-body {
    padding-right: 8.6rem !important;
  }

  .tp-dashboard-plan-unlock-image {
    width: 120px;
    top: -1.06rem;
  }
}

@media (max-width: 575.98px) {
  .tp-dashboard-plan-callout .card-body {
    padding: 1.6rem 6.6rem 1.6rem 1.6rem !important;
  }

  .tp-dashboard-plan-mainline-label,
  .tp-dashboard-plan-mainline-name {
    font-size: 1.1rem;
  }

  .tp-dashboard-plan-subline {
    font-size: .95rem;
    margin-bottom: .60rem;
  }

  .tp-dashboard-plan-marketing {
    font-size: .90rem;
    max-width: 100%;
  }

  .tp-dashboard-plan-thumb-image {
    right: -0.75rem;
    top: 50%;
    width: 108px;
  }

  .tp-dashboard-plan-callout-free .tp-dashboard-plan-subline {
    font-size: .95rem;
    max-width: calc(100% - 1.4rem);
  }

  .tp-dashboard-plan-callout-free .tp-dashboard-plan-marketing {
    font-size: .84rem;
    max-width: 100%;
  }

  .tp-dashboard-plan-unlock-image {
    width: 128px;
    top: 1.4rem;
    right: -0.83rem;
  }

  .tp-dashboard-notification-callout .card-body {
    padding: 1.5rem .50rem 1.5rem 7rem !important;
  }

  .tp-dashboard-notification-illustration {
    left: -.5rem;
    width: 6.8rem;
  }

  .tp-dashboard-notification-title {
    font-size: 1.1rem;
  }

  .tp-dashboard-notification-text {
    font-size: .95rem;
  }

  .tp-dashboard-notification-time {
    font-size: .76rem;
  }
}

@media (max-width: 767.98px) {
  .tp-dashboard-upload-resume-card .card-body {
    flex-direction: column;
    align-items: flex-start;
  }

  .tp-dashboard-upload-resume-actions {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .tp-dashboard-upload-resume-actions .btn {
    flex: 1 1 auto;
    min-width: 165px;
  }

  .tp-dashboard-upload-resume-file {
    max-width: 100%;
  }

  .tp-dashboard-overview-section .tp-dashboard-summary-row .p-3,
  .tp-dashboard-conversion-row .p-3 {
    margin-bottom: -0.4rem;
  }

  .tp-dashboard-account-heading {
    margin-top: 1.5rem;
  }

  .tp-dashboard-performance-heading {
    align-items: flex-start;
    flex-direction: row;
    gap: .42rem;
  }

  .tp-dashboard-transfer-reset-note {
    font-size: .72rem;
    white-space: normal;
    max-width: 58%;
  }

  .tp-dashboard-performance-title {
    font-size: .98rem;
  }

  .tp-dashboard-files-count-value {
    font-size: 1.85rem;
  }

  .tp-dashboard-files-count-headline .tp-dashboard-performance-title {
    flex-basis: 62%;
    max-width: 62%;
  }

  .tp-dashboard-donut-wrap {
    width: 184px;
    min-width: 184px;
    height: 184px;
    max-height: 184px;
  }

  .tp-dashboard-donut-center-value {
    font-size: 1.28rem;
  }

  .tp-dashboard-performance-stat-label,
  .tp-dashboard-performance-stat-value {
    font-size: .75rem;
  }

  .tp-dashboard-summary-row {
    margin-top: .75rem;
    margin-bottom: 0;
  }

  .tp-dashboard-conversion-row {
    margin-top: 0;
    margin-bottom: .4rem;
  }

  .tp-dashboard-overview-section .tp-dashboard-summary-row .p-3,
  .tp-dashboard-conversion-row .p-3 {
    padding: .72rem !important;
  }

  .tp-dashboard-health-card .card-body {
    padding-top: 1.1rem;
  }

  .tp-dashboard-health-image {
    width: 182px;
  }

  .tp-dashboard-health-visual {
    margin-top: .1rem;
    margin-bottom: .5rem;
  }

  .tp-dashboard-health-title {
    font-size: 1.1rem;
    margin-top: .12rem;
    margin-bottom: .9rem;
  }

  .tp-dashboard-plan-mainline-label,
  .tp-dashboard-plan-mainline-name {
    font-size: 1.1rem;
  }

  .tp-dashboard-mini-stack {
    gap: 1rem;
  }

  .tp-dashboard-quick-kpi-stack {
    gap: 1.45rem;
  }

  .tp-dashboard-lifetime-chart-card .card-body {
    padding-right: 1.2rem;
  }

  .tp-dashboard-lifetime-illustration {
    width: 116px;
    top: -0.86rem;
    right: -0.36rem;
  }

  .tp-dashboard-lifetime-chart-card .tp-dashboard-performance-title {
    padding-right: 4.1rem;
  }

  .tp-dashboard-limit-notice-global {
    flex-direction: column;
    align-items: flex-start;
  }

  .tp-dashboard-limit-notice-global .tp-dashboard-limit-notice-text {
    font-size: 1rem;
    line-height: 1.3;
  }

  .tp-dashboard-limit-notice-global .tp-dashboard-limit-notice-cta {
    width: 100%;
    text-align: center;
  }

  .tp-dashboard-transfers-table .table {
    min-width: 920px;
  }

  .tp-dashboard-recent-transfers-header .small {
    font-size: .78rem;
  }
}

/* Keep files-count card visually static (no hover state changes). */
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):active .tp-dashboard-files-count-card,
.tp-dashboard-files-count-card:not(.tp-dashboard-shortcut-card):hover {
  background: #12347C !important;
  border-color: #12347C !important;
  box-shadow: 0 10px 24px rgba(6, 16, 34, .16), inset 0 1px 0 rgba(255, 255, 255, .16) !important;
  transform: translateY(-1px) scale(1.01) !important;
  filter: none !important;
}

.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card .tp-dashboard-performance-title,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card .tp-dashboard-files-count-value,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card .tp-dashboard-performance-title,
.tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card .tp-dashboard-files-count-value {
  color: rgba(255, 255, 255, .96) !important;
}

[data-theme-style="dark"] .tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card,
[data-theme-style="dark"] .tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card,
[data-theme-style="dark"] .tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):active .tp-dashboard-files-count-card,
[data-theme-style="dark"] .tp-dashboard-files-count-card:not(.tp-dashboard-shortcut-card):hover {
  border: 1px solid rgba(90, 177, 237, .5) !important;
  background: linear-gradient(180deg, rgba(22, 94, 160, .78), rgba(18, 52, 124, .72)) !important;
  box-shadow: 0 10px 24px rgba(2, 8, 20, .38), inset 0 1px 0 rgba(255, 255, 255, .16) !important;
  transform: translateY(-1px) scale(1.01) !important;
  filter: none !important;
}

[data-theme-style="dark"] .tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card .tp-dashboard-performance-title,
[data-theme-style="dark"] .tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):hover .tp-dashboard-files-count-card .tp-dashboard-files-count-value,
[data-theme-style="dark"] .tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card .tp-dashboard-performance-title,
[data-theme-style="dark"] .tp-dashboard-files-count-link:not(.tp-dashboard-shortcut-link):focus .tp-dashboard-files-count-card .tp-dashboard-files-count-value {
  color: rgba(240, 248, 255, .95) !important;
}

[data-theme-style="dark"] .tp-dashboard-shortcut-chevron {
  color: rgba(238, 245, 255, .78);
}

[data-theme-style="dark"] .tp-dashboard-shortcut-card {
  border: 1px solid rgba(90, 177, 237, .5) !important;
  background: linear-gradient(180deg, rgba(22, 94, 160, .78), rgba(18, 52, 124, .72)) !important;
  box-shadow: 0 10px 24px rgba(2, 8, 20, .38), inset 0 1px 0 rgba(255, 255, 255, .16) !important;
}

[data-theme-style="dark"] .tp-dashboard-shortcut-card .tp-dashboard-performance-title,
[data-theme-style="dark"] .tp-dashboard-shortcut-card .tp-dashboard-shortcut-icon,
[data-theme-style="dark"] .tp-dashboard-shortcut-card .tp-dashboard-shortcut-chevron {
  color: rgba(240, 248, 255, .95) !important;
}

[data-theme-style="dark"] .tp-dashboard-dsa-badge {
  background: #ef4444;
  color: #fff;
}

[data-theme-style="dark"] .tp-dashboard-shortcut-link:hover .tp-dashboard-shortcut-chevron,
[data-theme-style="dark"] .tp-dashboard-shortcut-link:focus .tp-dashboard-shortcut-chevron,
[data-theme-style="dark"] .tp-dashboard-shortcut-link:active .tp-dashboard-shortcut-chevron {
  color: rgba(255, 255, 255, .92);
}

/* Hard stop: no hover/scale animation on dashboard info icons. */
.tp-dashboard-info-trigger,
.tp-dashboard-info-trigger-static,
.tp-dashboard-info-trigger:hover,
.tp-dashboard-info-trigger-static:hover,
.tp-dashboard-info-trigger:focus,
.tp-dashboard-info-trigger-static:focus,
.tp-dashboard-info-trigger:active,
.tp-dashboard-info-trigger-static:active,
.tp-dashboard-files-count-link:hover .tp-dashboard-info-trigger,
.tp-dashboard-files-count-link:focus .tp-dashboard-info-trigger,
.tp-dashboard-files-count-headline [data-toggle="tooltip"],
.tp-dashboard-files-count-headline [data-toggle="tooltip"]:hover,
.tp-dashboard-files-count-headline [data-toggle="tooltip"]:focus,
.tp-dashboard-files-count-headline [data-toggle="tooltip"]:active {
  transform: none !important;
  filter: none !important;
  animation: none !important;
  transition: none !important;
}

.tp-dashboard-info-trigger i,
.tp-dashboard-info-trigger svg,
.tp-dashboard-info-trigger .svg-inline--fa,
.tp-dashboard-info-trigger-static i,
.tp-dashboard-info-trigger-static svg,
.tp-dashboard-info-trigger-static .svg-inline--fa,
.tp-dashboard-info-trigger:hover i,
.tp-dashboard-info-trigger:hover svg,
.tp-dashboard-info-trigger:hover .svg-inline--fa,
.tp-dashboard-info-trigger-static:hover i,
.tp-dashboard-info-trigger-static:hover svg,
.tp-dashboard-info-trigger-static:hover .svg-inline--fa,
.tp-dashboard-info-trigger:focus i,
.tp-dashboard-info-trigger:focus svg,
.tp-dashboard-info-trigger:focus .svg-inline--fa,
.tp-dashboard-info-trigger-static:focus i,
.tp-dashboard-info-trigger-static:focus svg,
.tp-dashboard-info-trigger-static:focus .svg-inline--fa,
.tp-dashboard-info-trigger:active i,
.tp-dashboard-info-trigger:active svg,
.tp-dashboard-info-trigger:active .svg-inline--fa,
.tp-dashboard-info-trigger-static:active i,
.tp-dashboard-info-trigger-static:active svg,
.tp-dashboard-info-trigger-static:active .svg-inline--fa,
.tp-dashboard-files-count-link:hover .tp-dashboard-info-trigger i,
.tp-dashboard-files-count-link:hover .tp-dashboard-info-trigger svg,
.tp-dashboard-files-count-link:hover .tp-dashboard-info-trigger .svg-inline--fa,
.tp-dashboard-files-count-link:focus .tp-dashboard-info-trigger i,
.tp-dashboard-files-count-link:focus .tp-dashboard-info-trigger svg,
.tp-dashboard-files-count-link:focus .tp-dashboard-info-trigger .svg-inline--fa {
  transform: none !important;
  filter: none !important;
  animation: none !important;
  transition: none !important;
}

/* Final lock: dashboard shortcut cards keep clean SaaS base style. */
.tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link .tp-dashboard-shortcut-card.tp-dashboard-conversion-card.tp-dashboard-insights-card {
  --tp-dashboard-card-border: 1px solid rgba(15, 165, 235, .24);
  --tp-dashboard-card-bg: linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(245, 250, 255, .92));
  --tp-dashboard-card-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9);
  border: var(--tp-dashboard-card-border) !important;
  background: var(--tp-dashboard-card-bg) !important;
  box-shadow: var(--tp-dashboard-card-shadow) !important;
  opacity: 1 !important;
  filter: none !important;
}

.tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link .tp-dashboard-shortcut-card .tp-dashboard-performance-title,
.tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link .tp-dashboard-shortcut-card .tp-dashboard-shortcut-icon,
.tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link .tp-dashboard-shortcut-card .tp-dashboard-shortcut-chevron {
  color: #10253f !important;
  opacity: 1 !important;
}

.tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link:hover .tp-dashboard-shortcut-card.tp-dashboard-conversion-card.tp-dashboard-insights-card,
.tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link:focus .tp-dashboard-shortcut-card.tp-dashboard-conversion-card.tp-dashboard-insights-card,
.tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link:active .tp-dashboard-shortcut-card.tp-dashboard-conversion-card.tp-dashboard-insights-card {
  border-color: rgba(15, 165, 235, .46) !important;
  background: linear-gradient(180deg, rgba(239, 248, 255, .98), rgba(222, 241, 255, .96)) !important;
  box-shadow: 0 8px 18px rgba(7, 31, 56, .11), inset 0 1px 0 rgba(255, 255, 255, .96) !important;
  transform: none !important;
  filter: none !important;
}

[data-theme-style="dark"] .tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link .tp-dashboard-shortcut-card.tp-dashboard-conversion-card.tp-dashboard-insights-card {
  border: 1px solid rgba(90, 177, 237, .5) !important;
  background: linear-gradient(180deg, rgba(22, 94, 160, .78), rgba(18, 52, 124, .72)) !important;
  box-shadow: 0 10px 24px rgba(2, 8, 20, .38), inset 0 1px 0 rgba(255, 255, 255, .16) !important;
}

[data-theme-style="dark"] .tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link .tp-dashboard-shortcut-card .tp-dashboard-performance-title,
[data-theme-style="dark"] .tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link .tp-dashboard-shortcut-card .tp-dashboard-shortcut-icon,
[data-theme-style="dark"] .tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link .tp-dashboard-shortcut-card .tp-dashboard-shortcut-chevron {
  color: rgba(240, 248, 255, .95) !important;
}

[data-theme-style="dark"] .tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link:hover .tp-dashboard-shortcut-card.tp-dashboard-conversion-card.tp-dashboard-insights-card,
[data-theme-style="dark"] .tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link:focus .tp-dashboard-shortcut-card.tp-dashboard-conversion-card.tp-dashboard-insights-card,
[data-theme-style="dark"] .tp-dashboard-shortcuts-row .tp-dashboard-files-count-link.tp-dashboard-shortcut-link:active .tp-dashboard-shortcut-card.tp-dashboard-conversion-card.tp-dashboard-insights-card {
  border-color: rgba(124, 195, 244, .58) !important;
  background: linear-gradient(180deg, rgba(27, 105, 176, .84), rgba(19, 60, 136, .8)) !important;
  box-shadow: 0 10px 24px rgba(2, 8, 20, .38), inset 0 1px 0 rgba(255, 255, 255, .2) !important;
  transform: none !important;
  filter: none !important;
}

/* =========================================================
   MERGED LEGACY PAGES CSS
   Keep active custom CSS in this single file only.
   ========================================================= */

/* Pages (index, category, detail) – isolated surface fixes */

[data-theme-style="light"] .tp-pages-container .card,
[data-theme-style="light"] .tp-pages-container .bg-gray-50 {
    background: #ffffff !important;
    border-radius: 18px !important;
    box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content,
[data-theme-style="light"] .tp-pages-container .ql-content {
    color: #10253f;
}

/* ------------------------------------------------------------------
   Unified text typography (pages + blog content inside tp-pages-container)
   ------------------------------------------------------------------ */
[data-theme-style="light"] .tp-pages-container .tp-custom-page-boxed .card-body > h1.h4,
[data-theme-style="light"] .tp-pages-container .tp-custom-page-title {
    font-weight: 900 !important;
    font-size: 2rem !important;
    line-height: 1.15;
    color: hsl(221, 39%, 11%) !important;
    letter-spacing: -0.02em;
}

[data-theme-style="light"] .tp-pages-container .tp-blog-post-title {
    font-weight: 900 !important;
    font-size: 2rem !important;
    line-height: 1.15;
    color: hsl(221, 39%, 11%) !important;
    letter-spacing: -0.02em;
}

[data-theme-style="light"] .tp-pages-container .tp-custom-page-description,
[data-theme-style="light"] .tp-pages-container .tp-custom-page-body,
[data-theme-style="light"] .tp-pages-container .blog-post-content,
[data-theme-style="light"] .tp-pages-container .ql-content,
[data-theme-style="light"] .tp-pages-container .blog-post-content p,
[data-theme-style="light"] .tp-pages-container .blog-post-content li,
[data-theme-style="light"] .tp-pages-container .blog-post-content div,
[data-theme-style="light"] .tp-pages-container .blog-post-content span,
[data-theme-style="light"] .tp-pages-container .ql-content p,
[data-theme-style="light"] .tp-pages-container .ql-content li,
[data-theme-style="light"] .tp-pages-container .ql-content div,
[data-theme-style="light"] .tp-pages-container .ql-content span {
    color: hsl(221, 39%, 11%);
}

[data-theme-style="light"] .tp-pages-container .blog-post-content h1,
[data-theme-style="light"] .tp-pages-container .blog-post-content h2,
[data-theme-style="light"] .tp-pages-container .blog-post-content h3,
[data-theme-style="light"] .tp-pages-container .blog-post-content h4,
[data-theme-style="light"] .tp-pages-container .blog-post-content h5,
[data-theme-style="light"] .tp-pages-container .blog-post-content h6,
[data-theme-style="light"] .tp-pages-container .ql-content h1,
[data-theme-style="light"] .tp-pages-container .ql-content h2,
[data-theme-style="light"] .tp-pages-container .ql-content h3,
[data-theme-style="light"] .tp-pages-container .ql-content h4,
[data-theme-style="light"] .tp-pages-container .ql-content h5,
[data-theme-style="light"] .tp-pages-container .ql-content h6 {
    color: hsl(221, 39%, 11%) !important;
    font-weight: 850;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin-top: 1.4rem;
    margin-bottom: .65rem;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content h1,
[data-theme-style="light"] .tp-pages-container .ql-content h1 { font-size: 1.75rem; }
[data-theme-style="light"] .tp-pages-container .blog-post-content h2,
[data-theme-style="light"] .tp-pages-container .ql-content h2 { font-size: 1.65rem; }
[data-theme-style="light"] .tp-pages-container .blog-post-content h3,
[data-theme-style="light"] .tp-pages-container .ql-content h3 { font-size: 1.65rem; }
[data-theme-style="light"] .tp-pages-container .blog-post-content h4,
[data-theme-style="light"] .tp-pages-container .ql-content h4 { font-size: 1.40rem; }
[data-theme-style="light"] .tp-pages-container .blog-post-content h5,
[data-theme-style="light"] .tp-pages-container .blog-post-content h6,
[data-theme-style="light"] .tp-pages-container .ql-content h5,
[data-theme-style="light"] .tp-pages-container .ql-content h6 { font-size: 1.40rem; }

[data-theme-style="light"] .tp-pages-container .blog-post-content h2,
[data-theme-style="light"] .tp-pages-container .blog-post-content h3,
[data-theme-style="light"] .tp-pages-container .blog-post-content h4,
[data-theme-style="light"] .tp-pages-container .blog-post-content h5,
[data-theme-style="light"] .tp-pages-container .blog-post-content h6,
[data-theme-style="light"] .tp-pages-container .ql-content h2,
[data-theme-style="light"] .tp-pages-container .ql-content h3,
[data-theme-style="light"] .tp-pages-container .ql-content h4,
[data-theme-style="light"] .tp-pages-container .ql-content h5,
[data-theme-style="light"] .tp-pages-container .ql-content h6 {
    font-weight: 600 !important;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content p,
[data-theme-style="light"] .tp-pages-container .ql-content p,
[data-theme-style="light"] .tp-pages-container .blog-post-content li,
[data-theme-style="light"] .tp-pages-container .ql-content li {
    line-height: 1.68;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content p + p,
[data-theme-style="light"] .tp-pages-container .ql-content p + p,
[data-theme-style="dark"] .tp-pages-container .blog-post-content p + p,
[data-theme-style="dark"] .tp-pages-container .ql-content p + p {
    margin-top: 0;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content ul,
[data-theme-style="light"] .tp-pages-container .blog-post-content ol,
[data-theme-style="light"] .tp-pages-container .ql-content ul,
[data-theme-style="light"] .tp-pages-container .ql-content ol {
    margin: .75rem 0 1.1rem;
    padding-left: 1.2rem;
    color: hsl(221, 39%, 11%);
}

[data-theme-style="light"] .tp-pages-container .blog-post-content p + ul,
[data-theme-style="light"] .tp-pages-container .blog-post-content p + ol,
[data-theme-style="light"] .tp-pages-container .ql-content p + ul,
[data-theme-style="light"] .tp-pages-container .ql-content p + ol {
    margin-top: -1.5rem;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content li,
[data-theme-style="light"] .tp-pages-container .ql-content li {
    margin: .32rem 0;
    line-height: 1.6;
    color: inherit !important;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content ul li::marker,
[data-theme-style="light"] .tp-pages-container .ql-content ul li::marker {
    color: currentColor;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content ol li::marker,
[data-theme-style="light"] .tp-pages-container .ql-content ol li::marker {
    color: currentColor;
    font-weight: 700;
}

[data-theme-style="light"] .tp-pages-container .text-muted {
    color: rgba(66, 79, 96, .82) !important;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content .btn,
[data-theme-style="light"] .tp-pages-container .blog-post-content a.btn,
[data-theme-style="light"] .tp-pages-container .ql-content .btn,
[data-theme-style="light"] .tp-pages-container .ql-content a.btn {
    margin-top: 0rem;
    margin-bottom: 1.5rem;
}

/* Quote block (EditorJS + custom HTML) */
[data-theme-style="light"] .tp-pages-container .blog-post-content blockquote,
[data-theme-style="light"] .tp-pages-container .ql-content blockquote {
    position: relative;
    margin: 2.4rem 0 2.55rem !important;
    padding: 1.4rem 1.55rem 1.18rem 7.4rem !important;
    border: 1px solid #d8e2ee !important;
    border-radius: 18px !important;
    background: linear-gradient(180deg, #ffffff 0%, #ffffff 100%) !important;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content blockquote::before,
[data-theme-style="light"] .tp-pages-container .ql-content blockquote::before {
    content: '"';
    position: absolute;
    top: 1.08rem;
    left: -1rem;
    font-size: 17.8rem;
    line-height: .62;
    font-weight: 700;
    font-style: normal !important;
    font-family: "Ephesis", cursive;
    color: rgba(89, 124, 161, 0.28);
    pointer-events: none;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content blockquote,
[data-theme-style="light"] .tp-pages-container .ql-content blockquote,
[data-theme-style="light"] .tp-pages-container .blog-post-content blockquote > span,
[data-theme-style="light"] .tp-pages-container .ql-content blockquote > span {
    color: #16263a !important;
    font-size: 1.5rem !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    font-style: italic !important;
    font-family: inherit;
    letter-spacing: -0.008em;
}

[data-theme-style="light"] .tp-pages-container .blog-post-content blockquote cite,
[data-theme-style="light"] .tp-pages-container .ql-content blockquote cite,
[data-theme-style="light"] .tp-pages-container .blog-post-content blockquote .font-size-small,
[data-theme-style="light"] .tp-pages-container .ql-content blockquote .font-size-small,
[data-theme-style="light"] .tp-pages-container .blog-post-content blockquote .font-weight-bold,
[data-theme-style="light"] .tp-pages-container .ql-content blockquote .font-weight-bold {
    display: block;
    margin-top: 0.62rem !important;
    color: #5f7289 !important;
    font-size: 1.03rem !important;
    line-height: 1.52 !important;
    font-weight: 400 !important;
    font-style: normal !important;
    letter-spacing: 0;
}

[data-theme-style="dark"] .tp-pages-container .tp-custom-page-boxed .card-body > h1.h4,
[data-theme-style="dark"] .tp-pages-container .tp-custom-page-title {
    font-weight: 900 !important;
    font-size: 2rem !important;
    line-height: 1.15;
    color: #eaf2ff !important;
    letter-spacing: -0.02em;
}

[data-theme-style="dark"] .tp-pages-container .tp-blog-post-title {
    font-weight: 900 !important;
    font-size: 2rem !important;
    line-height: 1.15;
    color: #eaf2ff !important;
    letter-spacing: -0.02em;
}

[data-theme-style="dark"] .tp-pages-container .tp-custom-page-description,
[data-theme-style="dark"] .tp-pages-container .tp-custom-page-body,
[data-theme-style="dark"] .tp-pages-container .blog-post-content,
[data-theme-style="dark"] .tp-pages-container .ql-content,
[data-theme-style="dark"] .tp-pages-container .blog-post-content p,
[data-theme-style="dark"] .tp-pages-container .blog-post-content li,
[data-theme-style="dark"] .tp-pages-container .blog-post-content div,
[data-theme-style="dark"] .tp-pages-container .blog-post-content span,
[data-theme-style="dark"] .tp-pages-container .ql-content p,
[data-theme-style="dark"] .tp-pages-container .ql-content li,
[data-theme-style="dark"] .tp-pages-container .ql-content div,
[data-theme-style="dark"] .tp-pages-container .ql-content span {
    color: #d9e6f6;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content h1,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h2,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h3,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h4,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h5,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h6,
[data-theme-style="dark"] .tp-pages-container .ql-content h1,
[data-theme-style="dark"] .tp-pages-container .ql-content h2,
[data-theme-style="dark"] .tp-pages-container .ql-content h3,
[data-theme-style="dark"] .tp-pages-container .ql-content h4,
[data-theme-style="dark"] .tp-pages-container .ql-content h5,
[data-theme-style="dark"] .tp-pages-container .ql-content h6 {
    color: #eaf2ff !important;
    font-weight: 850;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin-top: 1.4rem;
    margin-bottom: .65rem;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content h1,
[data-theme-style="dark"] .tp-pages-container .ql-content h1 { font-size: 1.75rem; }
[data-theme-style="dark"] .tp-pages-container .blog-post-content h2,
[data-theme-style="dark"] .tp-pages-container .ql-content h2 { font-size: 1.65rem; }
[data-theme-style="dark"] .tp-pages-container .blog-post-content h3,
[data-theme-style="dark"] .tp-pages-container .ql-content h3 { font-size: 1.65rem; }
[data-theme-style="dark"] .tp-pages-container .blog-post-content h4,
[data-theme-style="dark"] .tp-pages-container .ql-content h4 { font-size: 1.40rem; }
[data-theme-style="dark"] .tp-pages-container .blog-post-content h5,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h6,
[data-theme-style="dark"] .tp-pages-container .ql-content h5,
[data-theme-style="dark"] .tp-pages-container .ql-content h6 { font-size: 1.40rem; }

[data-theme-style="dark"] .tp-pages-container .blog-post-content h2,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h3,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h4,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h5,
[data-theme-style="dark"] .tp-pages-container .blog-post-content h6,
[data-theme-style="dark"] .tp-pages-container .ql-content h2,
[data-theme-style="dark"] .tp-pages-container .ql-content h3,
[data-theme-style="dark"] .tp-pages-container .ql-content h4,
[data-theme-style="dark"] .tp-pages-container .ql-content h5,
[data-theme-style="dark"] .tp-pages-container .ql-content h6 {
    font-weight: 600 !important;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content p,
[data-theme-style="dark"] .tp-pages-container .ql-content p,
[data-theme-style="dark"] .tp-pages-container .blog-post-content li,
[data-theme-style="dark"] .tp-pages-container .ql-content li {
    line-height: 1.68;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content ul,
[data-theme-style="dark"] .tp-pages-container .blog-post-content ol,
[data-theme-style="dark"] .tp-pages-container .ql-content ul,
[data-theme-style="dark"] .tp-pages-container .ql-content ol {
    margin: .75rem 0 1.1rem;
    padding-left: 1.2rem;
    color: #d9e6f6;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content p + ul,
[data-theme-style="dark"] .tp-pages-container .blog-post-content p + ol,
[data-theme-style="dark"] .tp-pages-container .ql-content p + ul,
[data-theme-style="dark"] .tp-pages-container .ql-content p + ol {
    margin-top: -1.5rem;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content li,
[data-theme-style="dark"] .tp-pages-container .ql-content li {
    margin: .32rem 0;
    line-height: 1.6;
    color: inherit !important;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content ul li::marker,
[data-theme-style="dark"] .tp-pages-container .ql-content ul li::marker {
    color: currentColor;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content ol li::marker,
[data-theme-style="dark"] .tp-pages-container .ql-content ol li::marker {
    color: currentColor;
    font-weight: 700;
}

[data-theme-style="dark"] .tp-pages-container .text-muted {
    color: rgba(211, 227, 245, .78) !important;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content .btn,
[data-theme-style="dark"] .tp-pages-container .blog-post-content a.btn,
[data-theme-style="dark"] .tp-pages-container .ql-content .btn,
[data-theme-style="dark"] .tp-pages-container .ql-content a.btn {
    margin-top: .35rem;
    margin-bottom: .9rem;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote,
[data-theme-style="dark"] .tp-pages-container .ql-content blockquote {
    position: relative;
    margin: 2.4rem 0 2.55rem !important;
    padding: 1.4rem 1.55rem 1.18rem 5.4rem !important;
    border: 1px solid rgba(88, 111, 138, 0.56) !important;
    border-left: 1px solid rgba(88, 111, 138, 0.56) !important;
    border-radius: 18px !important;
    background: linear-gradient(180deg, rgba(24, 35, 50, 0.9), rgba(17, 27, 41, 0.94)) !important;
    box-shadow: 0 12px 26px rgba(2, 8, 23, 0.32) !important;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote::before,
[data-theme-style="dark"] .tp-pages-container .ql-content blockquote::before {
    content: '"';
    position: absolute;
    top: 1rem;
    left: 1rem;
    font-size: 6rem;
    line-height: .62;
    font-weight: 700;
    font-style: normal !important;
    font-family: "Ephesis", cursive;
    color: rgba(159, 192, 225, 0.24);
    pointer-events: none;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote,
[data-theme-style="dark"] .tp-pages-container .ql-content blockquote,
[data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote > span,
[data-theme-style="dark"] .tp-pages-container .ql-content blockquote > span {
    color: #e6edf7 !important;
    font-size: 1.4rem !important;
    line-height: 1.58 !important;
    font-weight: 700 !important;
    font-style: italic !important;
    font-family: inherit;
    letter-spacing: -0.008em;
}

[data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote cite,
[data-theme-style="dark"] .tp-pages-container .ql-content blockquote cite,
[data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote .font-size-small,
[data-theme-style="dark"] .tp-pages-container .ql-content blockquote .font-size-small,
[data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote .font-weight-bold,
[data-theme-style="dark"] .tp-pages-container .ql-content blockquote .font-weight-bold {
    display: block;
    margin-top: 0.62rem !important;
    color: #98acc2 !important;
    font-size: 1.03rem !important;
    line-height: 1.52 !important;
    font-weight: 400 !important;
    font-style: normal !important;
    letter-spacing: 0;
}

@media (max-width: 767.98px) {
    [data-theme-style="light"] .tp-pages-container .tp-custom-page-boxed .card-body > h1.h4,
    [data-theme-style="light"] .tp-pages-container .tp-custom-page-title {
        font-size: 1.6rem !important;
        line-height: 1.18;
    }

    [data-theme-style="light"] .tp-pages-container .tp-blog-post-title {
        font-size: 1.6rem !important;
        line-height: 1.18;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content h1,
    [data-theme-style="light"] .tp-pages-container .ql-content h1 {
        font-size: 1.45rem;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content h2,
    [data-theme-style="light"] .tp-pages-container .ql-content h2,
    [data-theme-style="light"] .tp-pages-container .blog-post-content h3,
    [data-theme-style="light"] .tp-pages-container .ql-content h3 {
        font-size: 1.32rem;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content h4,
    [data-theme-style="light"] .tp-pages-container .blog-post-content h5,
    [data-theme-style="light"] .tp-pages-container .blog-post-content h6,
    [data-theme-style="light"] .tp-pages-container .ql-content h4,
    [data-theme-style="light"] .tp-pages-container .ql-content h5,
    [data-theme-style="light"] .tp-pages-container .ql-content h6 {
        font-size: 1.18rem;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content h1,
    [data-theme-style="light"] .tp-pages-container .blog-post-content h2,
    [data-theme-style="light"] .tp-pages-container .blog-post-content h3,
    [data-theme-style="light"] .tp-pages-container .blog-post-content h4,
    [data-theme-style="light"] .tp-pages-container .blog-post-content h5,
    [data-theme-style="light"] .tp-pages-container .blog-post-content h6,
    [data-theme-style="light"] .tp-pages-container .ql-content h1,
    [data-theme-style="light"] .tp-pages-container .ql-content h2,
    [data-theme-style="light"] .tp-pages-container .ql-content h3,
    [data-theme-style="light"] .tp-pages-container .ql-content h4,
    [data-theme-style="light"] .tp-pages-container .ql-content h5,
    [data-theme-style="light"] .tp-pages-container .ql-content h6 {
        margin-top: 1.1rem;
        margin-bottom: .5rem;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content p,
    [data-theme-style="light"] .tp-pages-container .ql-content p,
    [data-theme-style="light"] .tp-pages-container .blog-post-content li,
    [data-theme-style="light"] .tp-pages-container .ql-content li {
        line-height: 1.58;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content ul,
    [data-theme-style="light"] .tp-pages-container .blog-post-content ol,
    [data-theme-style="light"] .tp-pages-container .ql-content ul,
    [data-theme-style="light"] .tp-pages-container .ql-content ol {
        padding-left: 1.05rem;
        margin: .6rem 0 .95rem;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content li,
    [data-theme-style="light"] .tp-pages-container .ql-content li {
        margin: .22rem 0;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content blockquote,
    [data-theme-style="light"] .tp-pages-container .ql-content blockquote,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote,
    [data-theme-style="dark"] .tp-pages-container .ql-content blockquote {
        margin: 1.7rem 0 1.9rem !important;
        padding: 1rem 1rem .9rem 4.5rem !important;
        border-radius: 16px !important;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content blockquote,
    [data-theme-style="light"] .tp-pages-container .ql-content blockquote,
    [data-theme-style="light"] .tp-pages-container .blog-post-content blockquote > span,
    [data-theme-style="light"] .tp-pages-container .ql-content blockquote > span,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote,
    [data-theme-style="dark"] .tp-pages-container .ql-content blockquote,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote > span,
    [data-theme-style="dark"] .tp-pages-container .ql-content blockquote > span {
        font-size: 1.12rem !important;
        line-height: 1.52 !important;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content blockquote::before,
    [data-theme-style="light"] .tp-pages-container .ql-content blockquote::before,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote::before,
    [data-theme-style="dark"] .tp-pages-container .ql-content blockquote::before {
        top: .68rem !important;
        left: .72rem !important;
        font-size: 4.1rem !important;
        line-height: .68 !important;
    }

    [data-theme-style="light"] .tp-pages-container .blog-post-content blockquote cite,
    [data-theme-style="light"] .tp-pages-container .ql-content blockquote cite,
    [data-theme-style="light"] .tp-pages-container .blog-post-content blockquote .font-size-small,
    [data-theme-style="light"] .tp-pages-container .ql-content blockquote .font-size-small,
    [data-theme-style="light"] .tp-pages-container .blog-post-content blockquote .font-weight-bold,
    [data-theme-style="light"] .tp-pages-container .ql-content blockquote .font-weight-bold,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote cite,
    [data-theme-style="dark"] .tp-pages-container .ql-content blockquote cite,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote .font-size-small,
    [data-theme-style="dark"] .tp-pages-container .ql-content blockquote .font-size-small,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content blockquote .font-weight-bold,
    [data-theme-style="dark"] .tp-pages-container .ql-content blockquote .font-weight-bold {
        font-size: .94rem !important;
        margin-top: .5rem !important;
    }

    [data-theme-style="dark"] .tp-pages-container .tp-custom-page-boxed .card-body > h1.h4,
    [data-theme-style="dark"] .tp-pages-container .tp-custom-page-title {
        font-size: 1.6rem !important;
        line-height: 1.18;
    }

    [data-theme-style="dark"] .tp-pages-container .tp-blog-post-title {
        font-size: 1.6rem !important;
        line-height: 1.18;
    }

    [data-theme-style="dark"] .tp-pages-container .blog-post-content h1,
    [data-theme-style="dark"] .tp-pages-container .ql-content h1 {
        font-size: 1.45rem;
    }

    [data-theme-style="dark"] .tp-pages-container .blog-post-content h2,
    [data-theme-style="dark"] .tp-pages-container .ql-content h2,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content h3,
    [data-theme-style="dark"] .tp-pages-container .ql-content h3 {
        font-size: 1.32rem;
    }

    [data-theme-style="dark"] .tp-pages-container .blog-post-content h4,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content h5,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content h6,
    [data-theme-style="dark"] .tp-pages-container .ql-content h4,
    [data-theme-style="dark"] .tp-pages-container .ql-content h5,
    [data-theme-style="dark"] .tp-pages-container .ql-content h6 {
        font-size: 1.18rem;
    }

    [data-theme-style="dark"] .tp-pages-container .blog-post-content h1,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content h2,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content h3,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content h4,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content h5,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content h6,
    [data-theme-style="dark"] .tp-pages-container .ql-content h1,
    [data-theme-style="dark"] .tp-pages-container .ql-content h2,
    [data-theme-style="dark"] .tp-pages-container .ql-content h3,
    [data-theme-style="dark"] .tp-pages-container .ql-content h4,
    [data-theme-style="dark"] .tp-pages-container .ql-content h5,
    [data-theme-style="dark"] .tp-pages-container .ql-content h6 {
        margin-top: 1.1rem;
        margin-bottom: .5rem;
    }

    [data-theme-style="dark"] .tp-pages-container .blog-post-content p,
    [data-theme-style="dark"] .tp-pages-container .ql-content p,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content li,
    [data-theme-style="dark"] .tp-pages-container .ql-content li {
        line-height: 1.58;
    }

    [data-theme-style="dark"] .tp-pages-container .blog-post-content ul,
    [data-theme-style="dark"] .tp-pages-container .blog-post-content ol,
    [data-theme-style="dark"] .tp-pages-container .ql-content ul,
    [data-theme-style="dark"] .tp-pages-container .ql-content ol {
        padding-left: 1.05rem;
        margin: .6rem 0 .95rem;
    }

    [data-theme-style="dark"] .tp-pages-container .blog-post-content li,
    [data-theme-style="dark"] .tp-pages-container .ql-content li {
        margin: .22rem 0;
    }
}

[data-theme-style="dark"] .tp-pages-container .card,
[data-theme-style="dark"] .tp-pages-container .bg-gray-50 {
    background: linear-gradient(180deg, hsl(218deg 23.65% 16.68%), rgb(0 0 0 / 92%)) !important;
    border: 1px solid rgba(255, 255, 255, 0.06) !important;
    border-radius: 18px !important;
    box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
}

.tp-custom-page-layout.tp-custom-page-layout-full {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding: .2rem 2rem 0;
}

.tp-custom-page-layout.tp-custom-page-layout-full .tp-custom-page-body > *:last-child {
    margin-bottom: 0;
}

/* Remove accidental top gap from the first GrapesJS block */
.tp-custom-page-body > style#tp-grapesjs-css + *,
.tp-custom-page-body-full > style#tp-grapesjs-css + * {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

.tp-custom-page-body > style#tp-grapesjs-css + .container,
.tp-custom-page-body > style#tp-grapesjs-css + .container-fluid,
.tp-custom-page-body-full > style#tp-grapesjs-css + .container,
.tp-custom-page-body-full > style#tp-grapesjs-css + .container-fluid {
    padding-top: 0 !important;
}

.tp-custom-page-boxed .card-body {
    padding: 1.5rem;
}

.tp-custom-page-plain {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.tp-custom-page-plain-body {
    padding: 1.5rem;
}

.tp-custom-page-layout.tp-custom-page-layout-full .tp-custom-page-body-full {
    width: 100% !important;
    max-width: none !important;
}

.tp-custom-page-layout.tp-custom-page-layout-full .tp-custom-page-header,
.tp-custom-page-layout.tp-custom-page-layout-full .tp-custom-page-description {
    max-width: none !important;
}

.tp-custom-page-layout.tp-custom-page-layout-full .tp-custom-page-body-full .container,
.tp-custom-page-layout.tp-custom-page-layout-full .tp-custom-page-body-full .container-fluid {
    width: 100% !important;
    max-width: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.tp-pages-container.tp-pages-container-full {
    max-width: 100% !important;
    width: 100%;
}

@media (max-width: 991.98px) {
    .tp-custom-page-layout.tp-custom-page-layout-full {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

.tp-custom-page-layout.tp-custom-page-layout-full.tp-custom-page-layout-full-transparent {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: .2rem 2rem 0;
}

[data-theme-style="light"] .tp-custom-page-layout.tp-custom-page-layout-full.tp-custom-page-layout-full-bg {
    background: #ffffff !important;
    border-radius: 18px !important;
    box-shadow: 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
    padding: 1.5rem;
}

[data-theme-style="dark"] .tp-custom-page-layout.tp-custom-page-layout-full.tp-custom-page-layout-full-bg {
    background: linear-gradient(180deg, hsl(218deg 23.65% 16.68%), rgb(0 0 0 / 92%)) !important;
    border: 1px solid rgba(255, 255, 255, 0.06) !important;
    border-radius: 18px !important;
    box-shadow: 0 16px 38px rgba(6, 16, 34, .14), 0 8px 18px rgba(6, 16, 34, .10), inset 0 1px 0 rgb(113 113 113 / 66%) !important;
    padding: 1.5rem;
}

@media (max-width: 991.98px) {
    .tp-custom-page-layout.tp-custom-page-layout-full.tp-custom-page-layout-full-transparent {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

/* EditorJS nested columns block (pages/blog only) */
.tp-pages-container .tp-editor-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin: 1rem 0 1.25rem;
    align-items: stretch;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--40-60 {
    grid-template-columns: 2fr 3fr;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--50-50 {
    grid-template-columns: 1fr 1fr;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--60-40 {
    grid-template-columns: 3fr 2fr;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--single {
    grid-template-columns: 1fr;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--thirds {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--25-50-25 {
    grid-template-columns: 1fr 2fr 1fr;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--fourths {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--how-it-works {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
}

.tp-pages-container .tp-editor-columns-col {
    min-width: 0;
}

.tp-pages-container .tp-editor-columns:not(.tp-editor-columns--single) .tp-editor-columns-col {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.tp-pages-container .tp-editor-columns:not(.tp-editor-columns--single) .tp-editor-columns-col > .card,
.tp-pages-container .tp-editor-columns:not(.tp-editor-columns--single) .tp-editor-columns-col > .card > .card-body,
.tp-pages-container .tp-editor-columns:not(.tp-editor-columns--single) .tp-editor-columns-col > .card > .card-body > .blog-post-content {
    height: 100%;
}

.tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home {
    align-items: stretch;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns.tp-editor-columns--cta-home {
    align-items: stretch;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home > .card-body {
    padding: 3rem !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:last-child {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-end !important;
    align-self: center !important;
    min-height: auto;
    height: 100%;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:last-child {
    align-self: center !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:last-child .index-button {
    width: auto !important;
    max-width: 100%;
    margin: 0 0 0 auto !important;
}

/* CTA typography (only for CTA block) */
.tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:first-child h2 {
    font-size: clamp(2rem, 3.2vw, 2.60rem);
    font-weight: 700 !important;
    line-height: 1.06;
}

.tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:first-child h3 {
    font-size: clamp(1.65rem, 2.8vw, 2.35rem);
    line-height: 1.12;
}

.tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:first-child h4 {
    font-size: clamp(1.35rem, 2.1vw, 1.85rem);
    line-height: 1.2;
}

.tp-pages-container .tp-editor-columns-col > *:first-child {
    margin-top: 0 !important;
}

.tp-pages-container .tp-editor-columns-col > *:last-child {
    margin-bottom: 0 !important;
}

/* Box content rhythm: keep inner spacing, remove only top/bottom outer gap in each box */
.tp-pages-container .tp-editor-columns-col .blog-post-content > :first-child,
.tp-pages-container .tp-editor-columns-col .ql-content > :first-child {
    margin-top: 0 !important;
}

.tp-pages-container .tp-editor-columns-col .blog-post-content > :last-child,
.tp-pages-container .tp-editor-columns-col .ql-content > :last-child {
    margin-bottom: 0 !important;
}

.tp-pages-container .tp-editor-columns-col .blog-post-content p,
.tp-pages-container .tp-editor-columns-col .ql-content p,
.tp-pages-container .tp-editor-columns-col p {
    max-width: 100%;
}

.tp-pages-container .tp-editor-columns-col img {
    max-width: 100%;
    height: auto;
}

.tp-pages-container .tp-editor-icon-box {
    height: auto;
    min-height: 100%;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    padding: .4rem .35rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: inherit;
}

.tp-pages-container .tp-editor-columns .tp-editor-icon-box {
    height: 100%;
}

.tp-pages-container .tp-editor-columns .tp-editor-icon-box > .tp-editor-icon-box-icon {
    --tp-icon-box-size: 1.55rem;
    margin: .34rem 0 .58rem;
    line-height: 1;
}

.tp-pages-container .tp-editor-columns .tp-editor-icon-box > .tp-editor-icon-box-icon > i {
    font-size: var(--tp-icon-box-size) !important;
    color: inherit;
    width: var(--tp-icon-box-size);
    height: var(--tp-icon-box-size);
}

.tp-pages-container .tp-editor-columns .tp-editor-icon-box > .tp-editor-icon-box-icon > .svg-inline--fa {
    font-size: var(--tp-icon-box-size) !important;
    width: var(--tp-icon-box-size);
    height: var(--tp-icon-box-size);
    color: inherit !important;
}

.tp-pages-container .tp-editor-icon-box-title {
    margin: 0 0 .65rem;
    font-size: 1.65rem;
    line-height: 1.18;
    font-weight: 700;
    color: inherit;
}

.tp-pages-container .tp-editor-icon-box-text {
    margin: 0;
    color: inherit;
    opacity: .72;
    font-size: 1.02rem;
    line-height: 1.75;
    max-width: 34ch;
}
[data-theme-style="dark"] .tp-pages-container .tp-editor-icon-box-text { opacity: .84; }

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col {
    position: relative;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col--step::before {
    content: attr(data-step-number);
    position: absolute;
    top: .35rem;
    right: 1.2rem;
    font-size: clamp(5rem, 8vw, 7.4rem);
    line-height: .84;
    font-weight: 900;
    letter-spacing: -.03em;
    color: rgba(15, 165, 235, .15);
    pointer-events: none;
    user-select: none;
    z-index: 4;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col--step .card .card-body > .blog-post-content {
    position: relative;
    z-index: 5;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col--step .card .card-body {
    padding-top: 4.1rem;
    padding-bottom: 1.5rem;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col .tp-editor-steps-arrow {
    position: absolute;
    right: -1.87rem;
    top: 50%;
    transform: translateY(-50%);
    width: 2.6rem;
    height: 2.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    z-index: 6;
    pointer-events: none;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col .tp-editor-steps-arrow i {
    color: rgb(201 209 212);
    font-size: 1.3rem;
    line-height: 1;
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col .tp-editor-steps-arrow svg {
    color: rgb(201 209 212);
    width: 1.3rem;
    height: 1.3rem;
}

[data-theme-style="dark"] .tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col .tp-editor-steps-arrow i,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col .tp-editor-steps-arrow svg {
    color: rgb(226 242 255);
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col--step[data-column-boxed="1"][data-column-box-style="blue-dark"]::before,
.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col--step[data-column-boxed="1"][data-column-box-style="blue"]::before {
    color: rgba(255, 255, 255, .22);
}

.tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col--step[data-column-boxed="1"][data-column-box-style="orange"]::before {
    color: rgba(31, 41, 55, .2);
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark {
    border: 1px solid rgb(18 52 124) !important;
    background: linear-gradient(180deg, #106db4, rgb(18 52 124)) !important;
    box-shadow: var(--tp-dashboard-card-shadow) !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark {
    border: 1px solid rgb(18 52 124) !important;
    background: linear-gradient(180deg, #106db4, rgb(18 52 124)) !important;
    box-shadow: var(--tp-dashboard-card-shadow) !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue {
    border: 1px solid rgb(35 136 219) !important;
    background: linear-gradient(180deg, #34b5ef, rgb(35 136 219)) !important;
    box-shadow: var(--tp-dashboard-card-shadow) !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue {
    border: 1px solid rgb(35 136 219) !important;
    background: linear-gradient(180deg, #34b5ef, rgb(35 136 219)) !important;
    box-shadow: var(--tp-dashboard-card-shadow) !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light {
    border: 1px solid rgba(15, 165, 235, .34) !important;
    background: linear-gradient(180deg, rgba(211, 236, 252, .92), rgba(236, 248, 255, .96)) !important;
    box-shadow: var(--tp-dashboard-card-shadow), 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light {
    border: 1px solid rgba(15, 165, 235, .34) !important;
    background: linear-gradient(180deg, rgba(211, 236, 252, .92), rgba(236, 248, 255, .96)) !important;
    box-shadow: var(--tp-dashboard-card-shadow), 0 3px 8px rgb(6 16 34 / 5%), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange {
    border: 1px solid rgba(235, 128, 15, .65) !important;
    background: linear-gradient(135deg, #ff9500 0%, #ff8a00 56%, #f67f00 100%) !important;
    box-shadow: var(--tp-dashboard-card-shadow) !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange {
    border: 1px solid rgba(235, 128, 15, .65) !important;
    background: linear-gradient(135deg, #ff9500 0%, #ff8a00 56%, #f67f00 100%) !important;
    box-shadow: var(--tp-dashboard-card-shadow) !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content p,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content li,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content h1,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content h2,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content h3,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content h4,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content h5,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content h6,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content p,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content li,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content h1,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content h2,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content h3,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content h4,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content h5,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content h6 {
    color: #ffffff !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .tp-editor-icon-box,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .tp-editor-icon-box *,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .tp-editor-icon-box,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .tp-editor-icon-box * {
    color: #ffffff !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-dark .blog-post-content a,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue .blog-post-content a {
    color: #ffffff !important;
    text-decoration-color: rgba(255, 255, 255, .8);
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col p,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col li,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col h1,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col h2,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col h3,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col h4,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col h5,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col h6,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col p,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col li,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col h1,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col h2,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col h3,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col h4,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col h5,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col h6 {
    color: #ffffff !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col a,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col a {
    color: #ffffff !important;
    text-decoration-color: rgba(255, 255, 255, .8);
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col div,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-dark .tp-editor-columns-col span,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col div,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue .tp-editor-columns-col span {
    color: #ffffff !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content p,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content li,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h1,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h2,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h3,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h4,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h5,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h6,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content p,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content li,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content h1,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content h2,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content h3,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content h4,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content h5,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content h6 {
    color: #1f2937;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .tp-editor-icon-box,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .tp-editor-icon-box *,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .tp-editor-icon-box,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .tp-editor-icon-box * {
    color: #1f2937 !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content a,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content a {
    color: #1f2937 !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col p,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col li,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col h1,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col h2,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col h3,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col h4,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col h5,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col h6,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col p,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col li,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col h1,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col h2,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col h3,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col h4,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col h5,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col h6 {
    color: #1f2937 !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--blue-light .tp-editor-columns-col a,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col a {
    color: #1f2937 !important;
}

.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content *,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content ul li::marker,
.tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--orange .blog-post-content ol li::marker {
    color: #000 !important;
}

.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col *,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col ul li::marker,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home.tp-editor-columns-card--orange .tp-editor-columns-col ol li::marker {
    color: #000 !important;
}

/* Keep CTA button text white in every background variant */
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button:hover,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button:active,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button:focus,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button:visited,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button *,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button:hover *,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button:active *,
.tp-pages-container .blog-post-content .tp-editor-columns-card.tp-editor-columns-card--cta-home .tp-editor-columns-col .index-button:focus * {
    color: #ffffff !important;
}

[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content p,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content li,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h1,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h2,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h3,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h4,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h5,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content h6,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content a,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content ul li::marker,
[data-theme-style="dark"] .tp-pages-container .tp-editor-columns-col .tp-editor-columns-card.tp-editor-columns-card--blue-light .blog-post-content ol li::marker {
    color: #1f2937 !important;
}

[data-theme-style="dark"] .tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col--step::before {
    color: rgba(255, 255, 255, .1);
}

.tp-editor-spacer {
    display: block;
    width: 100%;
    line-height: 0;
    font-size: 0;
    background: transparent;
    pointer-events: none;
}

.tp-editor-spacer--sm {
    height: .5rem;
}

.tp-editor-spacer--lg {
    height: 1.5rem;
}

@media (max-width: 991.98px) {
    .tp-pages-container .tp-editor-columns {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .tp-pages-container .tp-editor-columns-col img,
    .tp-pages-container .blog-post-content img,
    .tp-pages-container .ql-content img {
        display: block !important;
        width: 90% !important;
        max-width: 90% !important;
        margin-left: auto !important;
        margin-right: auto !important;
        height: auto !important;
    }

    .tp-pages-container .tp-editor-columns.tp-editor-columns--40-60,
    .tp-pages-container .tp-editor-columns.tp-editor-columns--50-50,
    .tp-pages-container .tp-editor-columns.tp-editor-columns--60-40,
    .tp-pages-container .tp-editor-columns.tp-editor-columns--single,
    .tp-pages-container .tp-editor-columns.tp-editor-columns--thirds,
    .tp-pages-container .tp-editor-columns.tp-editor-columns--25-50-25,
    .tp-pages-container .tp-editor-columns.tp-editor-columns--fourths,
    .tp-pages-container .tp-editor-columns.tp-editor-columns--how-it-works {
        grid-template-columns: 1fr !important;
    }

    .tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col .tp-editor-steps-arrow {
        right: auto;
        left: 50%;
        top: auto;
        bottom: -1.9rem;
        transform: translateX(-50%) rotate(90deg);
    }

    .tp-pages-container .tp-editor-columns.tp-editor-columns--steps .tp-editor-columns-col--step .card .card-body {
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
    }

    .tp-pages-container .tp-editor-icon-box {
        padding: .25rem .15rem;
    }

    .tp-pages-container .tp-editor-columns .tp-editor-icon-box > .tp-editor-icon-box-icon {
        --tp-icon-box-size: 1.38rem;
        margin: .24rem 0 .48rem;
    }

    .tp-pages-container .tp-editor-columns .tp-editor-icon-box > .tp-editor-icon-box-icon > i,
    .tp-pages-container .tp-editor-columns .tp-editor-icon-box > .tp-editor-icon-box-icon > .svg-inline--fa {
        font-size: var(--tp-icon-box-size) !important;
        width: var(--tp-icon-box-size);
        height: var(--tp-icon-box-size);
    }

    .tp-pages-container .tp-editor-icon-box-title {
        font-size: 1.4rem;
    }

    .tp-pages-container .tp-editor-icon-box-text {
        font-size: .98rem;
        line-height: 1.66;
    }

    .tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:last-child {
        flex-direction: row !important;
        justify-content: center !important;
        align-items: center !important;
        text-align: center !important;
        align-self: stretch !important;
    }

    .tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:last-child .index-button {
        margin: 0 auto !important;
        width: min(100%, 420px) !important;
    }

    .tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:first-child,
    .tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:first-child * {
        text-align: center !important;
    }

    .tp-pages-container .blog-post-content .tp-editor-columns.tp-editor-columns--cta-home .tp-editor-columns-col:first-child {
        padding-left: 0;
    }
}

.tp-custom-page-plain-body {
    padding: 0rem 0;
}

@media (max-width: 767.98px) {
    .tp-custom-page-plain-body {
        padding: 0rem 0.5rem;
    }
}

/* Dashboard add-files uploader: compact one-column uploader, isolated from homepage uploader skin. */
#tp_add_files_uploader.tp-transfer-add-files,
#tp_add_files_uploader.tp-transfer-add-files *,
#tp_add_files_uploader.tp-transfer-add-files *::before,
#tp_add_files_uploader.tp-transfer-add-files *::after {
  box-sizing: border-box;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_main_dropzone,
#tp_add_files_uploader.tp-transfer-add-files #upload_form,
#tp_add_files_uploader.tp-transfer-add-files #upload_form #upload_previews_wrapper,
#tp_add_files_uploader.tp-transfer-add-files #upload_form #upload_previews_files,
#tp_add_files_uploader.tp-transfer-add-files #upload_form #upload_previews,
#tp_add_files_uploader.tp-transfer-add-files #upload_form .upload-previews {
  min-height: 0 !important;
  height: auto !important;
  transform: none !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_main_dropzone {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 1rem 0 0 !important;
  padding: 0 !important;
  background: rgba(235, 248, 255, .86) !important;
  border: 1px dashed rgba(16, 110, 180, .38) !important;
  border-radius: 1.15rem !important;
  box-shadow: 0 14px 34px rgba(16, 110, 180, .10) !important;
  overflow: hidden !important;
}

[data-theme-style="dark"] #tp_add_files_uploader.tp-transfer-add-files #upload_main_dropzone {
  background: rgba(8, 23, 36, .82) !important;
  border-color: rgba(62, 190, 255, .34) !important;
  box-shadow: 0 16px 38px rgba(0, 0, 0, .28) !important;
}

#tp_add_files_uploader.tp-transfer-add-files .upload-hint-wrapper,
#tp_add_files_uploader.tp-transfer-add-files .upload-hint-badge {
  display: none !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_main_dropzone > .card-body {
  display: block !important;
  width: 100% !important;
  min-height: 0 !important;
  padding: 1.1rem !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_form > .row:first-of-type {
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_form > .row:first-of-type > [class*="col-"] {
  flex: 0 0 100% !important;
  max-width: 34rem !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: .5rem !important;
  padding-right: .5rem !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_select_files {
  min-height: 3.1rem !important;
  margin: 0 !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_select_folders {
  margin-top: .65rem !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_previews_wrapper {
  display: block;
  margin-top: 1rem !important;
  padding: 0 !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_previews_wrapper > .row {
  display: block !important;
  margin: 0 !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_previews_settings {
  display: none !important;
  width: 0 !important;
  max-width: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_previews_files {
  display: block !important;
  flex: 0 0 100% !important;
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 1rem !important;
  box-shadow: none !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_previews_files > .row:first-child {
  display: flex !important;
  align-items: center !important;
  min-height: 0 !important;
  height: auto !important;
  margin: 0 0 .75rem 0 !important;
  padding: .72rem .95rem !important;
  border: 1px solid rgba(16, 110, 180, .18) !important;
  border-radius: .95rem !important;
  background: rgba(255, 255, 255, .72) !important;
  box-shadow: none !important;
}

[data-theme-style="dark"] #tp_add_files_uploader.tp-transfer-add-files #upload_previews_files > .row:first-child {
  border-color: rgba(62, 190, 255, .18) !important;
  background: rgba(255, 255, 255, .05) !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_previews {
  width: 100% !important;
  max-height: 16rem !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-gutter: stable;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_previews .row {
  width: 100% !important;
  margin: .45rem 0 !important;
  padding: .68rem .85rem !important;
  border: 1px solid rgba(16, 110, 180, .12) !important;
  border-radius: .95rem !important;
  background: rgba(255, 255, 255, .78) !important;
  box-shadow: 0 8px 18px rgba(16, 110, 180, .08) !important;
  transform: none !important;
}

[data-theme-style="dark"] #tp_add_files_uploader.tp-transfer-add-files #upload_previews .row {
  border-color: rgba(62, 190, 255, .14) !important;
  background: rgba(255, 255, 255, .055) !important;
  box-shadow: 0 10px 22px rgba(0, 0, 0, .22) !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_form .row.mt-5 {
  display: flex !important;
  justify-content: center !important;
  margin: 1rem 0 0 !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_form .row.mt-5 > [class*="col-"] {
  flex: 0 0 100% !important;
  max-width: 34rem !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: .5rem !important;
  padding-right: .5rem !important;
}

#tp_add_files_uploader.tp-transfer-add-files #upload_submit {
  width: 100% !important;
  min-height: 3rem !important;
  margin: 0 auto !important;
}
