:root {
    --adm-bg: #f4f6f9;
    --adm-card: #ffffff;
    --adm-text: #000000;
    --adm-muted: #000000;
    --adm-border: #e2e8f0;
    --adm-primary: #1e40af;
    --adm-primary-hover: #1e3a8a;
    --adm-success-bg: #ecfdf5;
    --adm-success-text: #047857;
    --adm-error-bg: #fef2f2;
    --adm-error-text: #b91c1c;
    --adm-radius: 12px;
    --adm-shadow: 0 1px 3px rgb(15 23 42 / 6%), 0 8px 24px rgb(15 23 42 / 4%);
    --adm-max: 960px;
    --adm-sidebar-w: 15.5rem;
}

*, *::before, *::after { box-sizing: border-box; }

body.adm-body {
    margin: 0;
    min-height: 100vh;
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    background: var(--adm-bg);
    color: var(--adm-text);
    line-height: 1.55;
    font-size: 15px;
}

a { color: var(--adm-primary); }

/* Login */
.adm-login-wrap {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background: linear-gradient(180deg, #fff 0%, var(--adm-bg) 100%);
}

.adm-login-box {
    background: var(--adm-card);
    border: 1px solid var(--adm-border);
    border-radius: var(--adm-radius);
    padding: 2rem;
    width: 100%;
    max-width: 24rem;
    box-shadow: var(--adm-shadow);
}

.adm-logo { font-size: 2rem; color: var(--adm-primary); margin-bottom: .5rem; }
.adm-sub, .adm-hint { color: var(--adm-text); font-size: .85rem; opacity: .85; }

.adm-error {
    background: var(--adm-error-bg);
    border: 1px solid #fecaca;
    color: var(--adm-error-text);
    padding: .65rem .85rem;
    border-radius: 8px;
    margin: 1rem 0;
    font-size: .85rem;
}

.adm-login-box label {
    display: block;
    margin: .75rem 0;
    font-size: .82rem;
    font-weight: 600;
    color: var(--adm-text);
}

.adm-login-box input {
    width: 100%;
    margin-top: .25rem;
    padding: .55rem .7rem;
    border-radius: 8px;
    border: 1px solid var(--adm-border);
    background: #fff;
    color: var(--adm-text);
    font: inherit;
}

.adm-login-box input:focus {
    outline: 2px solid #bfdbfe;
    border-color: #3b82f6;
}

/* Buttons */
.adm-btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .55rem 1rem;
    border-radius: 8px;
    border: none;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    font-size: .88rem;
    font-family: inherit;
}

.adm-btn-primary {
    background: var(--adm-primary);
    color: #fff;
    width: 100%;
    justify-content: center;
    margin-top: .5rem;
}

.adm-btn-primary:hover { background: var(--adm-primary-hover); }

.adm-btn-ghost {
    background: #fff;
    color: var(--adm-text);
    border: 1px solid var(--adm-border);
}

.adm-btn-danger {
    background: #fff;
    color: #b91c1c;
    border: 1px solid #fecaca;
}

.adm-btn-sm { padding: .35rem .65rem; font-size: .78rem; }

.adm-back { text-align: center; margin-top: 1.25rem; font-size: .82rem; }

/* Header */
.adm-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .75rem 1rem;
    padding: .75rem 1.25rem;
    border-bottom: 1px solid var(--adm-border);
    background: #fff;
    box-shadow: 0 1px 0 rgb(15 23 42 / 4%);
    position: sticky;
    top: 0;
    z-index: 10;
}

.adm-brand {
    color: var(--adm-text);
    text-decoration: none;
    font-weight: 700;
    font-size: 1rem;
}

.adm-nav {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem .75rem;
    margin-left: auto;
    font-size: .82rem;
}

.adm-nav a {
    color: var(--adm-text);
    text-decoration: none;
    padding: .35rem .55rem;
    border-radius: 6px;
    font-weight: 500;
}

.adm-nav a:hover,
.adm-nav a.active {
    color: var(--adm-primary);
    background: #eff6ff;
}

/* Main */
.adm-main {
    max-width: var(--adm-max);
    margin: 0 auto;
    padding: 1.5rem 1.25rem 3rem;
}

