/* ═══════════════════════════════════════════════════
   ChatGPT Trading — Dark Theme CSS (Mobile-First)
   Palette: #212121 bg · #10a37f green · #2d2d2d cards
═══════════════════════════════════════════════════ */

/* ─── DESIGN TOKENS ─── */
:root {
    --bg: #212121;
    --bg-2: #2a2a2a;
    --surface: #ffffff;
    --surface-2: #383838;
    --surface-3: #404040;

    --border: #dbdbdb;
    --border-2: #505050;

    --ink: #ececec;
    --ink-2: #d4d4d4;
    --ink-3: #b4b4b4;
    --ink-4: #8e8ea0;
    --ink-5: #6b6b7b;
    --ink-6: #4a4a5a;

    --text-main-color: #424242;

    --green: #10a37f;
    --green-dark: #0d8c6d;
    --green-deeper: #0a7a5e;
    --green-light: rgba(16, 163, 127, 0.12);
    --green-mid: rgba(16, 163, 127, 0.3);
    --green-glow: rgba(16, 163, 127, 0.18);
    --red-light: #f2463429;

    --profit: #19c37d;
    --profit-bg: rgba(25, 195, 125, 0.1);

    --red: #ef4146;
    --red-bg: rgba(239, 65, 70, 0.1);

    --amber: #f59e0b;
    --amber-bg: rgba(245, 158, 11, 0.1);

    --white: #ffffff;

    --sh-0: 0 1px 3px rgba(0, 0, 0, 0.4);
    --sh-1: 0 2px 8px rgba(0, 0, 0, 0.45), 0 1px 2px rgba(0, 0, 0, 0.3);
    --sh-2: 0 4px 16px rgba(0, 0, 0, 0.5), 0 2px 6px rgba(0, 0, 0, 0.35);
    --sh-3: 0 8px 28px rgba(0, 0, 0, 0.55), 0 4px 10px rgba(0, 0, 0, 0.4);
    --sh-modal: 0 24px 64px rgba(0, 0, 0, 0.7), 0 8px 24px rgba(0, 0, 0, 0.5);

    --r-xs: 6px;
    --r-s: 10px;
    --r-m: 12px;
    --r-l: 16px;
    --r-xl: 20px;

    --max-w: 480px;
    --px: 14px;
    --hdr: 52px;

    --ease: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-spr: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ─── RESET ─── */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
html {
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
    height: 100%;
}
body {
    font-family:
        "Inter",
        -apple-system,
        BlinkMacSystemFont,
        "Segoe UI",
        sans-serif;
    font-size: 15px;
    line-height: 1.6;
    color: var(--ink);
    
    -webkit-font-smoothing: antialiased;
    min-height: 100%;
    overflow-x: hidden;
}
button,
input,
select,
textarea {
    font-family: inherit;
}
button {
    cursor: pointer;
    border: none;
    background: none;
    -webkit-appearance: none;
}
input {
    -webkit-appearance: none;
    appearance: none;
}
input:focus {
    outline: none;
}
ul,
ol {
    list-style: none;
}
img {
    display: block;
    max-width: 100%;
}
a {
    color: inherit;
    text-decoration: none;
}

/* ─── UTILITY ─── */
.d-none {
    display: none !important;
}
.text-green {
    color: var(--profit) !important;
}
.text-red {
    color: var(--red) !important;
}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar {
    width: 3px;
}
::-webkit-scrollbar-track {
    background: transparent;
}
::-webkit-scrollbar-thumb {
    background: var(--border-2);
    border-radius: 2px;
}

/* ═══════════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════════ */
.app-container {
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    background: #ffffff;
}

/* ═══════════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════════ */
.header-block {
    position: sticky;
    top: 0;
    z-index: 200;
    height: var(--hdr);
    background: #ffffff;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border-bottom: 1px solid var(--border);
    padding: 0 var(--px);
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.iti__country-name {
    color: #222;
}
.brand {
    display: flex;
    align-items: center;
    gap: 10px;
}
.video-logo {
    display: flex;
    align-items: center;
}
.video-logo img {
    height: 24px;
    width: auto;
    filter: brightness(1.1);
}

.online-counter {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--red-light);
    border: 1px solid #f246344d;
    border-radius: 20px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 600;
    color: #f24634;
}
.pulse {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #f24634;
    flex-shrink: 0;
    animation: pulseDot 2s ease-in-out infinite;
}
.online-text {
    color: #424242;
    font-weight: 400;
    font-size: 11px;
}

/* ═══════════════════════════════════════════════════
   MAIN (ИЗМЕНЕНО: добавлено вертикальное центрирование)
═══════════════════════════════════════════════════ */
.main-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center; /* Центрируем окна по вертикали */
    padding: 18px var(--px) 28px;
    max-width: var(--max-w);
    margin: 0 auto;
    width: 100%;
}

