/* =========================================================================
   Account panel (and auth pages) — sibling of admin.css, separate from the
   public site's style.css. Same Bootstrap base, similar visual language.
   ========================================================================= */

:root {
    --a-bg:           #F4F6FA;
    --a-card:         #FFFFFF;
    --a-ink:          #1F2937;
    --a-ink-soft:     #6B7280;
    --a-ink-faint:    #9CA3AF;
    --a-rule:         #E5E7EB;
    --a-rule-soft:    #F1F3F7;
    --a-accent:       #2563EB;
    --a-accent-soft:  #DBEAFE;
    --a-success:      #10B981;
    --a-warning:      #F59E0B;
    --a-danger:       #EF4444;
    --a-info:         #06B6D4;

    --a-sb-w:         260px;
    --a-tb-h:         60px;

    --a-sb-bg:        #14181F;
    --a-sb-bg-2:      #1B2027;
    --a-sb-ink:       #FFFFFF;
    --a-sb-ink-soft:  #6B7280;
    --a-sb-ink-mute:  #4B5563;
    --a-sb-hover:     rgba(255, 255, 255, .05);

    --a-radius:       12px;
    --a-radius-sm:    8px;
    --a-shadow-card:  0 1px 2px rgba(15, 23, 42, .04), 0 8px 24px -12px rgba(15, 23, 42, .12);
    --a-shadow-pop:   0 4px 8px rgba(15, 23, 42, .06), 0 20px 36px -16px rgba(15, 23, 42, .22);
}

