/* --- Theme tokens --- */
:root {
    --bg-main: #0f141b;
    --bg-glow: rgba(18, 113, 255, 0.18);
    --bg-card: rgba(24, 31, 42, 0.92);
    --bg-card-soft: rgba(255, 255, 255, 0.04);
    --text-prim: #f4f7fb;
    --text-sec: #9da9bb;
    --accent: #2f8cff;
    --accent-hover: #1979ef;
    --accent-soft: rgba(47, 140, 255, 0.18);
    --border: rgba(255, 255, 255, 0.1);
    --input-border: rgba(255, 255, 255, 0.14);
    --btn-bg: rgba(255, 255, 255, 0.06);
    --btn-hover: rgba(255, 255, 255, 0.11);
    --shadow: 0 24px 70px rgba(0, 0, 0, 0.34);
}

[data-theme="light"] {
    --bg-main: #eef3f8;
    --bg-glow: rgba(47, 140, 255, 0.22);
    --bg-card: rgba(255, 255, 255, 0.92);
    --bg-card-soft: rgba(15, 20, 27, 0.04);
    --text-prim: #152033;
    --text-sec: #637084;
    --accent: #146ee8;
    --accent-hover: #0f5fc9;
    --accent-soft: rgba(20, 110, 232, 0.14);
    --border: rgba(21, 32, 51, 0.1);
    --input-border: rgba(21, 32, 51, 0.14);
    --btn-bg: rgba(21, 32, 51, 0.06);
    --btn-hover: rgba(21, 32, 51, 0.1);
    --shadow: 0 24px 70px rgba(40, 61, 90, 0.18);
}

* {
    box-sizing: border-box;
}

body {
    min-height: 100vh;
    min-height: 100svh;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
    background:
        radial-gradient(circle at 50% 12%, var(--bg-glow), transparent 34rem),
        linear-gradient(145deg, var(--bg-main), #151b24);
    color: var(--text-prim);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 16px;
}

button,
input,
textarea {
    font: inherit;
}

button {
    -webkit-tap-highlight-color: transparent;
}

.app-container {
    width: min(100%, 860px);
    padding: 32px;
}

.navbar {
    z-index: 10;
    position: fixed;
    top: 22px;
    right: 22px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(12, 17, 24, 0.5);
    box-shadow: 0 12px 34px rgba(0, 0, 0, 0.18);
    backdrop-filter: blur(14px);
}

[data-theme="light"] .navbar {
    background: rgba(255, 255, 255, 0.6);
}

.lang-switcher {
    display: flex;
    gap: 6px;
}

.icon-btn,
.lang-btn {
    width: 40px;
    height: 40px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid transparent;
    border-radius: 8px;
    background-color: var(--btn-bg);
    cursor: pointer;
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease;
}

.icon-btn:hover,
.lang-btn:hover {
    transform: translateY(-1px);
    background-color: var(--btn-hover);
    border-color: var(--border);
}

.icon-btn:focus-visible,
.lang-btn:focus-visible,
input:focus-visible,
#toggle-password:focus-visible,
#connect-btn:focus-visible,
#disconnect-btn:focus-visible,
#create-tables-btn:focus-visible,
#wipe-db-btn:focus-visible,
#back-to-wallet-btn:focus-visible,
#back-from-tron-btn:focus-visible,
#back-from-ethereum-btn:focus-visible,
#back-from-audit-btn:focus-visible {
    outline: 3px solid var(--accent-soft);
    outline-offset: 2px;
}

.lang-btn.active {
    background-color: var(--accent);
    border-color: var(--accent);
}

.icon-btn img,
.lang-btn img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

.hidden {
    display: none !important;
}

.connect-card {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 38px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background:
        linear-gradient(180deg, var(--bg-card-soft), transparent 46%),
        var(--bg-card);
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px);
}

.wallet-logo {
    display: block;
    width: min(100%, 260px);
    height: auto;
    margin: 2px auto 16px;
    filter: drop-shadow(0 14px 24px rgba(0, 0, 0, 0.24));
}

[data-theme="light"] .wallet-logo {
    filter: invert(1) drop-shadow(0 14px 24px rgba(40, 61, 90, 0.12));
}