/* ═══════════════════════════════════════════════════
   CARD
═══════════════════════════════════════════════════ */
.card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    padding: 20px 16px;
    box-shadow: var(--sh-1);
    animation: cardIn 0.35s var(--ease) both;
}

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

/* ═══════════════════════════════════════════════════
   STEP 1 — Hook / Balance
═══════════════════════════════════════════════════ */
.hook-container {
    background: linear-gradient(111.47deg, rgba(242, 70, 52, 0.26) 0%, rgba(242, 70, 52, 0.04) 100%);

    border: 1px solid #f246344d;
    border-radius: var(--r-l);
    padding: 18px 16px;
    margin-bottom: 20px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.hook-container::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent 0%, rgba(16, 163, 127, 0.07) 50%, transparent 100%);
    transform: translateX(-100%);
    animation: shimmer 3.5s ease-in-out infinite 1s;
    pointer-events: none;
}

.hook-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: #f24634;

    border-radius: 20px;
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 600;
    color: var(--white);
    margin-bottom: 10px;
}

.balance-label {
    font-size: 11px;
    color: var(--text-main-color);
    font-weight: 500;
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: 0.6px;
}
.balance-amount {
    font-size: 34px;
    font-weight: 800;
    color: #1f1f1f;
    letter-spacing: -1.2px;
    line-height: 1;
}

/* ═══════════════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════════════ */
.title {
    font-size: 21px;
    font-weight: 700;
    color: #1f1f1f;
    letter-spacing: -0.5px;
    margin-bottom: 6px;
    line-height: 1.25;
}
.subtitle {
    font-size: 13.5px;
    color: var(--text-main-color);
    line-height: 1.6;
    margin-bottom: 18px;
}
.section-title {
    font-size: 15px;
    font-weight: 700;
    color: #1f1f1f;
    letter-spacing: -0.2px;
    margin-bottom: 12px;
}

/* ═══════════════════════════════════════════════════
   FORM FIELDS
═══════════════════════════════════════════════════ */
.form-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 12px;
}

.form-group input,
.form-group .form-input,
#regform1 .form-input,
#regform1 input[type="text"],
#regform1 input[type="email"],
#regform1 input[type="tel"] {
    width: 100% !important;
    background: var(--white) !important;
    border: 1.5px solid var(--border) !important;
    border-radius: var(--r-m) !important;
    padding: 13px 14px !important;
    font-family: "Inter", sans-serif !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: var(--text-main-color) !important;
    min-height: 50px !important;
    transition:
        border-color 0.2s var(--ease),
        box-shadow 0.2s var(--ease) !important;
    -webkit-appearance: none !important;
}
.form-group input::placeholder,
#regform1 input::placeholder {
    color: var(--ink-5) !important;
    font-weight: 400 !important;
}
.form-group input:hover:not(:focus),
#regform1 input:hover:not(:focus) {
    border-color: var(--border-2) !important;
}
.form-group input:focus,
#regform1 input:focus {
    box-shadow: 0 0 0 3px var(--green-glow) !important;
    background: var(--surface) !important;
}
.form-group input.error,
#regform1 input.error {
    border-color: var(--red) !important;
}

#regform1 .messages,
.messages {
    display: block;
    font-size: 11px;
    font-weight: 600;
    color: var(--red);
    line-height: 1.4;
    padding-top: 2px;
    padding-left: 2px;
}
#regform1 .messages:empty {
    display: none;
}

/* ═══════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════ */
.btn-submit {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    background: #f24634;
    color: #fff;
    border: none;
    border-radius: var(--r-m);
    padding: 14px 18px;
    font-family: "Inter", sans-serif;
    font-size: 15px;
    font-weight: 700;
    min-height: 52px;
    cursor: pointer;
    transition:
        background 0.2s var(--ease),
        transform 0.15s var(--ease),
        box-shadow 0.2s var(--ease);
    box-shadow: 0px 4px 18px 0px #f2463466;

    letter-spacing: -0.1px;
    -webkit-tap-highlight-color: transparent;
}
.btn-submit:hover:not(:disabled) {
    background: #50312e;
    transform: translateY(-1px);
}
.btn-submit:active:not(:disabled) {
    transform: scale(0.985);
    box-shadow: 0 2px 10px rgba(16, 163, 127, 0.25);
}
.btn-submit:disabled {
    background: var(--surface-3);
    cursor: not-allowed;
    box-shadow: none;
    color: var(--ink-5);
}

