/* ============================================================
   Amypay — UI theme
   Тёмная/светлая тема, голубой акцент (#22a7f0 / #0d6efd).
   ============================================================ */

:root {
    --ap-accent:       #22a7f0;
    --ap-accent-600:   #0f95dd;
    --ap-accent-50:    rgba(34,167,240,.10);
    --ap-success:      #22c55e;
    --ap-danger:       #ef4444;
    --ap-warning:      #f59e0b;
    --ap-muted:        #8b97a7;
}

[data-bs-theme="dark"] {
    --bs-body-bg:          #101826;
    --bs-body-color:       #e6edf5;
    --bs-tertiary-bg:      #0d1622;
    --bs-border-color:     rgba(255,255,255,.06);
    --ap-card-bg:          #172233;
    --ap-card-border:      rgba(255,255,255,.06);
    --ap-sidebar-bg:       #0b1420;
    --ap-sidebar-border:   rgba(255,255,255,.05);
    --ap-input-bg:         #1a2538;
    --ap-input-border:     rgba(255,255,255,.08);
    --ap-hover:            rgba(255,255,255,.04);
}

[data-bs-theme="light"] {
    --bs-body-bg:          #f6f8fb;
    --bs-body-color:       #1a2538;
    --bs-tertiary-bg:      #ffffff;
    --bs-border-color:     rgba(10,22,40,.08);
    --ap-card-bg:          #ffffff;
    --ap-card-border:      rgba(10,22,40,.08);
    --ap-sidebar-bg:       #ffffff;
    --ap-sidebar-border:   rgba(10,22,40,.08);
    --ap-input-bg:         #ffffff;
    --ap-input-border:     rgba(10,22,40,.12);
    --ap-hover:            rgba(10,22,40,.04);
}

html, body { height: 100%; }
body { background: var(--bs-body-bg); color: var(--bs-body-color); }

.ap-link { color: var(--ap-accent); text-decoration: none; }
.ap-link:hover { color: var(--ap-accent-600); text-decoration: underline; }