.input-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

label {
    color: var(--text-sec);
    font-size: 14px;
    font-weight: 650;
}

input {
    width: 100%;
    min-width: 0;
    min-height: 50px;
    padding: 0 16px;
    border: 1px solid var(--input-border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.035);
    color: var(--text-prim);
    transition: border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

textarea {
    width: 100%;
    min-width: 0;
    resize: vertical;
    min-height: 112px;
    padding: 13px 16px;
    border: 1px solid var(--input-border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.035);
    color: var(--text-prim);
    transition: border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

[data-theme="light"] textarea {
    background: rgba(255, 255, 255, 0.68);
}

textarea:hover {
    border-color: rgba(47, 140, 255, 0.42);
}

textarea:focus {
    border-color: var(--accent);
    background: rgba(255, 255, 255, 0.06);
    box-shadow: 0 0 0 4px var(--accent-soft);
    outline: none;
}

[data-theme="light"] input {
    background: rgba(255, 255, 255, 0.68);
}

input:hover {
    border-color: rgba(47, 140, 255, 0.42);
}

input:focus {
    border-color: var(--accent);
    background: rgba(255, 255, 255, 0.06);
    box-shadow: 0 0 0 4px var(--accent-soft);
    outline: none;
}

.password-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
}

.fake-password {
    -webkit-text-security: disc;
}

#toggle-password {
    min-width: 84px;
    min-height: 50px;
    padding: 0 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    font-size: 13px;
    font-weight: 750;
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease;
}

#toggle-password:hover {
    transform: translateY(-1px);
    background: var(--btn-hover);
    border-color: rgba(47, 140, 255, 0.32);
}

button.primary-btn,
button#connect-btn {
    min-height: 52px;
    margin-top: 8px;
    padding: 0 16px;
    border: none;
    border-radius: 8px;
    background: linear-gradient(180deg, var(--accent), var(--accent-hover));
    color: #fff;
    cursor: pointer;
    font-weight: 800;
    box-shadow: 0 14px 28px rgba(20, 110, 232, 0.28);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

button.primary-btn:hover,
button#connect-btn:hover {
    transform: translateY(-1px);
    filter: brightness(1.03);
    box-shadow: 0 18px 34px rgba(20, 110, 232, 0.34);
}

button.primary-btn:active,
button#connect-btn:active,
#toggle-password:active,
.icon-btn:active,
.lang-btn:active {
    transform: translateY(0);
}

.message {
    padding: 13px 16px;
    border-radius: 8px;
    font-size: 15px;
    line-height: 1.4;
    text-align: center;
}

.message.error {
    border: 1px solid rgba(248, 113, 113, 0.24);
    background-color: rgba(127, 29, 29, 0.28);
    color: #fecaca;
}

.message.success {
    border: 1px solid rgba(74, 222, 128, 0.24);
    background-color: rgba(22, 101, 52, 0.28);
    color: #bbf7d0;
}

.wallet-screen {
    width: min(100%, 800px);
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 32px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background:
        linear-gradient(180deg, var(--bg-card-soft), transparent 48%),
        var(--bg-card);
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px);
}

.wallet-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.wallet-logo-small {
    width: 205px;
    margin: 0;
}

.connection-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 14px;
    border: 1px solid rgba(74, 222, 128, 0.24);
    border-radius: 8px;
    background: rgba(22, 101, 52, 0.22);
    color: #bbf7d0;
    font-size: 14px;
    font-weight: 750;
}

.warning-pill {
    border-color: rgba(250, 204, 21, 0.28);
    background: rgba(113, 63, 18, 0.24);
    color: #fde68a;
}

.ready-pill {
    border-color: rgba(74, 222, 128, 0.24);
    background: rgba(22, 101, 52, 0.22);
    color: #bbf7d0;
}

.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #4ade80;
    box-shadow: 0 0 0 5px rgba(74, 222, 128, 0.12);
}

.warning-dot {
    background: #facc15;
    box-shadow: 0 0 0 5px rgba(250, 204, 21, 0.12);
}

.screen-title {
    margin: 0;
    font-size: 32px;
    line-height: 1.15;
}