.ai-btn {
    background: #f24634;
    position: relative;
    overflow: hidden;
    
}
.ai-btn::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    transform: translateX(-100%);
    animation: shimmer 4s ease-in-out infinite 1.2s;
    pointer-events: none;
}
.sparkle {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    fill: rgba(255, 255, 255, 0.9);
}
.sparkle .path {
    fill: rgba(255, 255, 255, 0.95);
}

.btn-loader {
    display: inline-block;
    width: 15px;
    height: 15px;
    border: 2.5px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin 0.75s linear infinite;
}

/* ═══════════════════════════════════════════════════
   SECURITY BLOCK
═══════════════════════════════════════════════════ */
.security-block {
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
    text-align: center;
}
.security-text {
    font-size: 11px;
    color: var(--ink-5);
    margin-bottom: 8px;
}
.payment-logos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 28px;
    flex-wrap: wrap;
}
.payment-logos img {
    height: 24px !important;
    width: auto;
    opacity: 0.85;
}

/* ═══════════════════════════════════════════════════
   LOADER STEP
═══════════════════════════════════════════════════ */
.loader-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 28px 0 16px;
    text-align: center;
    gap: 10px;
}
.loader-revolut-logo {
    margin-bottom: 6px;
    opacity: 0.8;
}
.loader-revolut-logo img {
    filter: brightness(1.2);
}
.loader-title {
    font-size: 17px;
    font-weight: 700;
    color: #1f1f1f;
    letter-spacing: -0.4px;
}
.loader-subtitle {
    font-size: 13px;
    color: var(--text-main-color);
    font-weight: 500;
}
.progress-track {
    width: 100%;
    max-width: 280px;
    height: 5px;
    background: #efefef;
    border-radius: 3px;
    overflow: hidden;
    margin-top: 6px;
}
.progress-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--green-deeper) 0%, var(--green) 60%, #5ccfad 100%);
    border-radius: 3px;
    transition: width 0.15s ease;
}

/* ═══════════════════════════════════════════════════
   STEP 2 — Greeting & Strategy
═══════════════════════════════════════════════════ */
.greeting-block {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    padding: 14px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--r-l);
}
.avatar-placeholder {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: #f24634;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
}
.greeting-text {
    font-size: 14px;
    font-weight: 600;
    color: #1f1f1f;
}
.greeting-status {
    font-size: 11px;
    color: var(--green);
    font-weight: 600;
    margin-top: 2px;
    display: flex;
    align-items: center;
    gap: 5px;
}
.greeting-status::before {
    content: "";
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--green);
    flex-shrink: 0;
}

.mini-balance-card {
    background: var(--white);
    border: 1px solid #f246344d;
    border-radius: var(--r-l);
    padding: 12px 14px;
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.mini-balance-label {
    font-size: 12px;
    color: #f24634;
    font-weight: 600;
}
.mini-balance-amount {
    font-size: 19px;
    font-weight: 800;
    color: #f24634;
    letter-spacing: -0.6px;
}

/* Strategy cards */
.strategy-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 18px;
}

.strategy-card {
    display: block;
    position: relative;
    border: 1.5px solid var(--border);
    border-radius: var(--r-l);
    padding: 12px 14px;
    cursor: pointer;
    background: var(--white);
    transition:
        border-color 0.2s var(--ease),
        background 0.2s var(--ease),
        box-shadow 0.2s var(--ease);
    -webkit-tap-highlight-color: transparent;
}
.strategy-card:hover {
    border-color: #f24634;
    background: linear-gradient(111.47deg, rgba(242, 70, 52, 0.26) 0%, rgba(242, 70, 52, 0.04) 100%);
}
.strategy-card input[type="radio"] {
    display: none;
}
.strategy-card:has(input:checked) {
    border-color: #f24634;
    background: linear-gradient(111.47deg, rgba(242, 70, 52, 0.26) 0%, rgba(242, 70, 52, 0.04) 100%);
}

.strategy-card.recommended {
    border-color: #dea7a1;
}
.recommended-badge {
    display: inline-block;
    background: #f24634;
    color: #fff;
    font-size: 9.5px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    border-radius: 6px;
    padding: 2px 8px;
    margin-bottom: 8px;
}

.strategy-content {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.strategy-icon-box {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    border: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
}
.strategy-icon {
    width: 22px;
    height: 22px;
    object-fit: contain;
}
.strategy-name {
    font-size: 13.5px;
    font-weight: 700;
    color: #1f1f1f;
}
.strategy-desc {
    font-size: 12px;
    color: var(--text-main-color);
    line-height: 1.5;
    margin-top: 2px;
}

/* ═══════════════════════════════════════════════════
   STEP 3 — Dashboard
═══════════════════════════════════════════════════ */
.dashboard-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
    gap: 8px;
}