.adm-page-title {
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    margin: 0 0 1.25rem;
    letter-spacing: -.02em;
}

.adm-error {
    background: var(--adm-error-bg);
    border: 1px solid #fecaca;
    color: var(--adm-error-text);
    padding: .65rem .85rem;
    border-radius: 8px;
    margin-bottom: 1rem;
    font-size: .88rem;
}

.adm-success {
    background: var(--adm-success-bg);
    border: 1px solid #a7f3d0;
    color: var(--adm-success-text);
    padding: .65rem 1rem;
    border-radius: 8px;
    margin-bottom: 1rem;
    font-size: .88rem;
}

.adm-card {
    background: var(--adm-card);
    border: 1px solid var(--adm-border);
    border-radius: var(--adm-radius);
    padding: 1.25rem;
    margin-bottom: 1rem;
    box-shadow: var(--adm-shadow);
}

.adm-card h2 {
    font-size: .95rem;
    margin: 0 0 1rem;
    color: var(--adm-primary);
    font-weight: 600;
}

.adm-field { margin-bottom: .75rem; }

.adm-field label {
    display: block;
    font-size: .75rem;
    font-weight: 600;
    color: var(--adm-text);
    margin-bottom: .2rem;
}

.adm-field input,
.adm-field select,
.adm-field textarea {
    width: 100%;
    padding: .5rem .65rem;
    border-radius: 8px;
    border: 1px solid var(--adm-border);
    background: #fff;
    color: var(--adm-text);
    font: inherit;
}

.adm-field input:focus,
.adm-field select:focus,
.adm-field textarea:focus {
    outline: 2px solid #bfdbfe;
    border-color: #3b82f6;
}

.adm-field-hint {
    font-size: .72rem;
    color: var(--adm-muted);
    margin-top: .2rem;
}

.adm-grid-2 {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
}

.adm-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

.adm-table {
    width: 100%;
    min-width: 480px;
    border-collapse: collapse;
    font-size: .85rem;
}

.adm-table th {
    text-align: left;
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--adm-muted);
    padding: .5rem .4rem;
    border-bottom: 1px solid var(--adm-border);
    background: #f8fafc;
}

.adm-table td {
    border-bottom: 1px solid var(--adm-border);
    padding: .55rem .4rem;
    vertical-align: middle;
}

.adm-table tr:hover td { background: #f8fafc; }

.adm-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.adm-stat {
    background: var(--adm-card);
    border: 1px solid var(--adm-border);
    border-radius: var(--adm-radius);
    padding: 1rem;
    box-shadow: var(--adm-shadow);
}

.adm-stat strong {
    display: block;
    font-size: 1.5rem;
    color: var(--adm-primary);
}

.adm-stat span {
    font-size: .82rem;
    color: var(--adm-muted);
}

.adm-stat i {
    color: var(--adm-primary);
    font-size: .9rem;
    margin-bottom: .15rem;
}

.adm-stat--link {
    text-decoration: none;
    color: inherit;
    transition: border-color .15s, transform .15s;
}

.adm-stat--link:hover {
    border-color: #93c5fd;
    transform: translateY(-2px);
}

.adm-card h2 i {
    margin-right: .35rem;
    font-size: .88rem;
    opacity: .85;
}

.adm-card-lead {
    color: var(--adm-text);
    font-size: .88rem;
    opacity: .85;
    margin: 0 0 .75rem;
}

.adm-card--recent { padding: 0; overflow: hidden; }

.adm-doc-head--compact {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--adm-border);
    margin: 0;
}

.adm-recent-grid {
    display: grid;
    gap: .5rem;
    grid-template-columns: 1fr;
    padding: .85rem 1.25rem 1.15rem;
}

@media (min-width: 700px) {
    .adm-recent-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1100px) {
    .adm-recent-grid { grid-template-columns: repeat(3, 1fr); }
}

.adm-recent-card {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: .65rem;
    align-items: center;
    padding: .65rem .75rem;
    border: 1px solid var(--adm-border);
    border-radius: 10px;
    text-decoration: none;
    color: var(--adm-text);
    background: #f8fafc;
    transition: border-color .15s, background .15s;
}

.adm-recent-card:hover {
    border-color: #93c5fd;
    background: #eff6ff;
}