.wallet-panel {
    display: grid;
    gap: 12px;
    padding: 26px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.045);
}

[data-theme="light"] .wallet-panel {
    background: rgba(255, 255, 255, 0.66);
}

.eyebrow {
    margin: 0 0 8px;
    color: var(--text-sec);
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.wallet-panel h1 {
    margin: 0;
    overflow-wrap: anywhere;
    font-size: 32px;
    line-height: 1.15;
}

.contracts-panel,
.users-panel {
    display: grid;
    gap: 16px;
    padding: 22px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.045);
}

[data-theme="light"] .contracts-panel,
[data-theme="light"] .users-panel {
    background: rgba(255, 255, 255, 0.66);
}

.contracts-panel h2,
.users-panel h2 {
    margin: 0;
    color: var(--text-prim);
    font-size: 20px;
}

.panel-heading-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

#create-user-btn {
    min-height: 44px;
    padding: 0 14px;
    border: none;
    border-radius: 8px;
    background: linear-gradient(180deg, var(--accent), var(--accent-hover));
    color: #fff;
    cursor: pointer;
    font-weight: 800;
}

.users-list {
    display: grid;
    gap: 10px;
}

.user-row {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.035);
}

.user-main strong {
    display: block;
    color: var(--text-prim);
    font-size: 16px;
}

.user-main small {
    display: block;
    margin-top: 5px;
    color: var(--text-sec);
    font-size: 13px;
    font-weight: 700;
}

.user-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.user-controls select,
#user-role {
    height: 42px;
    width: auto;
    min-width: 132px;
    flex: 1 1 132px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--input-bg);
    color: var(--text-prim);
    font-weight: 750;
}

.user-active-toggle {
    height: 42px;
    flex: 1 1 112px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-sec);
    font-size: 13px;
    font-weight: 800;
}

.user-controls button {
    min-height: 42px;
    flex: 1 1 96px;
    padding: 0 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    font-size: 12px;
    font-weight: 850;
    white-space: nowrap;
}

.user-controls [data-action="password"] {
    flex-basis: 150px;
}

.user-controls button:hover,
#create-user-btn:hover {
    filter: brightness(1.04);
}

.user-controls button:disabled {
    cursor: not-allowed;
    opacity: 0.48;
    filter: none;
}

.danger-user-btn {
    border-color: rgba(248, 113, 113, 0.28) !important;
    color: #fecaca !important;
}

#save-contracts-btn {
    min-height: 50px;
    padding: 0 16px;
    border: none;
    border-radius: 8px;
    background: linear-gradient(180deg, var(--accent), var(--accent-hover));
    color: #fff;
    cursor: pointer;
    font-weight: 800;
    box-shadow: 0 14px 28px rgba(20, 110, 232, 0.2);
}

#save-contracts-btn:hover {
    filter: brightness(1.03);
}

.wallet-copy {
    margin: 0;
    color: var(--text-sec);
    font-size: 16px;
    line-height: 1.45;
}

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

.action-card {
    min-height: 190px;
    display: grid;
    grid-template-rows: auto 1fr;
    align-content: start;
    gap: 20px;
    padding: 22px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.055), transparent),
        var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    text-align: left;
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.action-card:hover {
    transform: translateY(-2px);
    border-color: rgba(47, 140, 255, 0.36);
    background:
        linear-gradient(180deg, rgba(47, 140, 255, 0.12), transparent),
        var(--btn-hover);
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.18);
}

.action-card:focus-visible {
    outline: 3px solid var(--accent-soft);
    outline-offset: 2px;
}

.action-card:active {
    transform: translateY(0);
}

.action-card:disabled {
    cursor: not-allowed;
    opacity: 0.48;
    transform: none;
}

.action-card:disabled:hover {
    border-color: var(--border);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.055), transparent),
        var(--btn-bg);
    box-shadow: none;
}

.action-icon {
    width: 60px;
    height: 60px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(47, 140, 255, 0.24);
    border-radius: 8px;
    background: linear-gradient(145deg, rgba(47, 140, 255, 0.28), rgba(47, 140, 255, 0.1));
}