.status-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #EFEFEF;

    border: 1px solid #f246344d;
    border-radius: 20px;
    padding: 5px 12px;
    font-size: 11.5px;
    font-weight: 600;
    color: #f24634;
}
.status-pill--done {
    background: #EFEFEF;
    border: 1px solid #dbdbdb;
    color: #4E4A4A;
}
.status-pill--open {
    background: var(--green-light);
    border-color: var(--green-mid);
    color: var(--green);
}
.status-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #f24634;
    flex-shrink: 0;
    animation: pulseDot 2s ease-in-out infinite;
}

.strategy-badge {
    display: inline-flex;
    align-items: center;
    background: #efefef;
    border: 1px solid #dbdbdb;
    border-radius: 20px;
    padding: 5px 11px;
    font-size: 11px;
    font-weight: 600;
    color: #4e4a4a;
}

/* Live balance */
.live-balance-wrapper {
    background: #fff);
    border: 1px solid var(--border);
    border-radius: var(--r-l);
    padding: 16px;
    margin-bottom: 14px;
}
.summary-hero {
    text-align: center;
}
.live-balance-label {
    font-size: 11px;
    color: var(--ink-5);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin-bottom: 6px;
}
.live-balance-row {
    display: flex;
    align-items: center;
    gap: 12px;
}
.live-balance-amount {
    font-size: 28px;
    font-weight: 800;
    color: #1F1F1F;
    letter-spacing: -1px;
}
.live-profit {
    font-size: 13px;
    font-weight: 700;
    color: var(--profit);
    background: var(--profit-bg);
    border: 1px solid rgba(25, 195, 125, 0.2);
    border-radius: 8px;
    padding: 3px 8px;
}
.live-profit--loss {
    color: var(--red);
    background: var(--red-bg);
    border-color: rgba(239, 65, 70, 0.2);
}
.flash-green {
    animation: flashGreen 0.4s ease;
}
.flash-red {
    animation: flashRed 0.4s ease;
}

/* Chart */
.custom-chart-wrapper {
    height: 120px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-l);
    overflow: hidden;
    margin-bottom: 14px;
    position: relative;
}
#smoothChart {
    width: 100%;
    height: 100%;
    display: block;
}

/* Stats row */
.stats-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 6px;
    margin-bottom: 14px;
}
.stat-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-m);
    padding: 10px 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.stat-icon {
    width: 26px;
    height: 26px;
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.stat-icon--up {
    background: var(--green-light);
    color: var(--green);
}
.stat-icon--neutral {
   
    color: var(--ink-4);
}
.stat-icon--green {
    background: var(--green-light);
    color: var(--green);
}
.stat-icon svg {
    display: block;
    flex-shrink: 0;
}
.stat-icon--up svg {
    stroke: var(--green);
}
.stat-icon--neutral svg {
    stroke: var(--ink-4);
}
.stat-icon--green svg {
    stroke: var(--green);
}

.stat-value {
    font-size: 14px;
    font-weight: 800;
    color: #1F1F1F;
    letter-spacing: -0.3px;
}
.stat-label {
    font-size: 10px;
    color: var(--ink-5);
    font-weight: 500;
    margin-top: 1px;
}

/* Feed (ИЗМЕНЕНО: Фиксированная высота и скрытие переполнения для плавности) */
.feed-section {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-l);
    overflow: hidden;
}
.feed-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    border-bottom: 1px solid var(--border);
    font-size: 12px;
    font-weight: 600;
    color: var(--text-main-color);
}
.live-indicator {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 10px;
    font-weight: 700;
    color: var(--green);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.live-pulse {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--green);
    animation: pulseDot 1.5s ease-in-out infinite;
}

/* Фиксация высоты ровно под 3 элемента (1 элемент ~47-48px) */
.feed-list {
    padding: 0;
    height: 144px;
    overflow: hidden;
    position: relative;
}

.feed-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 14px;
    border-bottom: 1px solid var(--border);
    transition:
        opacity 0.3s ease,
        transform 0.3s ease;
    animation: feedIn 0.3s var(--ease) both;
}
.feed-item:last-child {
    border-bottom: none;
}

/* Уходящий элемент просто скрывается вниз под overflow: hidden */
.feed-item.removing {
    opacity: 0;
    transform: translateY(10px);
}

/* ИЗМЕНЕНО: Анимация margin-top мягко раздвигает контейнер сверху вниз без скачков */
@keyframes feedIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
        margin-top: -48px;
    }
    to {
        opacity: 1;
        transform: translateY(0);
        margin-top: 0;
    }
}