.adm-recent-icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 8px;
    background: #fff;
    border: 1px solid var(--adm-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--adm-primary);
}

.adm-recent-body {
    display: flex;
    flex-direction: column;
    gap: .1rem;
    min-width: 0;
}

.adm-recent-body strong {
    font-size: .84rem;
    line-height: 1.25;
}

.adm-recent-body span {
    font-size: .74rem;
    opacity: .75;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.adm-recent-body em {
    font-style: normal;
    font-size: .78rem;
    font-weight: 700;
    color: var(--adm-primary);
}

.adm-recent-go {
    font-size: .72rem;
    color: var(--adm-primary);
    opacity: .5;
}

.adm-recent-card:hover .adm-recent-go { opacity: 1; }

.adm-badge-demo--sm {
    font-size: .62rem;
    padding: .1rem .35rem;
}

.adm-empty {
    color: var(--adm-muted);
    font-size: .88rem;
    padding: 1rem 0;
}

.adm-actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
}

code {
    background: #f1f5f9;
    padding: .15rem .35rem;
    border-radius: 4px;
    font-size: .85em;
}

@media (min-width: 640px) {
    .adm-grid-2 { grid-template-columns: 1fr 1fr; }
}

.adm-lang-switch {
    display: flex;
    flex-wrap: wrap;
    gap: .25rem;
    font-size: .68rem;
}

.adm-lang-switch a {
    padding: .2rem .45rem;
    border: 1px solid var(--adm-border);
    border-radius: 999px;
    text-decoration: none;
    color: var(--adm-muted);
    background: #fff;
}

.adm-lang-switch a.active {
    background: #eff6ff;
    border-color: #bfdbfe;
    color: var(--adm-primary);
    font-weight: 600;
}

.fk-lang-dropdown--admin .fk-lang-dropdown-btn {
    min-height: 2.25rem;
}

.adm-mobile-lang {
    margin-top: .75rem;
    padding-top: .75rem;
    border-top: 1px solid var(--adm-border);
}

.adm-login-lang {
    display: flex;
    justify-content: flex-end;
    margin-bottom: .75rem;
}

.adm-login-box label i {
    margin-right: .35rem;
    color: var(--adm-primary);
    font-size: .78rem;
}

@media (min-width: 900px) {
    .adm-mobile-lang { display: none; }
}

.adm-badge-demo {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .72rem;
    font-weight: 600;
    color: #047857;
    background: #ecfdf5;
    border: 1px solid #a7f3d0;
    border-radius: 999px;
    padding: .15rem .45rem;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.adm-menu-btn {
    display: none;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border: 1px solid var(--adm-border);
    border-radius: 8px;
    background: #fff;
    color: var(--adm-text);
    cursor: pointer;
    margin-left: auto;
}

.adm-nav-jump { margin-left: auto; min-width: 10rem; }
.adm-select {
    width: 100%;
    padding: .5rem .65rem;
    border-radius: 8px;
    border: 1px solid var(--adm-border);
    background: #fff;
    color: var(--adm-text);
    font: inherit;
    font-size: .82rem;
    font-weight: 600;
}

.adm-mobile-nav {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    padding: .75rem 1rem 1rem;
    border-bottom: 1px solid var(--adm-border);
    background: #fff;
}

.adm-mobile-nav[hidden] { display: none !important; }

body.adm-nav-open { overflow: hidden; }

.adm-mobile-nav-label {
    margin: .5rem 0 .15rem;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--adm-text);
    opacity: .65;
}

.adm-mobile-nav a {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .6rem .65rem;
    border-radius: 8px;
    text-decoration: none;
    color: var(--adm-text);
    font-size: .88rem;
    font-weight: 500;
}

.adm-mobile-nav a:hover,
.adm-mobile-nav a.active {
    background: #eff6ff;
    color: var(--adm-primary);
}

.adm-feature-grid {
    display: grid;
    gap: .65rem;
    grid-template-columns: 1fr;
}

.adm-feature-card {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    padding: .85rem 1rem;
    border: 1px solid var(--adm-border);
    border-radius: 10px;
    text-decoration: none;
    color: var(--adm-text);
    background: #f8fafc;
    transition: border-color .15s, background .15s;
}