.action-icon img {
    width: 34px;
    height: 34px;
    object-fit: contain;
}

.tron-icon {
    border-color: rgba(248, 113, 113, 0.28);
    background: linear-gradient(145deg, rgba(239, 68, 68, 0.28), rgba(239, 68, 68, 0.1));
}

.eth-icon {
    border-color: rgba(129, 140, 248, 0.3);
    background: linear-gradient(145deg, rgba(99, 102, 241, 0.28), rgba(99, 102, 241, 0.1));
}

.ethereum-badge {
    border-color: rgba(129, 140, 248, 0.3);
    background: rgba(49, 46, 129, 0.24);
    color: #c7d2fe;
}

.ethereum-column-icon {
    border-color: rgba(129, 140, 248, 0.3);
    background: linear-gradient(145deg, rgba(99, 102, 241, 0.24), rgba(99, 102, 241, 0.08));
}

.action-card strong {
    display: block;
    margin-bottom: 8px;
    color: var(--text-prim);
    font-size: 18px;
    line-height: 1.25;
}

.action-card small {
    display: block;
    color: var(--text-sec);
    font-size: 14px;
    font-weight: 650;
    line-height: 1.35;
}

#disconnect-btn {
    min-height: 50px;
    padding: 0 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    font-weight: 800;
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease;
}

#disconnect-btn:hover {
    transform: translateY(-1px);
    background: var(--btn-hover);
    border-color: rgba(47, 140, 255, 0.32);
}

.table-status-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.table-status-card {
    min-height: 102px;
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 16px;
    padding: 20px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
}

.table-status-card.ready {
    border-color: rgba(74, 222, 128, 0.24);
    background: rgba(22, 101, 52, 0.16);
}

.table-status-dot {
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: #facc15;
    box-shadow: 0 0 0 6px rgba(250, 204, 21, 0.1);
}

.table-status-card.ready .table-status-dot {
    background: #4ade80;
    box-shadow: 0 0 0 6px rgba(74, 222, 128, 0.1);
}

.table-status-card strong {
    display: block;
    margin-bottom: 6px;
    color: var(--text-prim);
    font-size: 19px;
}

.table-status-card small {
    color: var(--text-sec);
    font-size: 14px;
    font-weight: 650;
}

.management-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

#create-tables-btn,
#wipe-db-btn,
#back-to-wallet-btn,
#back-from-tron-btn,
#back-from-ethereum-btn,
#back-from-audit-btn {
    min-height: 50px;
    padding: 0 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-prim);
    cursor: pointer;
    font-weight: 800;
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, filter 0.18s ease;
}

#create-tables-btn {
    border: none;
    background: linear-gradient(180deg, var(--accent), var(--accent-hover));
    color: #fff;
    box-shadow: 0 14px 28px rgba(20, 110, 232, 0.24);
}

#wipe-db-btn,
#back-to-wallet-btn,
#back-from-tron-btn,
#back-from-ethereum-btn,
#back-from-audit-btn {
    background: var(--btn-bg);
}

#wipe-db-btn {
    border-color: rgba(248, 113, 113, 0.26);
    color: #fecaca;
}

#create-tables-btn:hover,
#wipe-db-btn:hover,
#back-to-wallet-btn:hover,
#back-from-tron-btn:hover,
#back-from-ethereum-btn:hover,
#back-from-audit-btn:hover {
    transform: translateY(-1px);
    filter: brightness(1.03);
}

#wipe-db-btn:hover {
    background: rgba(127, 29, 29, 0.24);
}

#back-to-wallet-btn:hover,
#back-from-tron-btn:hover,
#back-from-ethereum-btn:hover,
#back-from-audit-btn:hover {
    background: var(--btn-hover);
    border-color: rgba(47, 140, 255, 0.32);
}

#create-tables-btn:disabled,
#wipe-db-btn:disabled {
    cursor: not-allowed;
    opacity: 0.48;
    transform: none;
    filter: none;
    box-shadow: none;
}

.network-badge {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 0 13px;
    border: 1px solid rgba(248, 113, 113, 0.28);
    border-radius: 8px;
    background: rgba(127, 29, 29, 0.2);
    color: #fecaca;
    font-size: 14px;
    font-weight: 850;
}