.feed-left {
    display: flex;
    align-items: center;
    gap: 8px;
}
.feed-icon {
    width: 30px;
    height: 30px;
    border-radius: 7px;
  
    border: 1px solid var(--border);
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.feed-icon img {
    width: 22px;
    height: 22px;
    object-fit: contain;
}
.feed-pair {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--ink-2);
}
.feed-time {
    font-size: 10px;
    color: var(--ink-5);
    display: block;
}
.feed-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.feed-result {
    font-size: 12.5px;
    font-weight: 700;
    color: var(--profit);
}
.feed-result--loss {
    color: var(--red);
}
.feed-type-badge {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: var(--green);
    background: var(--green-light);
    border: 1px solid var(--green-mid);
    border-radius: 5px;
    padding: 1px 5px;
}
.feed-type-badge--loss {
    color: var(--red);
    background: var(--red-bg);
    border-color: rgba(239, 65, 70, 0.2);
}

.feed-avatar {
    flex-shrink: 0;
}

/* ИЗМЕНЕНО: Синхронизация высоты для фида на последнем шаге */
#registrationFeed {
    height: 144px;
    min-height: unset;
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════
   STEP 4 — Statistics
═══════════════════════════════════════════════════ */
.stats-grid-2x2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-bottom: 18px;
}
.stat-box {
    background: #FFFFFF;
    border: 1px solid #DBDBDB;
    border-radius: var(--r-m);
    padding: 12px;
}
.stat-box-label {
    font-size: 11px;
    color: var(--ink-5);
    font-weight: 500;
    margin-bottom: 5px;
}
.stat-box-value {
    font-size: 18px;
    font-weight: 800;
    color:#000000;
    letter-spacing: -0.5px;
}

/* Asset analysis */
.asset-analysis-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 20px;
}
.asset-row {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-m);
    padding: 10px 12px;
}
.asset-row-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: #EFEFEF;
    border: 1px solid #DBDBDB;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.asset-row-icon img {
    width: 22px;
    height: 22px;
    object-fit: contain;
}
.asset-row-info {
    flex: 1;
}
.asset-row-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 5px;
}
.asset-row-name {
    font-size: 12.5px;
    font-weight: 600;
    color: #1F1F1F;
}
.asset-row-amount {
    font-size: 12.5px;
    font-weight: 700;
}
.asset-row-amount.profit {
    color: var(--profit);
}
.asset-row-amount.loss {
    color: var(--red);
}
.asset-bar-bg {
    height: 4px;
    background: var(--surface-3);
    border-radius: 2px;
    overflow: hidden;
}
.asset-bar-fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.6s var(--ease);
}
.asset-bar-fill.profit {
    background: linear-gradient(90deg, var(--green-deeper), var(--green));
}
.asset-bar-fill.loss {
    background: linear-gradient(90deg, #b91c1c, var(--red));
}

/* Sticky action */
.sticky-action {
    position: sticky;
    bottom: 0;
    padding: 14px 0 0;
    background: linear-gradient(to top, var(--surface) 70%, transparent);
    margin: 0 -4px;
    padding-left: 4px;
    padding-right: 4px;
}

/* ═══════════════════════════════════════════════════
   INTL-TEL-INPUT OVERRIDES (dark)
═══════════════════════════════════════════════════ */
#regform1 .iti {
    display: block !important;
    width: 100% !important;
}
#regform1 .iti--allow-dropdown input,
#regform1 .iti--separate-dial-code input {
    padding-left: 90px !important;
}
#regform1 .iti__flag-container {
    padding: 0 !important;
}
#regform1 .iti__selected-flag {
    border-radius: var(--r-m) 0 0 var(--r-m) !important;
    /* background: var(--surface-2) !important; */
    border-right: 1px solid var(--border) !important;
}
#regform1 .iti__selected-flag:hover {
    background: var(--surface-3) !important;
}
#regform1 .iti__country-list {
    z-index: 1000 !important;
    font-family: "Inter", sans-serif !important;
    font-size: 13px !important;
    border-radius: var(--r-m) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--sh-3) !important;
    background: var(--surface) !important;
    color: var(--ink) !important;
    max-height: 200px !important;
}
#regform1 .iti__country-list .iti__country:hover,
#regform1 .iti__country-list .iti__country.iti__active {
    background: var(--surface-2) !important;
}
#regform1 .iti--separate-dial-code .iti__selected-dial-code {
    color: #1F1F1F !important;
    font-weight: 600 !important;
    font-size: 13px !important;
}
#regform1 .iti__divider {
    border-bottom-color: var(--border) !important;
}
#regform1 .iti__search-input {
    background: var(--bg-2) !important;
    color: var(--ink) !important;
    border-color: var(--border) !important;
}