.adm-feature-card:hover {
    border-color: #93c5fd;
    background: #eff6ff;
}

.adm-feature-card i { color: var(--adm-primary); font-size: 1.1rem; }
.adm-feature-card strong { font-size: .9rem; }
.adm-feature-card span { font-size: .78rem; color: #64748b; line-height: 1.4; }

.adm-card-lead { color: #64748b; font-size: .88rem; margin: 0 0 1rem; line-height: 1.5; }

.adm-muted-list {
    font-size: .9rem;
    color: #64748b;
    line-height: 1.6;
    margin: 0;
    padding-left: 1.2rem;
}

.adm-model-custom { display: none; margin-top: .35rem; width: 100%; }

@media (min-width: 520px) {
    .adm-feature-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 899px) {
    .adm-menu-btn { display: inline-flex; }
    .adm-nav { display: none; }
    .adm-nav-jump { flex: 1; min-width: 0; margin-left: .5rem; }
    .adm-top { flex-wrap: wrap; }
    .adm-lang-switch { width: 100%; order: 10; }
    .adm-top-crumb { display: none; }
}

@media (min-width: 900px) {
    .adm-nav-jump { display: none; }
    .adm-menu-btn { display: none !important; }
    .adm-mobile-nav { display: none !important; }
}

@media (max-width: 600px) {
    .adm-top { padding: .65rem 1rem; }
}

/* —— Shell + sidebar (PC) —— */
.adm-shell { min-height: 100vh; }

.adm-sidebar {
    display: none;
}

.adm-shell-main {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.adm-sidebar-brand {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: 1rem 1rem .75rem;
    text-decoration: none;
    color: var(--adm-text);
    font-weight: 700;
    font-size: .95rem;
    border-bottom: 1px solid var(--adm-border);
    margin-bottom: .5rem;
}

.adm-sidebar-brand-icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    background: #eff6ff;
    color: var(--adm-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
}

.adm-sidebar-label {
    margin: .65rem 1rem .2rem;
    font-size: .65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--adm-text);
    opacity: .55;
}

.adm-sidebar-nav { display: flex; flex-direction: column; gap: .1rem; padding: 0 .5rem; }

.adm-sidebar-link {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .55rem .75rem;
    border-radius: 8px;
    text-decoration: none;
    color: var(--adm-text);
    font-size: .84rem;
    font-weight: 500;
    transition: background .15s, color .15s;
}

.adm-sidebar-link i {
    width: 1.15rem;
    text-align: center;
    color: var(--adm-primary);
    font-size: .9rem;
}

.adm-sidebar-link:hover,
.adm-sidebar-link.active {
    background: #eff6ff;
    color: var(--adm-primary);
}

.adm-sidebar-foot {
    margin-top: auto;
    padding: .75rem .5rem 1rem;
    border-top: 1px solid var(--adm-border);
}

.adm-top-tools {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-left: auto;
}

.adm-top-icon {
    display: none;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 8px;
    border: 1px solid var(--adm-border);
    background: #fff;
    color: var(--adm-primary);
    text-decoration: none;
    font-size: .85rem;
}

.adm-top-icon:hover { background: #eff6ff; border-color: #bfdbfe; }

.adm-nav a {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
}

.adm-nav a i { color: var(--adm-primary); font-size: .78rem; }

.adm-success {
    display: flex;
    align-items: center;
    gap: .45rem;
}

.adm-success i { color: var(--adm-success-text); }

@media (min-width: 900px) {
    .adm-shell {
        display: grid;
        grid-template-columns: var(--adm-sidebar-w) 1fr;
    }

    .adm-sidebar {
        display: flex;
        flex-direction: column;
        position: sticky;
        top: 0;
        height: 100vh;
        border-right: 1px solid var(--adm-border);
        background: #fff;
        overflow-y: auto;
        box-shadow: 1px 0 0 rgb(15 23 42 / 4%);
    }

    .adm-top {
        padding: .65rem 1.75rem;
        flex-wrap: nowrap;
    }

    .adm-top .adm-brand { display: none; }
    .adm-nav { display: none !important; }
    .adm-top-crumb {
        display: flex;
        align-items: center;
        gap: .5rem;
        margin: 0;
        font-size: .95rem;
        font-weight: 600;
        color: var(--adm-text);
        min-width: 0;
        flex: 1;
    }

    .adm-top-crumb i { color: var(--adm-primary); font-size: .85rem; }

    .adm-top-tools { margin-left: auto; flex-shrink: 0; }
    .adm-top-icon--desk { display: inline-flex; }
    .adm-top-icon:first-of-type { display: inline-flex; }

    .adm-lang-switch { width: auto; order: 0; }

    .adm-body-pc .adm-main {
        max-width: 1200px;
        padding: 1.5rem 2rem 3rem;
        width: 100%;
    }

    body.adm-page-invoices .adm-main {
        max-width: 1440px;
    }

    .adm-pc-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
        align-items: start;
    }

    .adm-pc-grid .adm-card { margin-bottom: 0; }

    .adm-stat-grid--icons {
        grid-template-columns: repeat(5, 1fr);
    }

    .adm-doc-grid {
        grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
    }

    .adm-feature-grid {
        grid-template-columns: 1fr 1fr;
    }

    .adm-actions-row--pc { flex-wrap: nowrap; }
}

@media (min-width: 1280px) {
    .adm-doc-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1500px) {
    body.adm-page-invoices .adm-main { max-width: 100%; padding-right: 2.5rem; }
    .adm-doc-grid { grid-template-columns: repeat(4, 1fr); }
}

/* —— Icon buttons —— */
.adm-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 8px;
    border: 1px solid var(--adm-border);
    background: #fff;
    color: var(--adm-text);
    cursor: pointer;
    text-decoration: none;
    font-size: .82rem;
    font-family: inherit;
    padding: 0;
    transition: background .15s, border-color .15s, color .15s;
}

.adm-icon-btn:hover {
    background: #eff6ff;
    border-color: #93c5fd;
    color: var(--adm-primary);
}

.adm-icon-btn--sm { width: 2rem; height: 2rem; font-size: .75rem; }

.adm-icon-btn--danger:hover {
    background: #fef2f2;
    border-color: #fecaca;
    color: #b91c1c;
}

.adm-doc-card-actions form { display: inline; margin: 0; }

/* —— Documents browser —— */
.adm-card--flush { padding: 0; overflow: hidden; }

.adm-doc-head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.15rem 1.25rem;
    border-bottom: 1px solid var(--adm-border);
    background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.adm-doc-head h2 {
    margin: 0 0 .35rem;
    font-size: 1.05rem;
    display: flex;
    align-items: center;
    gap: .5rem;
    color: var(--adm-primary);
}

.adm-doc-head h2 i { font-size: .95rem; opacity: .85; }

.adm-doc-head p {
    margin: 0;
    font-size: .84rem;
    color: var(--adm-text);
    opacity: .85;
    max-width: 36rem;
}

.adm-doc-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .65rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--adm-border);
    background: #f8fafc;
}