.network-badge img {
    width: 22px;
    height: 22px;
}

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

.wallet-column {
    min-height: 320px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 24px;
    padding: 24px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.055), transparent 58%),
        var(--btn-bg);
}

.temporary-column {
    border-color: rgba(250, 204, 21, 0.2);
}

.permanent-column {
    border-color: rgba(74, 222, 128, 0.2);
}

.wallet-column-header {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: start;
    gap: 16px;
}

.column-icon {
    width: 64px;
    height: 64px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border: 1px solid rgba(250, 204, 21, 0.24);
    border-radius: 8px;
    background: linear-gradient(145deg, rgba(250, 204, 21, 0.22), rgba(250, 204, 21, 0.08));
}

.stable-icon {
    border-color: rgba(74, 222, 128, 0.24);
    background: linear-gradient(145deg, rgba(74, 222, 128, 0.22), rgba(74, 222, 128, 0.08));
}

.column-icon img {
    width: 36px;
    height: 36px;
}

.wallet-column h2 {
    margin: 0 0 8px;
    color: var(--text-prim);
    font-size: 22px;
    line-height: 1.2;
}

.wallet-column p {
    margin: 0;
    color: var(--text-sec);
    font-size: 15px;
    font-weight: 650;
    line-height: 1.45;
}

.wallet-column-actions {
    display: grid;
    gap: 10px;
    margin-top: auto;
}

.wallet-list {
    display: grid;
    gap: 12px;
}

.empty-list {
    margin: 0;
    padding: 16px;
    border: 1px dashed var(--border);
    border-radius: 8px;
    color: var(--text-sec);
    font-size: 14px;
    font-weight: 650;
    text-align: center;
}

.created-wallet-card {
    display: grid;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.045);
    transition: border-color 0.18s ease, background-color 0.18s ease;
}

.created-wallet-card.expanded {
    border-color: rgba(47, 140, 255, 0.34);
    background: rgba(255, 255, 255, 0.065);
}

.created-wallet-summary {
    width: 100%;
    min-width: 0;
    min-height: 68px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    padding: 15px;
    border: none;
    background: transparent;
    color: inherit;
    cursor: pointer;
    text-align: left;
}

.created-wallet-summary:hover {
    background: rgba(255, 255, 255, 0.035);
}

.created-wallet-card strong,
.created-wallet-card small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.created-wallet-card strong {
    color: var(--text-prim);
    font-size: 15px;
}

.created-wallet-card small,
.created-wallet-card span {
    color: var(--text-sec);
    font-size: 13px;
    font-weight: 700;
}

.created-wallet-card .wallet-summary-balance {
    margin-top: 5px;
    color: var(--accent);
    font-size: 12px;
    font-weight: 850;
}

.wallet-summary-balance {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 6px;
}

.wallet-summary-balance .summary-trx-balance {
    color: #f87171;
}

.wallet-summary-balance .summary-eth-balance {
    color: #818cf8;
}

.wallet-summary-balance .summary-usdt-balance {
    color: #4ade80;
}

.wallet-summary-balance .summary-balance-separator {
    color: var(--text-sec);
}

.wallet-details {
    display: grid;
    gap: 14px;
    padding: 0 15px 15px;
}

.wallet-details-top {
    display: grid;
    grid-template-columns: 104px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
}

.wallet-qr {
    width: 104px;
    height: 104px;
    padding: 6px;
    border-radius: 8px;
    background: #fff;
}

.wallet-address-block {
    min-width: 0;
    display: grid;
    gap: 6px;
}