*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
body.acc-body {
    margin: 0;
    background: var(--a-bg);
    color: var(--a-ink);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, system-ui, sans-serif;
    font-size: 14px;
    -webkit-font-smoothing: antialiased;
}
a { color: var(--a-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
code { background: var(--a-rule-soft); padding: .12em .35em; border-radius: 4px; font-size: .85em; color: var(--a-ink); }

/* ============ Sidebar ============ */
.acc-sidebar {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: var(--a-sb-w);
    background: var(--a-sb-bg); color: var(--a-sb-ink);
    display: flex; flex-direction: column;
    z-index: 1040; box-shadow: 1px 0 0 rgba(255,255,255,.04);
}
.acc-brand {
    display: flex; align-items: center; gap: .65rem;
    padding: .85rem 1.15rem;
    color: #fff; text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,.06);
    flex: 0 0 auto;
}
.acc-brand:hover { color: #fff; text-decoration: none; }
.acc-brand-mark {
    width: 36px; height: 36px; border-radius: 9px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(160deg, #3B82F6, #2563EB 60%, #1D4ED8);
    color: #fff; font-size: 1.05rem; flex: 0 0 auto;
    box-shadow: 0 6px 14px -6px rgba(37,99,235,.6), inset 0 1px 0 rgba(255,255,255,.25);
}
.acc-brand-text { display: flex; flex-direction: column; line-height: 1.15; min-width: 0; }
.acc-brand-name { font-weight: 600; font-size: .95rem; letter-spacing: -.01em; color: #fff; }
.acc-brand-sub  { font-size: .68rem; color: var(--a-sb-ink-soft); letter-spacing: .14em; text-transform: uppercase; }

.acc-nav {
    flex: 1 1 auto; min-height: 0; padding: .5rem 0;
    overflow-y: auto; overflow-x: hidden;
    scrollbar-width: none; -ms-overflow-style: none;
}
.acc-nav::-webkit-scrollbar { display: none; width: 0; height: 0; }

.acc-nav-link {
    display: flex; align-items: center; gap: .8rem;
    padding: .55rem 1rem; margin: 1px .55rem;
    color: #fff; text-decoration: none;
    font-size: .92rem; font-weight: 500;
    border-radius: var(--a-radius-sm);
    position: relative; transition: background-color .12s ease;
}
.acc-nav-link:hover { background: var(--a-sb-hover); color: #fff; text-decoration: none; }
.acc-nav-link.active {
    background: color-mix(in srgb, var(--ic, #3B82F6) 18%, transparent);
    color: #fff;
}
.acc-nav-link.active::before {
    content: '';
    position: absolute; left: -.55rem; top: 6px; bottom: 6px;
    width: 3px; background: var(--ic, #3B82F6);
    border-radius: 0 3px 3px 0;
    box-shadow: 0 0 8px var(--ic, #3B82F6);
}
.acc-nav-link i.bi {
    width: 20px; text-align: center; font-size: 1rem;
    color: var(--ic, #9CA3AF);
    transition: transform .15s ease;
}
.acc-nav-link:hover i.bi { transform: scale(1.08); }
.acc-nav-label { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.acc-nav-divider {
    height: 1px; background: rgba(255,255,255,.06);
    margin: .5rem 1rem;
}

.acc-sidebar-foot {
    padding: .65rem 1.15rem .8rem;
    border-top: 1px solid rgba(255,255,255,.06);
    flex: 0 0 auto;
}
.acc-foot-link {
    color: var(--a-sb-ink-soft); text-decoration: none; font-size: .82rem;
    display: inline-flex; align-items: center; gap: .45rem;
}
.acc-foot-link:hover { color: #fff; text-decoration: none; }

/* ============ Topbar + content shell ============ */
.acc-wrap {
    margin-left: var(--a-sb-w);
    padding-top: var(--a-tb-h);
    min-height: 100vh;
    display: flex; flex-direction: column;
}
.acc-topbar {
    position: fixed; top: 0; left: var(--a-sb-w); right: 0;
    height: var(--a-tb-h);
    background: rgba(255,255,255,.92);
    backdrop-filter: saturate(180%) blur(8px);
    -webkit-backdrop-filter: saturate(180%) blur(8px);
    border-bottom: 1px solid var(--a-rule);
    display: flex; align-items: center; gap: 1rem;
    padding: 0 1.4rem; z-index: 1030;
}
.acc-sidebar-toggle {
    display: none; width: 36px; height: 36px;
    border: 1px solid var(--a-rule); background: #fff;
    border-radius: var(--a-radius-sm); color: var(--a-ink);
    align-items: center; justify-content: center; font-size: 1.1rem; cursor: pointer;
}
.acc-topbar-title { font-size: 1rem; color: var(--a-ink); }
.acc-topbar-actions { display: flex; align-items: center; gap: .4rem; }

.acc-topbar-link {
    display: inline-flex; align-items: center; gap: .45rem;
    height: 36px; padding: 0 .85rem;
    border: 1px solid var(--a-rule); border-radius: var(--a-radius-sm);
    background: #fff; color: var(--a-ink);
    font-size: .82rem; font-weight: 500; text-decoration: none;
    transition: background-color .12s ease, border-color .12s ease;
}
.acc-topbar-link:hover { background: var(--a-rule-soft); color: var(--a-ink); text-decoration: none; }
.acc-topbar-link i.bi { font-size: .95rem; color: var(--a-accent); }

.acc-user-menu { margin-left: .35rem; }
.acc-user-btn {
    display: inline-flex; align-items: center; gap: .55rem;
    background: transparent; border: 1px solid transparent;
    padding: .25rem .55rem .25rem .25rem;
    border-radius: var(--a-radius-sm); cursor: pointer; color: var(--a-ink);
}
.acc-user-btn:hover { background: var(--a-rule-soft); border-color: var(--a-rule); }
.acc-user-avatar {
    width: 32px; height: 32px; border-radius: 50%;
    background: linear-gradient(160deg, #6366F1, #2563EB);
    color: #fff; font-weight: 700;
    display: inline-flex; align-items: center; justify-content: center; font-size: .8rem;
}
.acc-user-meta { line-height: 1.1; text-align: left; }
.acc-user-name { display: block; font-weight: 600; font-size: .85rem; }
.acc-user-plan { display: block; font-size: .7rem; color: var(--a-ink-soft); text-transform: uppercase; letter-spacing: .06em; }

.acc-content {
    flex: 1 1 auto;
    padding: 1.5rem 1.75rem 2rem;
    max-width: 1600px; width: 100%;
}
.acc-footer {
    padding: .85rem 1.75rem;
    border-top: 1px solid var(--a-rule);
    background: #fff; color: var(--a-ink-soft); font-size: .82rem;
    display: flex; align-items: center;
}
.acc-footer a { color: var(--a-ink-soft); }
.acc-footer a:hover { color: var(--a-accent); }

/* ============ Page primitives ============ */
.acc-page-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 1rem; flex-wrap: wrap; margin-bottom: 1.4rem;
}
.acc-page-head h1 {
    font-size: 1.55rem; font-weight: 700; margin: 0 0 .25rem;
    letter-spacing: -.015em; color: var(--a-ink);
}
.acc-crumb { font-size: .8rem; color: var(--a-ink-soft); }
.acc-crumb a { color: var(--a-ink-soft); }
.acc-crumb a:hover { color: var(--a-accent); }

.acc-card {
    background: var(--a-card); border: 1px solid var(--a-rule);
    border-radius: var(--a-radius); box-shadow: var(--a-shadow-card);
    overflow: hidden;
}
.acc-card-head {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1rem; padding: 1rem 1.4rem;
    border-bottom: 1px solid var(--a-rule);
}
.acc-card-title { margin: 0; font-size: 1rem; font-weight: 600; }
.acc-card-body { padding: 1.25rem 1.4rem; }

/* KPI tiles */
.acc-kpis {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem; margin-bottom: 1.5rem;
}
.acc-kpi {
    background: var(--a-card); border: 1px solid var(--a-rule);
    border-radius: var(--a-radius); padding: 1.2rem 1.3rem;
    box-shadow: var(--a-shadow-card); position: relative; overflow: hidden;
}
.acc-kpi-icon {
    --c: var(--a-accent);
    position: absolute; top: 1.1rem; right: 1.1rem;
    width: 40px; height: 40px; border-radius: 10px;
    background: color-mix(in srgb, var(--c) 14%, transparent);
    color: var(--c);
    display: inline-flex; align-items: center; justify-content: center; font-size: 1.05rem;
}
.acc-kpi-label { color: var(--a-ink-soft); font-size: .76rem; letter-spacing: .04em; text-transform: uppercase; font-weight: 600; margin: 0 0 .35rem; }
.acc-kpi-value { font-size: 1.65rem; font-weight: 700; color: var(--a-ink); letter-spacing: -.02em; line-height: 1.1; margin: 0; }
.acc-kpi-delta { margin-top: .55rem; font-size: .78rem; color: var(--a-ink-soft); }

/* Tables */
.acc-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.acc-table thead th {
    text-align: left; font-size: .72rem; text-transform: uppercase; letter-spacing: .08em;
    color: var(--a-ink-soft); font-weight: 600;
    padding: .85rem 1rem; background: var(--a-rule-soft);
    border-bottom: 1px solid var(--a-rule); white-space: nowrap;
}
.acc-table tbody td {
    padding: .85rem 1rem; border-bottom: 1px solid var(--a-rule);
    font-size: .89rem; vertical-align: middle;
}
.acc-table tbody tr:hover td { background: var(--a-rule-soft); }
.acc-table tbody tr:last-child td { border-bottom: 0; }
.acc-table .cell-id { color: var(--a-ink-soft); font-family: ui-monospace, monospace; font-size: .82rem; }
.acc-table .cell-actions { white-space: nowrap; text-align: right; }
.acc-table .cell-actions .btn { padding: .25rem .55rem; font-size: .8rem; }

/* Plan cards */
.acc-plan-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; }
.acc-plan-card {
    background: var(--a-card); border: 1px solid var(--a-rule);
    border-radius: var(--a-radius); padding: 1.5rem;
    box-shadow: var(--a-shadow-card); position: relative;
    display: flex; flex-direction: column;
}
.acc-plan-card.current {
    border-color: var(--a-success);
    box-shadow: 0 0 0 1px var(--a-success), var(--a-shadow-card);
}
.acc-plan-card.popular {
    border-color: var(--a-accent);
    box-shadow: 0 0 0 1px var(--a-accent), var(--a-shadow-card);
}
.acc-plan-card h3 { font-size: 1.05rem; font-weight: 700; margin: 0; }
.acc-plan-card .price {
    font-size: 2rem; font-weight: 800; letter-spacing: -.025em; margin: .35rem 0 1rem;
}
.acc-plan-card .price small { font-size: .85rem; color: var(--a-ink-soft); font-weight: 500; }
.acc-plan-card ul { list-style: none; padding: 0; margin: 0 0 1.25rem; font-size: .88rem; line-height: 1.85; }
.acc-plan-card ul li i.bi { color: var(--a-success); margin-right: .35rem; }
.acc-plan-badge {
    position: absolute; top: 1rem; right: 1rem;
    font-size: .68rem; padding: .15rem .55rem;
    background: var(--a-success); color: #fff;
    border-radius: 999px; text-transform: uppercase; letter-spacing: .06em; font-weight: 600;
}
.acc-plan-badge.popular { background: var(--a-accent); }

/* Status dots / badges */
.acc-badge {
    display: inline-block; padding: .15rem .55rem;
    border-radius: 999px; font-size: .72rem; font-weight: 600; text-transform: capitalize;
}
.acc-badge.success    { background: #DCFCE7; color: #166534; }
.acc-badge.warning    { background: #FEF3C7; color: #92400E; }
.acc-badge.danger     { background: #FEE2E2; color: #991B1B; }
.acc-badge.info       { background: #DBEAFE; color: #1E40AF; }
.acc-badge.secondary  { background: var(--a-rule-soft); color: var(--a-ink-soft); }
.acc-badge.primary    { background: #DBEAFE; color: #1E40AF; }

/* Recent activity items (dashboard) */
.acc-recent-row {
    display: grid; grid-template-columns: auto 1fr auto auto auto;
    align-items: center; gap: 1rem;
    padding: .8rem 0; border-bottom: 1px solid var(--a-rule);
}
.acc-recent-row:last-child { border-bottom: 0; }
.acc-recent-icon {
    width: 36px; height: 36px; border-radius: 10px;
    background: var(--a-accent-soft); color: var(--a-accent);
    display: inline-flex; align-items: center; justify-content: center; font-size: 1rem;
}

/* Empty states */
.acc-empty {
    text-align: center; padding: 3rem 1rem;
    color: var(--a-ink-soft);
}
.acc-empty i.bi { font-size: 2.5rem; opacity: .35; display: block; margin: 0 auto .65rem; }

/* Mobile sidebar drawer */
.acc-sidebar-backdrop {
    position: fixed; inset: 0; background: rgba(15,23,42,.45);
    z-index: 1035; opacity: 0; pointer-events: none;
    transition: opacity .25s ease;
}
.acc-sidebar-backdrop.show { opacity: 1; pointer-events: auto; }

@media (max-width: 991.98px) {
    .acc-sidebar {
        transform: translateX(-100%);
        transition: transform .28s cubic-bezier(.4, 0, .2, 1);
    }
    .acc-sidebar.show { transform: translateX(0); }
    .acc-wrap, .acc-footer { margin-left: 0; }
    .acc-topbar { left: 0; }
    .acc-sidebar-toggle { display: inline-flex; }
}
@media (max-width: 575.98px) {
    .acc-content { padding: 1rem; }
    .acc-topbar { padding: 0 .85rem; }
    .acc-user-meta { display: none !important; }
}

/* ============ Auth pages (login/register/forgot) ============ */
.auth-body {
    margin: 0; min-height: 100vh;
    background: linear-gradient(135deg, #EEF2FF 0%, #DBEAFE 50%, #F0F9FF 100%);
    display: grid; place-items: center; padding: 1rem;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, system-ui, sans-serif;
    color: var(--a-ink);
}
.auth-wrap { width: 100%; max-width: 440px; }
.auth-back {
    display: inline-flex; align-items: center; gap: .35rem;
    margin-bottom: 1rem; font-size: .85rem;
    color: #4B5563; text-decoration: none;
}
.auth-back:hover { color: var(--a-accent); }
.auth-card {
    background: #fff; border-radius: 16px; padding: 2rem 2rem 1.75rem;
    box-shadow: 0 20px 50px -12px rgba(15, 23, 42, .15);
}
.auth-brand {
    display: flex; align-items: center; gap: .65rem;
    margin-bottom: 1.5rem;
}
.auth-brand-mark {
    width: 40px; height: 40px; border-radius: 10px;
    background: linear-gradient(160deg, #3B82F6, #2563EB 60%, #1D4ED8);
    color: #fff; display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.2rem;
    box-shadow: 0 6px 14px -6px rgba(37,99,235,.6), inset 0 1px 0 rgba(255,255,255,.25);
}
.auth-brand-name { font-weight: 700; font-size: 1rem; color: var(--a-ink); }
.auth-brand-sub  { font-size: .72rem; color: var(--a-ink-soft); letter-spacing: .12em; text-transform: uppercase; }

.auth-title { font-size: 1.4rem; font-weight: 700; margin: 0 0 .25rem; color: var(--a-ink); }
.auth-sub   { color: var(--a-ink-soft); margin-bottom: 1.25rem; }
.auth-foot  { text-align: center; margin-top: 1.5rem; color: #6B7280; font-size: .82rem; }
.auth-foot a { color: #6B7280; }
.auth-foot a:hover { color: var(--a-accent); }

/* The form-control / btn-primary in auth + account pages just inherit
   Bootstrap defaults; no overrides needed. */