#regform1 {
    display: flex;
    flex-direction: column;
    gap: 0;
    width: 100%;
}
#regform1 .form-group,
#regform1 .mb-2 {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 10px !important;
}
#regform1 button[type="submit"] {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    margin-top: 8px !important;
    
    color: #fff !important;
    border: none !important;
    border-radius: var(--r-m) !important;
    padding: 14px 18px !important;
    font-family: "Inter", sans-serif !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    min-height: 52px !important;
    cursor: pointer !important;
    transition: all 0.22s var(--ease) !important;
   
}
#regform1 button[type="submit"]:hover:not(:disabled) {
   
    transform: translateY(-1px) !important;

}
#regform1 button[type="submit"]:active:not(:disabled) {
    transform: scale(0.985) !important;
}
#regform1 button[type="submit"]:disabled {
   
    cursor: not-allowed !important;
    box-shadow: none !important;
    color: var(--ink-5) !important;
}

/* ═══════════════════════════════════════════════════
   MODALS
═══════════════════════════════════════════════════ */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.78);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    z-index: 900;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 0;
    animation: overlayIn 0.3s var(--ease) both;
}
.modal-overlay.overlay-fade-out {
    animation: overlayOut 0.35s var(--ease) both;
}

.modal-card {
    background: var(--surface);
    border: 1px solid var(--border-2);
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    padding: 24px 18px 28px;
    width: 100%;
    max-width: 480px;
    box-shadow: var(--sh-modal);
    animation: modalSlideUp 0.4s var(--ease-spr) both;
    max-height: 92dvh;
    overflow-y: auto;
}
.modal-card.modal-fade-out {
    animation: modalSlideDown 0.3s var(--ease) both;
}

.modal-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
    opacity: 0.85;
}
.modal-icon img {
    filter: brightness(1.2);
}
.modal-title {
    font-size: 18px;
    font-weight: 700;
    color: #1f1f1f;
    text-align: center;
    letter-spacing: -0.4px;
    margin-bottom: 6px;
}
.modal-desc {
    font-size: 13px;
    color: var(--ink-4);
    text-align: center;
    line-height: 1.6;
    margin-bottom: 18px;
}

.modal-stats {
    background: var(--white);
    border: 1px solid #dbdbdb;
    border-radius: var(--r-m);
    padding: 14px;
    margin-bottom: 18px;
}
.modal-stat-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 13px;
    padding: 4px 0;
}
.modal-stat-row span {
    color: var(--text-main-color);
    font-weight: 400;
}
.modal-stat-row strong {
    color: #1f1f1f;
    font-weight: 700;
}
.modal-stat-divider {
    height: 1px;
    background: var(--border);
    margin: 8px 0;
}
.modal-stat-total {
    margin-top: 4px;
}
.modal-stat-total span {
    font-weight: 600;
    color: #1f1f1f;
}
.modal-profit-text {
    font-size: 17px;
    color: var(--profit);
}
#modalProfit {
    color: #f24634;
}

/* ═══════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════ */
.bottom-nav {
    border-top: 1px solid var(--border);
    padding: 12px var(--px);
    text-align: center;
}
.links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 4px;
}
.links a {
    font-size: 11px;
    color: var(--ink-5);
    transition: color 0.2s;
}
.links a:hover {
    color: var(--green);
}
.dot-sep {
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--ink-6);
}
.copy {
    font-size: 10px;
    color: var(--ink-6);
}

/* ═══════════════════════════════════════════════════
   INLINE EXTRAS
═══════════════════════════════════════════════════ */

/* Confetti canvas */
#confettiCanvas {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 9999;
    display: none;
}

/* Session timer */
.session-timer-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #3B83F61A;
    border: 1px solid #3B83F64D;
    border-radius: var(--r-m);
    padding: 10px 14px;
    margin-bottom: 16px;
    gap: 8px;
}
.session-timer-label {
    font-size: 12px;
    font-weight: 600;
    color: #1F1F1F;
    flex: 1;
}
.session-timer-value {
    font-size: 18px;
    font-weight: 800;
    color: #3B83F6;
    letter-spacing: -0.5px;
    font-variant-numeric: tabular-nums;
    min-width: 54px;
    text-align: right;
}

/* Collapsible asset list */
.toggle-assets-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    background: #EFEFEF;
    border: 1px solid #DBDBDB;
    border-radius: var(--r-m);
    padding: 10px 14px;
    font-size: 12px;
    font-weight: 600;
    color: #4E4A4A;
    cursor: pointer;
    margin-bottom: 14px;
    transition: background 0.2s;
    -webkit-tap-highlight-color: transparent;
}