.wallet-address-block span {
    color: var(--text-sec);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.wallet-address-block strong {
    white-space: normal;
    overflow-wrap: anywhere;
    font-size: 14px;
    line-height: 1.35;
}

.copy-status {
    color: #4ade80;
    font-size: 13px;
    font-weight: 850;
}

.balance-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.balance-card {
    display: grid;
    gap: 6px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
}

.balance-card span {
    color: var(--text-sec);
    font-size: 12px;
    font-weight: 850;
}

.balance-card strong {
    font-size: 16px;
}

.trx-balance-card span,
.trx-balance-card strong {
    color: #f87171;
}

.eth-balance-card span,
.eth-balance-card strong {
    color: #818cf8;
}

.usdt-balance-card span,
.usdt-balance-card strong {
    color: #4ade80;
}

.balance-error {
    color: #fecaca;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

[data-theme="light"] .balance-error {
    color: #991b1b;
}

.wallet-detail-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.wallet-detail-actions button {
    min-height: 46px;
    padding: 0 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    font-size: 12px;
    font-weight: 850;
}

.wallet-detail-actions button img {
    width: 22px;
    height: 22px;
    object-fit: contain;
    flex: 0 0 auto;
}

.wallet-detail-actions button span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.wallet-detail-actions button:hover {
    background: var(--btn-hover);
    border-color: rgba(47, 140, 255, 0.32);
}

.wallet-detail-actions .danger-action {
    grid-column: 1 / -1;
    border-color: rgba(248, 113, 113, 0.34);
    background: rgba(127, 29, 29, 0.2);
    color: #fecaca;
}

[data-theme="light"] .wallet-detail-actions .danger-action {
    border-color: rgba(185, 28, 28, 0.28);
    background: rgba(254, 226, 226, 0.88);
    color: #991b1b;
}

.wallet-detail-actions .danger-action:hover {
    border-color: rgba(248, 113, 113, 0.48);
    background: rgba(127, 29, 29, 0.3);
}

[data-theme="light"] .wallet-detail-actions .danger-action:hover {
    border-color: rgba(185, 28, 28, 0.38);
    background: rgba(254, 202, 202, 0.96);
}

.wallet-action-btn {
    min-height: 50px;
    padding: 0 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    font-weight: 800;
    transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, filter 0.18s ease;
}

.wallet-action-btn:hover {
    transform: translateY(-1px);
    background: var(--btn-hover);
    border-color: rgba(47, 140, 255, 0.32);
}

.wallet-action-btn:focus-visible {
    outline: 3px solid var(--accent-soft);
    outline-offset: 2px;
}

.wallet-action-btn.primary-action {
    border: none;
    background: linear-gradient(180deg, var(--accent), var(--accent-hover));
    color: #fff;
    box-shadow: 0 14px 28px rgba(20, 110, 232, 0.22);
}

.wallet-action-btn.primary-action:hover {
    filter: brightness(1.03);
}

.modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(5, 9, 14, 0.62);
    backdrop-filter: blur(10px);
}

.modal-card {
    width: min(100%, 500px);
    max-height: calc(100svh - 40px);
    overflow: auto;
    display: grid;
    gap: 20px;
    padding: 28px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background:
        linear-gradient(180deg, var(--bg-card-soft), transparent 48%),
        var(--bg-card);
    box-shadow: var(--shadow);
}

.modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.modal-header h2 {
    margin: 0;
    color: var(--text-prim);
    font-size: 26px;
}

.import-fields {
    display: grid;
    gap: 16px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.035);
}

.modal-close {
    width: 40px;
    height: 40px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    font-size: 24px;
    line-height: 1;
}

.modal-close:hover {
    background: var(--btn-hover);
}

.modal-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.send-token-toggle {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.send-token-toggle label {
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    font-weight: 850;
}

.send-token-toggle input {
    width: auto;
    min-height: auto;
}

.amount-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
}

#send-max-btn {
    min-width: 82px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--btn-bg);
    color: var(--text-prim);
    cursor: pointer;
    font-weight: 850;
}

.transaction-link {
    display: grid;
    gap: 8px;
    padding: 14px;
    border: 1px solid rgba(74, 222, 128, 0.24);
    border-radius: 8px;
    background: rgba(22, 101, 52, 0.18);
}

.transaction-link span {
    color: var(--text-sec);
    font-size: 13px;
    font-weight: 800;
}

.transaction-link a {
    color: var(--accent);
    overflow-wrap: anywhere;
    font-size: 14px;
    font-weight: 800;
}

.seed-phrase-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.seed-word-cell {
    min-width: 0;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 8px;
    min-height: 42px;
    padding: 9px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.045);
}