.adm-doc-stat {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: .1rem;
    padding: .65rem .75rem;
    background: #fff;
    border: 1px solid var(--adm-border);
    border-radius: 10px;
}

.adm-doc-stat i {
    color: var(--adm-primary);
    font-size: .85rem;
    margin-bottom: .15rem;
}

.adm-doc-stat strong {
    font-size: 1.25rem;
    color: var(--adm-primary);
    line-height: 1.1;
}

.adm-doc-stat span {
    font-size: .72rem;
    color: var(--adm-text);
    opacity: .75;
}

.adm-doc-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .65rem;
    padding: .85rem 1.25rem;
    border-bottom: 1px solid var(--adm-border);
}

.adm-doc-search {
    flex: 1 1 12rem;
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .65rem;
    border: 1px solid var(--adm-border);
    border-radius: 8px;
    background: #fff;
}

.adm-doc-search i { color: var(--adm-primary); font-size: .82rem; }

.adm-doc-search input {
    border: none;
    outline: none;
    width: 100%;
    font: inherit;
    font-size: .84rem;
    color: var(--adm-text);
    background: transparent;
}

.adm-doc-filters,
.adm-doc-view-toggle {
    display: flex;
    gap: .35rem;
    flex-wrap: wrap;
}

.adm-filter-btn,
.adm-view-btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .45rem .7rem;
    border-radius: 8px;
    border: 1px solid var(--adm-border);
    background: #fff;
    color: var(--adm-text);
    font: inherit;
    font-size: .78rem;
    font-weight: 600;
    cursor: pointer;
}