.toggle-assets-btn svg {
    transition: transform 0.3s;
}
.toggle-assets-btn.open svg {
    transform: rotate(180deg);
}
#assetAnalysisWrap {
    display: none;
}
#assetAnalysisWrap.visible {
    display: block;
}

/* AI status ticker */
.ai-status-ticker {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #3b83f61a;

    border: 1px solid #3b83f64d;
    border-radius: var(--r-s);
    padding: 9px 12px;
    margin-bottom: 12px;
    font-size: 11.5px;
    font-weight: 600;
    color: #1f1f1f;
    animation: tickerPulse 3s ease-in-out infinite;
}
.ai-status-ticker .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #10a37f;
    flex-shrink: 0;
    animation: pulseDot 1.5s ease-in-out infinite;
}
@keyframes tickerPulse {
    0%,
    100% {
        opacity: 1;
    }
    50% {
        opacity: 0.78;
    }
}

/* Strategy profit badge */
.strategy-profit {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: linear-gradient(111.47deg, rgba(242, 70, 52, 0.26) 0%, rgba(242, 70, 52, 0.04) 100%);
    border: 1px solid var(--Color11, #f246344d);
    border-radius: 6px;
    padding: 2px 7px;
    font-size: 11px;
    font-weight: 700;
    color: #f24634;
    margin-top: 4px;
}

/* AI analysis progress modal */
.ai-progress-wrap {
    padding: 6px 0 4px;
}
.ai-progress-step {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 6px 0;
    font-size: 12.5px;
    font-weight: 500;
    color: var(--ink-4);
    transition: color 0.3s;
}
.ai-progress-step.done {
    color: #1f1f1f;
}
.ai-progress-step .step-icon {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;

    border: 1px solid var(--border);
    flex-shrink: 0;
    font-size: 9px;
    transition:
        background 0.3s,
        border-color 0.3s;
}
.ai-progress-step.done .step-icon {
    background: #f24634;
    border-color: #f2463429;

    color: var(--white);
}
.ai-analysis-bar-wrap {
    margin-top: 12px;
}
.ai-analysis-bar-label {
    font-size: 11px;
    color: var(--ink-4);
    margin-bottom: 5px;
    font-weight: 500;
}
.ai-analysis-bar-track {
    height: 5px;
    background: var(--white);
    border-radius: 3px;
    overflow: hidden;
}
.ai-analysis-bar-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, #0a7a5e, #10a37f, #5ccfad);
    border-radius: 3px;
    transition: width 0.12s ease;
}
.ai-analysis-pct {
    font-size: 12px;
    font-weight: 700;
    color: #10a37f;
    text-align: right;
    margin-top: 3px;
}

/* Profit glow */
.modal-profit-text.glow {
    text-shadow:
        0 0 18px rgba(25, 195, 125, 0.7),
        0 0 36px rgba(25, 195, 125, 0.35);
    animation: profitGlow 2s ease-in-out infinite;
}
@keyframes profitGlow {
    0%,
    100% {
        text-shadow: 0 0 18px rgba(25, 195, 125, 0.6);
    }
    50% {
        text-shadow:
            0 0 32px rgba(25, 195, 125, 0.9),
            0 0 60px rgba(25, 195, 125, 0.4);
    }
}

/* Balance counting */
@keyframes countUp {
    from {
        opacity: 0.6;
    }
    to {
        opacity: 1;
    }
}
.balance-counting {
    animation: countUp 0.15s ease;
}


/* ═══════════════════════════════════════════════════
   KEYFRAMES
═══════════════════════════════════════════════════ */
@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

@keyframes pulseDot {
    0%,
    100% {
        box-shadow: 0 0 0 0 rgba(16, 163, 127, 0.45);
        opacity: 1;
    }
    50% {
        box-shadow: 0 0 0 6px rgba(16, 163, 127, 0);
        opacity: 0.7;
    }
}

@keyframes shimmer {
    0% {
        transform: translateX(-100%);
    }
    60% {
        transform: translateX(100%);
    }
    100% {
        transform: translateX(100%);
    }
}

@keyframes btnPulse {
    0%,
    100% {
        box-shadow:
            0 4px 20px rgba(16, 163, 127, 0.32),
            0 2px 6px rgba(16, 163, 127, 0.2);
    }
    50% {
        box-shadow:
            0 6px 28px rgba(16, 163, 127, 0.5),
            0 3px 10px rgba(16, 163, 127, 0.28);
    }
}