/* ========== Layout ========== */
.ap-shell { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }
.ap-sidebar {
    background: var(--ap-sidebar-bg);
    border-right: 1px solid var(--ap-sidebar-border);
    padding: 18px 14px;
    position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.ap-main { min-width: 0; padding: 16px 24px 40px; }

@media (max-width: 991.98px) {
    .ap-shell { grid-template-columns: 1fr; }
    .ap-sidebar { display: none; }
    .ap-main { padding: 12px 14px 32px; }
}

/* ========== Sidebar ========== */
.ap-brand {
    display: flex; align-items: center; gap: 10px;
    font-weight: 800; font-size: 1.15rem; letter-spacing: .2px;
    padding: 6px 10px; margin-bottom: 18px;
    color: var(--bs-body-color);
}
.ap-brand .dot {
    width: 28px; height: 28px; border-radius: 8px;
    background: linear-gradient(135deg, var(--ap-accent), #7db7ff);
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff; font-weight: 800;
}
.ap-menu { list-style: none; padding: 0; margin: 0; }
.ap-menu li { margin: 2px 0; }
.ap-menu a {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 12px; border-radius: 10px;
    color: var(--bs-body-color); text-decoration: none;
    opacity: .8; transition: all .15s ease;
}
.ap-menu a:hover { background: var(--ap-hover); opacity: 1; }
.ap-menu a.active {
    background: var(--ap-accent-50);
    color: var(--ap-accent);
    opacity: 1;
    font-weight: 600;
}
.ap-menu a i { font-size: 1.05rem; min-width: 20px; text-align: center; }

/* ========== Topbar ========== */
.ap-topbar {
    display: flex; align-items: center; gap: 12px;
    padding: 8px 0 16px; flex-wrap: wrap;
}
.ap-topbar .right { margin-left: auto; display: flex; align-items: center; gap: 10px; }

/* ========== Card ========== */
.ap-card {
    background: var(--ap-card-bg);
    border: 1px solid var(--ap-card-border);
    border-radius: 14px;
    padding: 18px;
}
.ap-card + .ap-card { margin-top: 14px; }
.ap-card h3, .ap-card h4, .ap-card h5 { margin-top: 0; }

/* ========== Stats ========== */
.ap-stat {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 20px; border: 1px solid var(--ap-card-border);
    border-radius: 14px; background: var(--ap-card-bg);
}
.ap-stat .label { color: var(--ap-muted); font-size: .85rem; }
.ap-stat .value { font-size: 1.6rem; font-weight: 700; margin-top: 4px; }
.ap-stat .dotcolor { width: 10px; height: 10px; border-radius: 50%; }

/* ========== Form controls ========== */
.form-control, .form-select {
    background: var(--ap-input-bg);
    border: 1px solid var(--ap-input-border);
    color: var(--bs-body-color);
}
.form-control:focus, .form-select:focus {
    background: var(--ap-input-bg);
    color: var(--bs-body-color);
    border-color: var(--ap-accent);
    box-shadow: 0 0 0 .2rem var(--ap-accent-50);
}
.input-group-text {
    background: var(--ap-input-bg);
    border: 1px solid var(--ap-input-border);
    color: var(--ap-muted);
}

/* ========== Buttons ========== */
.btn-primary {
    background: var(--ap-accent);
    border-color: var(--ap-accent);
}
.btn-primary:hover, .btn-primary:focus {
    background: var(--ap-accent-600);
    border-color: var(--ap-accent-600);
}
.btn-outline-primary {
    color: var(--ap-accent);
    border-color: var(--ap-accent);
}
.btn-outline-primary:hover {
    background: var(--ap-accent);
    border-color: var(--ap-accent);
    color: #fff;
}

/* ========== Tables ========== */
.ap-table { width: 100%; }
.ap-table th {
    color: var(--ap-muted);
    font-weight: 600; font-size: .8rem;
    text-transform: uppercase; letter-spacing: .4px;
    padding: 10px 12px; border-bottom: 1px solid var(--ap-card-border);
}
.ap-table td {
    padding: 14px 12px; border-bottom: 1px solid var(--ap-card-border);
    vertical-align: middle;
}
.ap-table tr:hover td { background: var(--ap-hover); }
.ap-table .mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; }

/* ========== Status badges ========== */
.st { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; font-size: .78rem; font-weight: 600; }
.st-paid    { color: var(--ap-success); background: rgba(34,197,94,.12); }
.st-pending { color: var(--ap-warning); background: rgba(245,158,11,.12); }
.st-canceled, .st-failed, .st-rejected { color: var(--ap-danger); background: rgba(239,68,68,.12); }
.st-active  { color: var(--ap-success); background: rgba(34,197,94,.12); }
.st-suspended { color: var(--ap-danger); background: rgba(239,68,68,.12); }

/* ========== Flash/alerts ========== */
.flash { border-radius: 12px; padding: 12px 16px; margin-bottom: 14px; border: 1px solid transparent; }
.flash-success { background: rgba(34,197,94,.12); border-color: rgba(34,197,94,.3); color: #5ddf89; }
.flash-error   { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.3); color: #ffb0b0; }

/* ========== Auth ========== */
.ap-auth-wrap {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1.1fr 1fr;
}
.ap-auth-side {
    background: radial-gradient(circle at 20% 20%, rgba(34,167,240,.22), transparent 40%),
                radial-gradient(circle at 80% 80%, rgba(125,183,255,.18), transparent 40%),
                linear-gradient(135deg, #0a1422, #0f1a2c);
    color: #fff;
    padding: 48px;
    display: flex; flex-direction: column; justify-content: space-between;
}
.ap-auth-side h1 { font-size: 2.3rem; font-weight: 800; line-height: 1.1; }
.ap-auth-side p  { color: #b0bccc; max-width: 440px; }
.ap-auth-body {
    display: flex; align-items: center; justify-content: center;
    padding: 40px; background: var(--bs-body-bg);
}
.ap-auth-card { width: 100%; max-width: 420px; }
@media (max-width: 991.98px) {
    .ap-auth-wrap { grid-template-columns: 1fr; }
    .ap-auth-side { padding: 28px; }
}

/* ========== Mobile sidebar offcanvas ========== */
.ap-mobile-toggle { display: none; }
@media (max-width: 991.98px) {
    .ap-mobile-toggle { display: inline-flex; }
}
.ap-offcanvas-menu { min-width: 260px; }

/* ========== Misc ========== */
.ap-h-divider { height: 1px; background: var(--ap-card-border); margin: 16px 0; }
.ap-muted { color: var(--ap-muted); }
.ap-pill { display: inline-block; padding: 2px 8px; border-radius: 999px; background: var(--ap-accent-50); color: var(--ap-accent); font-size: .75rem; font-weight: 600; }

/* ========== Notifications bell ========== */
.ap-notify-menu {
    width: 360px; max-width: 92vw;
    background: var(--ap-card-bg);
    border: 1px solid var(--ap-card-border);
    color: var(--bs-body-color);
    border-radius: 14px;
    box-shadow: 0 20px 40px rgba(0,0,0,.24);
    overflow: hidden;
}
.ap-notify-list { max-height: 420px; overflow-y: auto; }
.ap-notify-item {
    display: grid; grid-template-columns: 28px 1fr; gap: 10px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--ap-card-border);
    font-size: .88rem;
}
.ap-notify-item:last-child { border-bottom: none; }
.ap-notify-item.unread { background: var(--ap-accent-50); }
.ap-notify-item .dot { width: 10px; height: 10px; border-radius: 50%; margin-top: 6px; }
.ap-notify-item .tt { font-weight: 600; }
.ap-notify-item .bd { color: var(--ap-muted); font-size: .82rem; margin-top: 2px; }
.ap-notify-item .tm { color: var(--ap-muted); font-size: .72rem; margin-top: 4px; }

/* ========== Methods slider ========== */
.ap-method-row {
    display: grid;
    grid-template-columns: auto 1.4fr 1fr 1fr 1.4fr 1fr;
    gap: 14px; align-items: center;
    padding: 12px 10px;
    border-bottom: 1px solid var(--ap-card-border);
}
.ap-method-row:last-child { border-bottom: none; }
.ap-method-row .title { display: flex; align-items: center; gap: 10px; font-weight: 600; }
.ap-method-row .title i { font-size: 1.3rem; color: var(--ap-accent); }
.ap-method-row .limits { font-size: .82rem; color: var(--ap-muted); }
.ap-method-row .fee-group { display: flex; align-items: center; gap: 6px; }
.ap-method-row .fee-group .fee-label { min-width: 58px; text-align: right; font-weight: 600; }
.ap-method-row input[type=range] { width: 100%; accent-color: var(--ap-accent); }
.ap-method-row .badge-api {
    display: inline-block; font-size: .65rem; padding: 2px 6px; border-radius: 4px;
    background: rgba(239,68,68,.15); color: #ef4444; font-weight: 700; margin-left: 4px;
}

@media (max-width: 991.98px) {
    .ap-method-row {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }
    .ap-method-row > .title { grid-column: 1/-1; }
    .ap-method-row > .limits { grid-column: 1/-1; }
}