.seed-word-cell span {
    width: 22px;
    color: var(--text-sec);
    font-size: 12px;
    font-weight: 850;
    text-align: right;
}

.seed-word-cell strong {
    min-width: 0;
    color: var(--text-prim);
    font-size: 14px;
    font-weight: 800;
    overflow-wrap: anywhere;
}

#cancel-wallet-modal-btn,
#save-wallet-btn,
#cancel-secret-modal-btn,
#copy-secret-btn,
#reveal-secret-btn,
#cancel-send-modal-btn,
#send-submit-btn,
#cancel-user-modal-btn,
#save-user-btn {
    min-height: 50px;
    padding: 0 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    cursor: pointer;
    font-weight: 800;
}

#cancel-wallet-modal-btn,
#cancel-secret-modal-btn,
#copy-secret-btn,
#cancel-send-modal-btn,
#cancel-user-modal-btn {
    background: var(--btn-bg);
    color: var(--text-prim);
}

#save-wallet-btn,
#reveal-secret-btn,
#send-submit-btn,
#save-user-btn {
    border: none;
    background: linear-gradient(180deg, var(--accent), var(--accent-hover));
    color: #fff;
}

#save-user-btn:disabled {
    cursor: not-allowed;
    opacity: 0.55;
    filter: none;
}

/* --- 4th action card: full-width horizontal --- */
.action-card-wide {
    grid-column: 1 / -1;
    min-height: auto;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
}

.log-icon {
    border-color: rgba(167, 139, 250, 0.3);
    background: linear-gradient(145deg, rgba(139, 92, 246, 0.28), rgba(139, 92, 246, 0.1));
}

/* --- Audit log screen --- */
.audit-log-list {
    display: grid;
    gap: 6px;
    max-height: 460px;
    overflow-y: auto;
    padding-right: 2px;
}

.audit-log-entry {
    display: grid;
    grid-template-columns: 8px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    padding: 11px 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.03);
}

.audit-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    flex-shrink: 0;
}

.audit-dot-success {
    background: #4ade80;
    box-shadow: 0 0 0 4px rgba(74, 222, 128, 0.12);
}

.audit-dot-fail {
    background: #f87171;
    box-shadow: 0 0 0 4px rgba(248, 113, 113, 0.12);
}

.audit-entry-body {
    min-width: 0;
    display: grid;
    gap: 4px;
}