@keyframes overlayIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
@keyframes overlayOut {
    from {
        opacity: 1;
    }
    to {
        opacity: 0;
    }
}
@keyframes modalSlideUp {
    from {
        opacity: 0;
        transform: translateY(100%);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
@keyframes modalSlideDown {
    from {
        opacity: 1;
        transform: translateY(0);
    }
    to {
        opacity: 0;
        transform: translateY(100%);
    }
}
@keyframes flashGreen {
    0%,
    100% {
        background: var(--profit-bg);
    }
    50% {
        background: rgba(25, 195, 125, 0.28);
    }
}
@keyframes flashRed {
    0%,
    100% {
        background: var(--red-bg);
    }
    50% {
        background: rgba(239, 65, 70, 0.28);
    }
}

/* ═══════════════════════════════════════════════════
   RESPONSIVE — Mobile-first, scale UP
═══════════════════════════════════════════════════ */

/* Tiny phones */
@media (max-width: 359px) {
    .title {
        font-size: 18px;
    }
    .balance-amount {
        font-size: 28px;
    }
    .live-balance-amount {
        font-size: 24px;
    }
    .stat-value {
        font-size: 12px;
    }
    .stat-label {
        font-size: 9px;
    }
    .card {
        padding: 16px 12px;
    }
    .stats-row {
        gap: 4px;
    }
    .stat-card {
        padding: 8px 6px;
        gap: 4px;
    }
    .stat-icon {
        width: 22px;
        height: 22px;
    }
    .strategy-card {
        padding: 10px 12px;
    }
    .modal-card {
        padding: 20px 14px 24px;
    }
}

/* Standard phones (360–479) — base styles above cover this */

/* Larger phones */
@media (min-width: 480px) {
    :root {
        --px: 18px;
    }
    .title {
        font-size: 23px;
    }
    .card {
        padding: 24px 20px;
    }
    .live-balance-amount {
        font-size: 30px;
    }
    .modal-overlay {
        align-items: center;
        padding: 20px;
    }
    .modal-card {
        border-radius: var(--r-xl);
        max-width: 400px;
    }
    .modal-card.modal-fade-out {
        animation: modalOut 0.35s var(--ease) both;
    }
    @keyframes modalSlideUp {
        from {
            opacity: 0;
            transform: scale(0.92) translateY(12px);
        }
        to {
            opacity: 1;
            transform: scale(1) translateY(0);
        }
    }
    @keyframes modalSlideDown {
        from {
            opacity: 1;
            transform: scale(1);
        }
        to {
            opacity: 0;
            transform: scale(0.92);
        }
    }
}

/* Tablets */
@media (min-width: 640px) {
    :root {
        --px: 24px;
        --max-w: 520px;
    }
    .title {
        font-size: 25px;
    }
    .balance-amount {
        font-size: 38px;
    }
    .live-balance-amount {
        font-size: 32px;
    }
    .custom-chart-wrapper {
        height: 150px;
    }
}

/* iPad / small laptop */
@media (min-width: 768px) {
    :root {
        --px: 28px;
        --max-w: 540px;
        --hdr: 58px;
    }
    .title {
        font-size: 26px;
    }
    .custom-chart-wrapper {
        height: 160px;
    }
    .video-logo img {
        height: 28px;
    }
}


/* form */
.error{
    color: red;
    font-size: 12px;
    margin-top: 4px;
    margin-left: 4px;
}
.universal-modal {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background-color: rgba(0, 0, 0, 0.5) !important;
  z-index: 3000 !important;
  overflow: hidden !important;
  color: #000000;
}

.universal-modal-content {
  background-color: #ffffff !important;
  padding: 32px 24px !important;
  border-radius: 10px !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
  text-align: center !important;
  max-width: 400px !important;
  position: relative !important;
  margin: 0 10px !important;
  border: none !important;
}

.universal-modal-content p {
  line-height: 140% !important;
  margin: 10px 0 0 !important;
}

.universal-modal-close {
  position: absolute !important;
  top: 5px !important;
  right: 5px !important;
  cursor: pointer !important;
  width: 30px !important;
  height: 30px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 24px !important;
  color: #777777 !important;
}

.universal-modal-close:hover {
  color: #333333 !important;
}

.universal-modal-close::before,
.universal-modal-close::after {
  content: '' !important;
  position: absolute !important;
  width: 16px !important;
  height: 2px !important;
  background-color: #777777 !important;
}

.universal-modal-close::before {
  transform: rotate(45deg) !important;
}

.universal-modal-close::after {
  transform: rotate(-45deg) !important;
}

.universal-modal-open {
  overflow: hidden !important;
}



#loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgb(168 168 168 / 70%);
  z-index: 4000;
}

#loader img {
  position: absolute;
  width: 130px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