.adm-filter-btn:hover,
.adm-view-btn:hover { border-color: #93c5fd; background: #f8fafc; }

.adm-filter-btn.active,
.adm-view-btn.active {
    background: #eff6ff;
    border-color: #93c5fd;
    color: var(--adm-primary);
}

.adm-doc-result {
    margin: 0;
    padding: 0 1.25rem .65rem;
    font-size: .72rem;
    font-weight: 600;
    color: var(--adm-text);
    opacity: .65;
}

.adm-doc-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fill, minmax(17.5rem, 1fr));
    padding: 1rem 1.25rem 1.25rem;
}

.adm-doc-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid var(--adm-border);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: var(--adm-shadow);
    transition: border-color .15s, transform .15s;
}

.adm-doc-card:hover {
    border-color: #93c5fd;
    transform: translateY(-2px);
}

.adm-doc-card-accent {
    height: 4px;
    width: 100%;
}

.adm-doc-card-top {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    padding: .85rem .85rem .35rem;
}

.adm-doc-card-icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 10px;
    background: #f8fafc;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.adm-doc-card-title {
    flex: 1;
    min-width: 0;
}

.adm-doc-card-title strong {
    display: block;
    font-size: .92rem;
    line-height: 1.3;
    word-break: break-word;
}

.adm-doc-card-date {
    display: block;
    font-size: .72rem;
    color: var(--adm-text);
    opacity: .7;
    margin-top: .15rem;
}

.adm-doc-card-body {
    padding: 0 .85rem .75rem;
    flex: 1;
}

.adm-doc-buyer {
    margin: 0 0 .35rem;
    font-size: .84rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: .4rem;
}

.adm-doc-buyer i,
.adm-doc-meta i,
.adm-doc-total i { color: var(--adm-primary); width: .9rem; text-align: center; font-size: .72rem; }

.adm-doc-meta {
    margin: 0 0 .35rem;
    font-size: .76rem;
    color: var(--adm-text);
    opacity: .8;
    display: flex;
    align-items: center;
    gap: .4rem;
    word-break: break-all;
}

.adm-doc-total {
    margin: .5rem 0 .55rem;
    font-size: 1rem;
    font-weight: 700;
    color: var(--adm-primary);
    display: flex;
    align-items: center;
    gap: .4rem;
}

.adm-doc-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}

.adm-doc-tag {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .68rem;
    font-weight: 600;
    padding: .2rem .45rem;
    border-radius: 999px;
    background: #f1f5f9;
    color: var(--adm-text);
    border: 1px solid var(--adm-border);
}

.adm-doc-tag--inline { font-size: .75rem; }

.adm-doc-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    padding: .65rem .85rem;
    border-top: 1px solid var(--adm-border);
    background: #f8fafc;
}

.adm-doc-table-view { padding: 0 1.25rem 1.25rem; }

.adm-table--icons th i {
    margin-right: .25rem;
    color: var(--adm-primary);
    font-size: .68rem;
}

.adm-design-dot {
    display: inline-block;
    width: .65rem;
    height: .65rem;
    border-radius: 999px;
    margin-right: .35rem;
    vertical-align: middle;
}

.adm-muted-dash { color: var(--adm-text); opacity: .4; }

.adm-actions-row--tight { gap: .25rem; }

.adm-empty i { margin-right: .35rem; color: var(--adm-primary); }

@media (max-width: 640px) {
    .adm-doc-stats { grid-template-columns: 1fr; }
    .adm-doc-grid { grid-template-columns: 1fr; }
    .adm-filter-btn span { display: none; }
    .adm-filter-btn { padding: .45rem .55rem; }
    .adm-doc-toolbar { flex-direction: column; align-items: stretch; }
    .adm-doc-filters, .adm-doc-view-toggle { justify-content: space-between; }
}

/* —— Clients page —— */
.adm-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.adm-inline-form { display: inline; margin: 0; }

.adm-client-meta {
    font-size: .75rem;
    color: var(--adm-muted);
}

.adm-clients-toolbar .adm-clients-search {
    flex: 1 1 100%;
    min-width: 0;
}