.audit-entry-main {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.audit-action-badge {
    padding: 2px 7px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 850;
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
}

.badge-connect    { background: rgba(47, 140, 255, 0.18); color: #93c5fd; }
.badge-disconnect { background: rgba(255, 255, 255, 0.08); color: var(--text-sec); }
.badge-create     { background: rgba(74, 222, 128, 0.15); color: #86efac; }
.badge-import     { background: rgba(74, 222, 128, 0.15); color: #86efac; }
.badge-delete     { background: rgba(248, 113, 113, 0.15); color: #fca5a5; }
.badge-send       { background: rgba(251, 191, 36, 0.15); color: #fcd34d; }
.badge-reveal     { background: rgba(167, 139, 250, 0.18); color: #c4b5fd; }
.badge-db         { background: rgba(47, 140, 255, 0.18); color: #93c5fd; }
.badge-wipe       { background: rgba(248, 113, 113, 0.15); color: #fca5a5; }

.audit-entry-detail {
    color: var(--text-sec);
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.audit-entry-meta {
    display: grid;
    gap: 3px;
    text-align: right;
    flex-shrink: 0;
}

.audit-entry-time {
    color: var(--text-sec);
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.audit-entry-ip {
    color: var(--text-sec);
    font-size: 11px;
    font-weight: 700;
    opacity: 0.7;
    white-space: nowrap;
}

#refresh-audit-btn {
    border: none;
    background: linear-gradient(180deg, var(--accent), var(--accent-hover));
    color: #fff;
    box-shadow: 0 14px 28px rgba(20, 110, 232, 0.24);
}

#refresh-audit-btn:hover {
    filter: brightness(1.03);
}

@media (max-width: 980px) {
    .user-controls select,
    .user-active-toggle,
    .user-controls button {
        flex-basis: calc(50% - 4px);
    }
}

@media (max-width: 760px) {
    body {
        align-items: flex-start;
        justify-content: stretch;
    }

    .app-container {
        width: 100%;
        padding: calc(86px + env(safe-area-inset-top)) 18px calc(24px + env(safe-area-inset-bottom));
    }

    .navbar {
        top: 16px;
        right: calc(16px + env(safe-area-inset-right));
    }

    .connect-card {
        max-width: none;
        padding: 28px 22px;
    }

    .wallet-logo {
        width: min(100%, 230px);
        margin-bottom: 10px;
    }

    .wallet-screen {
        width: 100%;
        padding: 22px;
    }

    .wallet-header {
        align-items: flex-start;
        flex-direction: column;
        gap: 14px;
    }

    .wallet-logo-small {
        width: 180px;
        margin-bottom: 0;
    }

    .wallet-panel {
        padding: 20px;
    }

    .wallet-panel h1 {
        font-size: 25px;
    }

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

    .action-card {
        min-height: 116px;
        grid-template-columns: auto 1fr;
        grid-template-rows: auto;
        align-items: center;
        gap: 16px;
        padding: 18px;
    }

    .table-status-grid,
    .wallet-columns,
    .management-actions {
        grid-template-columns: 1fr;
    }

    .panel-heading-row,
    .user-row {
        grid-template-columns: 1fr;
    }

    .panel-heading-row {
        align-items: stretch;
    }

    .user-controls {
        display: grid;
        grid-template-columns: 1fr;
    }

    .wallet-column {
        min-height: 260px;
        padding: 20px;
        gap: 20px;
    }

    .screen-title {
        font-size: 26px;
    }

    .connection-pill,
    .network-badge {
        max-width: 100%;
        white-space: normal;
    }

    .wallet-column-actions,
    .wallet-detail-actions,
    .modal-actions {
        grid-template-columns: 1fr;
    }

    .wallet-details-top {
        grid-template-columns: 92px minmax(0, 1fr);
        gap: 12px;
    }

    .wallet-qr {
        width: 92px;
        height: 92px;
    }

    .modal-backdrop {
        align-items: flex-end;
        padding: 12px;
        padding-bottom: max(12px, env(safe-area-inset-bottom));
    }

    .modal-card {
        width: 100%;
        max-height: calc(100svh - 24px);
        padding: 22px;
    }

    .modal-header h2 {
        font-size: 23px;
    }
}

@media (max-width: 520px) {
    .seed-phrase-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 420px) {
    body {
        font-size: 15px;
    }

    .app-container {
        padding-left: 12px;
        padding-right: 12px;
    }

    .navbar {
        top: 12px;
        right: 12px;
    }

    .icon-btn,
    .lang-btn {
        width: 38px;
        height: 38px;
    }

    .connect-card,
    .wallet-screen {
        padding: 18px;
    }

    .wallet-logo {
        width: min(100%, 210px);
    }

    .wallet-logo-small {
        width: 165px;
    }

    .screen-title,
    .wallet-panel h1 {
        font-size: 23px;
    }

    .wallet-panel,
    .contracts-panel,
    .table-status-card,
    .wallet-column {
        padding: 16px;
    }

    .action-card {
        min-height: auto;
        padding: 16px;
    }

    .action-icon,
    .column-icon {
        width: 52px;
        height: 52px;
    }

    .action-icon img,
    .column-icon img {
        width: 30px;
        height: 30px;
    }

    .action-card strong,
    .table-status-card strong {
        font-size: 16px;
    }

    .wallet-column-header,
    .created-wallet-summary,
    .wallet-details-top {
        grid-template-columns: 1fr;
    }

    .created-wallet-summary {
        gap: 8px;
    }

    .created-wallet-summary > span {
        justify-self: start;
    }

    .wallet-qr {
        width: 120px;
        height: 120px;
    }

    .balance-grid,
    .amount-row,
    .password-row {
        grid-template-columns: 1fr;
    }

    #toggle-password,
    #send-max-btn {
        width: 100%;
        min-height: 46px;
    }

    .modal-card {
        padding: 18px;
    }

    .send-token-toggle {
        gap: 8px;
    }
}