.adm-clients-table-wrap {
    padding: 0 1.25rem 1.25rem;
}

.adm-client-row[hidden] { display: none; }

.adm-clients-cards {
    display: none;
    flex-direction: column;
    gap: .65rem;
    padding: 0 1.25rem 1.25rem;
}

.adm-client-card {
    border: 1px solid var(--adm-border);
    border-radius: 12px;
    padding: .85rem;
    background: #fff;
    box-shadow: var(--adm-shadow);
}

.adm-client-card[hidden] { display: none !important; }

.adm-client-card-head {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    margin-bottom: .5rem;
}

.adm-client-card-head strong {
    display: block;
    font-size: .92rem;
}

.adm-client-card-avatar {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    background: #eff6ff;
    color: var(--adm-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.adm-client-card-line {
    margin: 0 0 .35rem;
    font-size: .82rem;
    display: flex;
    align-items: center;
    gap: .45rem;
    word-break: break-all;
}

.adm-client-card-line i {
    color: var(--adm-primary);
    width: .9rem;
    text-align: center;
    font-size: .72rem;
    flex-shrink: 0;
}

.adm-client-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    margin-top: .65rem;
    padding-top: .65rem;
    border-top: 1px solid var(--adm-border);
}

.adm-page-clients .adm-doc-head .adm-btn {
    flex-shrink: 0;
}

@media (max-width: 767px) {
    .adm-clients-table-wrap { display: none; }
    .adm-clients-cards { display: flex; }
    .adm-page-clients .adm-doc-head {
        flex-direction: column;
        align-items: stretch;
    }
    .adm-page-clients .adm-doc-head .adm-btn {
        width: 100%;
        justify-content: center;
    }
}

@media (min-width: 768px) {
    .adm-clients-toolbar .adm-clients-search {
        flex: 1 1 16rem;
    }
}

/* —— AI referral links —— */
.adm-ai-links-grid {
    display: flex;
    flex-direction: column;
    gap: .45rem;
    padding: 1rem 1.25rem 1.25rem;
}

.adm-ai-link-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .45rem;
}

.adm-ai-link-badges {
    display: inline-flex;
    gap: .35rem;
    flex: 0 0 auto;
    min-width: 9.5rem;
}

.adm-ai-link-lang,
.adm-ai-link-provider {
    font-size: .68rem;
    font-weight: 700;
    padding: .2rem .45rem;
    border-radius: 999px;
    border: 1px solid var(--adm-border);
    background: #f8fafc;
}

.adm-ai-link-provider--openai { color: #047857; border-color: #a7f3d0; background: #ecfdf5; }
.adm-ai-link-provider--grok { color: #1e40af; border-color: #93c5fd; background: #eff6ff; }

.adm-ai-link-input {
    flex: 1 1 12rem;
    min-width: 0;
    font: inherit;
    font-size: .76rem;
    padding: .4rem .55rem;
    border: 1px solid var(--adm-border);
    border-radius: 8px;
    background: #fff;
    color: var(--adm-text);
}

.adm-btn--copied { border-color: #86efac !important; color: #047857 !important; }

@media (max-width: 640px) {
    .adm-ai-link-row { flex-direction: column; align-items: stretch; }
    .adm-ai-link-badges { min-width: 0; }
    .adm-ai-link-row .adm-btn { align-self: flex-end; }
}

.adm-layout-split {
    display: grid;
    gap: 1rem;
}

@media (min-width: 1100px) {
    .adm-layout-split {
        grid-template-columns: minmax(0, 1fr) minmax(380px, 42%);
        align-items: start;
    }
}

.adm-preset-services {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    margin-bottom: .65rem;
}

.adm-preset-service-row {
    display: grid;
    grid-template-columns: 1fr 72px 88px 40px;
    gap: .45rem;
    align-items: center;
}

.adm-preset-service-row input {
    width: 100%;
    padding: .45rem .55rem;
    border: 1px solid var(--adm-border);
    border-radius: 8px;
    font-size: .88rem;
}

@media (max-width: 640px) {
    .adm-preset-service-row {
        grid-template-columns: 1fr 1fr;
    }
    .adm-preset-service-row input:first-child {
        grid-column: 1 / -1;
    }
}