/* =====================================================================
   VatProtect brand layer — vendored from the VatProtect Design System
   (claude.ai/design, project 90abde1b). Load AFTER bootstrap.min.css.
   Regenerate by re-pulling tokens/* + theme/bootstrap-theme.css via
   /design-sync and concatenating in this order (fonts → tokens → theme).
   Bootstrap 5.3.3 itself is vendored at public/bootstrap/bootstrap.min.css.
   ===================================================================== */

/* ---- tokens/fonts.css (Inter webfont) ---- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* Twemoji Country Flags — replaces the country-flag-emoji-polyfill npm pkg so emoji
   flags render on Windows without any JS. Listed first in --vp-font-sans. */
@font-face {
    font-family: "Twemoji Country Flags";
    unicode-range: U+1F1E6-1F1FF, U+1F3F4, U+E0062-E007F;
    src: url('https://cdn.jsdelivr.net/gh/talkjs/country-flag-emoji-polyfill@latest/dist/TwemojiCountryFlags.woff2') format('woff2');
    font-display: swap;
}

/* ---- tokens/colors.css ---- */
:root {
    --vp-crimson-50: #fbecec;
    --vp-crimson-100: #f3d2d2;
    --vp-crimson-200: #e3a3a3;
    --vp-crimson-300: #cf6b6b;
    --vp-crimson-400: #b73a3a;
    --vp-crimson-500: #9e1a1a;
    --vp-crimson-600: #901818;
    --vp-crimson-700: #781818;
    --vp-crimson-800: #5e0f12;
    --vp-crimson-900: #420a0c;

    --vp-gold-50: #faf1d8;
    --vp-gold-100: #f6e9c8;
    --vp-gold-200: #ecd29a;
    --vp-gold-300: #e0b85f;
    --vp-gold-400: #d4a24a;
    --vp-gold-500: #c2901f;
    --vp-gold-600: #a3780f;

    --vp-green-50: #e6f4ec;
    --vp-green-100: #c5e6d2;
    --vp-green-300: #5cb87e;
    --vp-green-500: #1e9e4b;
    --vp-green-600: #009048;
    --vp-green-700: #0b7038;

    --vp-blue-100: #d8f0ff;
    --vp-blue-400: #30a8ff;
    --vp-blue-500: #1890ff;
    --vp-blue-600: #0d6efd;

    --vp-secondary: #a9a9a9;
    --vp-info-navy: #1c2833;
    --vp-warning: #af601a;
    --vp-light: #f2f3f4;
    --vp-dark: #1c1c1c;

    --vp-danger-50: #fdecea;
    --vp-danger-500: #d92d20;
    --vp-danger-600: #b42318;

    --vp-white: #ffffff;
    --vp-gray-50: #f8f9fa;
    --vp-gray-100: #f7f7f9;
    --vp-gray-200: #eceeef;
    --vp-gray-300: #eceeef;
    --vp-gray-400: #ced4da;
    --vp-gray-500: #aaaaaa;
    --vp-gray-600: #888888;
    --vp-gray-700: #5a5a5a;
    --vp-gray-800: #343a40;
    --vp-gray-900: #212529;

    --vp-primary: var(--vp-crimson-500);
    --vp-primary-hover: var(--vp-crimson-600);
    --vp-primary-active: var(--vp-crimson-700);
    --vp-primary-contrast: var(--vp-white);

    --vp-accent: var(--vp-gold-400);
    --vp-success: var(--vp-green-500);
    --vp-success-strong: var(--vp-green-600);
    --vp-danger: var(--vp-danger-500);
    --vp-info: var(--vp-blue-500);

    --vp-text: var(--vp-gray-700);
    --vp-text-heading: var(--vp-gray-700);
    --vp-text-muted: var(--vp-gray-600);
    --vp-text-on-brand: var(--vp-white);
    --vp-text-on-brand-dim: rgba(255, 255, 255, 0.65);
    --vp-link: var(--vp-crimson-500);
    --vp-link-hover: var(--vp-crimson-700);

    --vp-bg: var(--vp-white);
    --vp-surface: var(--vp-white);
    --vp-surface-muted: var(--vp-gray-50);
    --vp-surface-brand: var(--vp-crimson-500);
    --vp-border: var(--vp-gray-300);
    --vp-border-input: var(--vp-gray-400);

    --vp-valid-bg: var(--vp-green-50);
    --vp-valid-text: var(--vp-green-700);
    --vp-invalid-bg: var(--vp-danger-50);
    --vp-invalid-text: var(--vp-danger-600);
}

/* ---- tokens/typography.css ---- */
:root {
    --vp-font-sans: "Twemoji Country Flags", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    "Helvetica Neue", Arial, "Noto Sans", sans-serif,
    "Apple Color Emoji", "Segoe UI Emoji";
    --vp-font-mono: "SFMono-Regular", Menlo, Monaco, Consolas,
    "Liberation Mono", "Courier New", monospace;

    --vp-text-display: 3.5rem;
    --vp-text-h1: 2.5rem;
    --vp-text-h2: 2rem;
    --vp-text-h3: 1.75rem;
    --vp-text-h4: 1.5rem;
    --vp-text-h5: 1.25rem;
    --vp-text-lead: 1.25rem;
    --vp-text-base: 1rem;
    --vp-text-sm: 0.875rem;
    --vp-text-xs: 0.75rem;

    --vp-weight-normal: 400;
    --vp-weight-medium: 500;
    --vp-weight-semibold: 600;
    --vp-weight-bold: 700;

    --vp-leading-tight: 1.2;
    --vp-leading-snug: 1.35;
    --vp-leading-base: 1.5;
    --vp-leading-loose: 1.7;

    --vp-tracking-tight: -0.01em;
    --vp-tracking-normal: 0;
    --vp-tracking-wide: 0.04em;
}

/* ---- tokens/spacing.css ---- */
:root {
    --vp-space-0: 0;
    --vp-space-1: 0.25rem;
    --vp-space-2: 0.5rem;
    --vp-space-3: 1rem;
    --vp-space-4: 1.5rem;
    --vp-space-5: 3rem;
    --vp-space-6: 4.5rem;
    --vp-space-section: 5rem;

    --vp-radius-sm: 0.2rem;
    --vp-radius: 0.25rem;
    --vp-radius-md: 0.5rem;
    --vp-radius-lg: 0.75rem;
    --vp-radius-pill: 50rem;

    --vp-container-max: 1140px;
    --vp-header-height: 80px;

    --vp-border-width: 1px;
    --vp-border-width-accent: 4px;
}

/* ---- tokens/effects.css ---- */
:root {
    --vp-shadow-sm: 0 1px 2px rgba(33, 37, 41, 0.08);
    --vp-shadow: 0 2px 8px rgba(33, 37, 41, 0.10);
    --vp-shadow-md: 0 6px 18px rgba(33, 37, 41, 0.12);
    --vp-shadow-lg: 0 16px 40px rgba(33, 37, 41, 0.16);
    --vp-shadow-focus: 0 0 0 0.2rem rgba(158, 26, 26, 0.25);

    --vp-gradient-brand: linear-gradient(135deg, var(--vp-crimson-500) 0%, var(--vp-crimson-700) 100%);
    --vp-gradient-gold: linear-gradient(135deg, var(--vp-gold-300) 0%, var(--vp-gold-500) 100%);
    --vp-sheen: linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0) 45%);

    --vp-ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --vp-transition-fast: 120ms var(--vp-ease);
    --vp-transition: 200ms var(--vp-ease);
}

/* ---- theme/bootstrap-theme.css (maps --vp-* onto --bs-* + brand components) ---- */
:root {
    --bs-primary: #9e1a1a;
    --bs-primary-rgb: 158, 26, 26;
    --bs-secondary: #a9a9a9;
    --bs-secondary-rgb: 169, 169, 169;
    --bs-success: #1e9e4b;
    --bs-success-rgb: 30, 158, 75;
    --bs-danger: #d92d20;
    --bs-danger-rgb: 217, 45, 32;
    --bs-warning: #d4a24a;
    --bs-warning-rgb: 212, 162, 74;
    --bs-info: #1c2833;
    --bs-info-rgb: 28, 40, 51;
    --bs-light: #f8f9fa;
    --bs-light-rgb: 248, 249, 250;
    --bs-dark: #1c1c1c;
    --bs-dark-rgb: 28, 28, 28;

    --bs-body-font-family: var(--vp-font-sans);
    --bs-body-font-size: 1rem;
    --bs-body-font-weight: 400;
    --bs-body-color: #5a5a5a;
    --bs-body-color-rgb: 90, 90, 90;
    --bs-heading-color: #2b2b2b;
    --bs-emphasis-color: #2b2b2b;

    --bs-link-color: #9e1a1a;
    --bs-link-color-rgb: 158, 26, 26;
    --bs-link-hover-color: #781818;
    --bs-link-hover-color-rgb: 120, 24, 24;

    --bs-body-bg: #ffffff;
    --bs-border-color: #e7e3e3;
    --bs-tertiary-bg: #faf7f7;

    --bs-border-radius: 0.6rem;
    --bs-border-radius-sm: 0.4rem;
    --bs-border-radius-lg: 0.9rem;
    --bs-border-radius-xl: 1.25rem;
    --bs-border-radius-2xl: 1.75rem;
    --bs-border-radius-pill: 50rem;

    --bs-focus-ring-color: rgba(158, 26, 26, 0.25);
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    font-weight: 700;
    letter-spacing: -0.018em;
    color: var(--bs-heading-color);
}

.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
    font-weight: 800;
    letter-spacing: -0.03em;
}

.lead {
    font-weight: 400;
}

.btn {
    --bs-btn-font-weight: 600;
    --bs-btn-padding-x: 1.1rem;
    --bs-btn-padding-y: 0.55rem;
}

.btn-lg {
    --bs-btn-padding-x: 1.6rem;
    --bs-btn-padding-y: 0.8rem;
    --bs-btn-font-size: 1.125rem;
}

.btn-primary {
    --bs-btn-bg: #9e1a1a;
    --bs-btn-border-color: #9e1a1a;
    --bs-btn-hover-bg: #871616;
    --bs-btn-hover-border-color: #871616;
    --bs-btn-active-bg: #781818;
    --bs-btn-active-border-color: #781818;
    --bs-btn-disabled-bg: #9e1a1a;
    --bs-btn-disabled-border-color: #9e1a1a;
    --bs-btn-color: #fff;
    --bs-btn-hover-color: #fff;
    --bs-btn-active-color: #fff;
}

.btn-success {
    --bs-btn-bg: #1e9e4b;
    --bs-btn-border-color: #1e9e4b;
    --bs-btn-hover-bg: #198a41;
    --bs-btn-hover-border-color: #198a41;
    --bs-btn-color: #fff;
    --bs-btn-hover-color: #fff;
}

.btn-gold {
    --bs-btn-bg: #d4a24a;
    --bs-btn-border-color: #c2901f;
    --bs-btn-hover-bg: #c2901f;
    --bs-btn-hover-border-color: #a3780f;
    --bs-btn-color: #42210a;
    --bs-btn-hover-color: #42210a;
    --bs-btn-active-color: #42210a;
}

.btn-outline-primary {
    --bs-btn-color: #9e1a1a;
    --bs-btn-border-color: #9e1a1a;
    --bs-btn-hover-bg: #9e1a1a;
    --bs-btn-hover-border-color: #9e1a1a;
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: #781818;
    --bs-btn-active-border-color: #781818;
}

.btn-light {
    --bs-btn-bg: #fff;
    --bs-btn-border-color: #e7e3e3;
    --bs-btn-color: #9e1a1a;
    --bs-btn-hover-bg: #faf7f7;
    --bs-btn-hover-border-color: #e0d6d6;
    --bs-btn-hover-color: #781818;
}

.btn-outline-light {
    --bs-btn-color: #fff;
    --bs-btn-border-color: rgba(255, 255, 255, .65);
    --bs-btn-hover-bg: #fff;
    --bs-btn-hover-border-color: #fff;
    --bs-btn-hover-color: #9e1a1a;
}

.btn-shiny {
    position: relative;
    overflow: hidden;
}

.btn-shiny::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.22) 0%, rgba(255, 255, 255, 0) 48%);
    pointer-events: none;
}

.btn {
    transition: transform var(--vp-transition-fast), filter var(--vp-transition), box-shadow var(--vp-transition);
}

.btn:not(.btn-link):active {
    transform: translateY(1px);
}

.btn-primary:hover, .btn-gold:hover, .btn-success:hover {
    box-shadow: var(--vp-shadow-md);
}

.badge {
    font-weight: 700;
    letter-spacing: .01em;
    padding: 0.45em 0.75em;
}

.badge.rounded-pill {
    padding: 0.45em 0.9em;
}

.badge-soft-valid {
    background: var(--vp-green-50);
    color: var(--vp-green-700);
}

.badge-soft-invalid {
    background: var(--vp-danger-50);
    color: var(--vp-danger-600);
}

.badge-soft-gold {
    background: var(--vp-gold-100);
    color: var(--vp-gold-600);
}

.badge-mono {
    font-family: var(--vp-font-mono);
    font-weight: 700;
}

/* Our --bs-info is dark navy (#1c2833); Bootstrap baked black text on .text-bg-info for the
   light default info colour → black-on-navy. Force readable white text. */
.text-bg-info {
    color: #fff !important;
}

.card {
    --bs-card-border-color: #efeaea;
    --bs-card-border-radius: var(--bs-border-radius-lg);
    --bs-card-inner-border-radius: calc(var(--bs-border-radius-lg) - 1px);
    --bs-card-spacer-x: 1.5rem;
    --bs-card-spacer-y: 1.5rem;
}

.card-elevated {
    border: 0;
    box-shadow: var(--vp-shadow-md);
}

.card-hover {
    transition: transform var(--vp-transition), box-shadow var(--vp-transition);
}

.card-hover:hover {
    transform: translateY(-4px);
    box-shadow: var(--vp-shadow-lg);
}

.form-control, .form-select {
    --bs-border-color: #d8d2d2;
    border-radius: var(--bs-border-radius);
    padding: 0.6rem 0.85rem;
}

.form-control:focus, .form-select:focus {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.22rem var(--bs-focus-ring-color);
}

.form-control-lg {
    padding: 0.8rem 1.1rem;
    font-size: 1.125rem;
}

.input-mono {
    font-family: var(--vp-font-mono);
    letter-spacing: 0.02em;
}

.form-label {
    font-weight: 600;
    color: #3a3a3a;
    margin-bottom: 0.4rem;
}

.alert {
    border: 1px solid;
    border-radius: var(--bs-border-radius);
}

.alert-success {
    background: var(--vp-green-50);
    border-color: var(--vp-green-100);
    color: var(--vp-green-700);
}

.alert-danger {
    background: var(--vp-danger-50);
    border-color: #f7c9c4;
    color: var(--vp-danger-600);
}

.alert-warning {
    background: var(--vp-gold-50);
    border-color: var(--vp-gold-200);
    color: var(--vp-gold-600);
}

.alert-info {
    background: #eaf4ff;
    border-color: #cfe6ff;
    color: #0d5bbf;
}

.section {
    padding: clamp(3rem, 7vw, 6rem) 0;
}

.section-muted {
    background: var(--vp-surface-muted);
}

.section-tint {
    background: var(--vp-crimson-50);
}

.section-brand {
    background: var(--vp-crimson-600);
    background-image: radial-gradient(900px 500px at 85% -10%, rgba(212, 162, 74, 0.22), transparent 60%),
    linear-gradient(160deg, #9e1a1a 0%, #781818 100%);
    color: #fff;
}

.section-brand h1, .section-brand h2, .section-brand h3 {
    color: #fff;
}

.section-dark {
    background: var(--vp-dark);
    color: #d9d4d4;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--vp-primary);
}

.section-brand .eyebrow, .section-dark .eyebrow {
    color: var(--vp-gold-300);
}

.eyebrow::before {
    content: "";
    width: 1.75rem;
    height: 2px;
    background: currentColor;
    opacity: .6;
}

.brand-bar {
    height: 4px;
    width: 64px;
    border-radius: 50rem;
    background: var(--vp-gradient-gold);
}

.icon-disc {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex: none;
    background: var(--vp-crimson-50);
    color: var(--vp-primary);
}

.icon-disc-gold {
    background: var(--vp-gold-50);
    color: var(--vp-gold-600);
}

.icon-disc-green {
    background: var(--vp-green-50);
    color: var(--vp-success-strong);
}

.icon-disc-navy {
    background: #e7ebef;
    color: var(--vp-info-navy);
}

.icon-disc-lg {
    width: 4.25rem;
    height: 4.25rem;
    border-radius: 1.25rem;
    font-size: 1.7rem;
}

.feature-card {
    background: #fff;
    border: 1px solid #efeaea;
    border-radius: var(--bs-border-radius-lg);
    padding: 1.75rem;
}

.price-card {
    position: relative;
    background: #fff;
    border: 1px solid #e7e3e3;
    border-radius: var(--bs-border-radius-xl);
    padding: 2rem;
}

.price-card.popular {
    border-color: var(--vp-primary);
    box-shadow: var(--vp-shadow-lg);
}

.price-card .price-amount {
    font-size: clamp(2.5rem, 4vw, 3.25rem);
    font-weight: 800;
    color: var(--vp-primary);
    letter-spacing: -0.03em;
    line-height: 1;
}

.price-ribbon {
    position: absolute;
    top: 1.25rem;
    right: -2.6rem;
    transform: rotate(45deg);
    background: var(--vp-gradient-gold);
    color: #42210a;
    font-weight: 800;
    font-size: .72rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .35rem 2.75rem;
    box-shadow: var(--vp-shadow-sm);
}

.price-feature {
    display: flex;
    gap: .6rem;
    align-items: flex-start;
    padding: .45rem 0;
}

.price-feature .fa-check {
    color: var(--vp-success);
    margin-top: .2rem;
}

.vat-result {
    border: 0;
    border-radius: var(--bs-border-radius-lg);
    box-shadow: var(--vp-shadow-md);
    overflow: hidden;
    background: #fff;
    color: var(--vp-text);
}

.vat-result .vat-id {
    font-family: var(--vp-font-mono);
    font-weight: 700;
    font-size: 1.1rem;
    letter-spacing: .02em;
}

.vat-result-foot {
    background: #faf7f7;
    border-top: 1px solid #efeaea;
    font-size: .82rem;
    color: var(--vp-text-muted);
}

/* VAT limit / upsell state — highest-frequency non-success render. Same footprint as
   .vat-result (radius + shadow) so the checker output doesn't jump. Gold = informational,
   not error red. Markup: templates/static/_demoVatCheckLimit.html.twig */
.vat-limit {
    border: 0;
    border-top: 3px solid var(--vp-gold-400);
    border-radius: var(--bs-border-radius-lg);
    box-shadow: var(--vp-shadow-md);
    overflow: hidden;
    background: #fff;
    color: var(--vp-text);
}

.vat-limit-icon {
    width: 3rem;
    height: 3rem;
    border-radius: .9rem;
    flex: none;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    background: var(--vp-gold-50);
    color: var(--vp-gold-600);
}

.vat-limit-title {
    font-weight: 800;
    color: #2b2b2b;
    letter-spacing: -.01em;
}

.vat-limit-foot {
    background: var(--vp-gold-50);
    border-top: 1px solid var(--vp-gold-100);
    color: var(--vp-gold-600);
    font-size: .82rem;
}

.flag-chip {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    text-decoration: none;
    color: inherit;
}

.flag-chip .fi {
    width: 1.4em;
    height: 1.05em;
    border-radius: 3px;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .08);
    flex: none;
}

.navbar-glass {
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: saturate(160%) blur(12px);
    -webkit-backdrop-filter: saturate(160%) blur(12px);
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.navbar-brand {
    font-weight: 800;
    letter-spacing: -0.02em;
}

.navbar-brand .fa-check-circle {
    color: var(--vp-info);
}

.trust-strip {
    color: var(--vp-text-muted);
    font-size: .95rem;
}

.trust-strip .fa-solid, .trust-strip .fas {
    color: var(--vp-primary);
}

.stat-card {
    background: #fff;
    border: 1px solid #efeaea;
    border-radius: var(--bs-border-radius-lg);
    padding: 1.25rem 1.4rem;
}

.stat-label {
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--vp-text-muted);
}

.stat-value {
    font-size: 1.6rem;
    font-weight: 800;
    color: #2b2b2b;
    letter-spacing: -0.02em;
}

.dash-side .nav-link {
    color: #5a5a5a;
    border-radius: var(--bs-border-radius);
    font-weight: 600;
    padding: .6rem .9rem;
    display: flex;
    gap: .65rem;
    align-items: center;
}

.dash-side .nav-link:hover {
    background: #faf7f7;
    color: var(--vp-primary);
}

.dash-side .nav-link.active {
    background: var(--vp-crimson-50);
    color: var(--vp-primary);
}

.table > :not(caption) > * > * {
    padding: .85rem 1rem;
}

.table thead th {
    font-size: .78rem;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--vp-text-muted);
    font-weight: 700;
}

.text-gold {
    color: var(--vp-gold-600) !important;
}

.bg-tint {
    background: var(--vp-crimson-50) !important;
}

.shadow-soft {
    box-shadow: var(--vp-shadow-md) !important;
}

.rounded-2xl {
    border-radius: var(--bs-border-radius-2xl) !important;
}

.fw-800 {
    font-weight: 800 !important;
}

.mono {
    font-family: var(--vp-font-mono);
}

/* ---- app-specific carry-overs (not in the DS theme) ---- */
/* The checker macro nests the result/limit card inside its .card-elevated; flatten the inner
   card so it doesn't double-shadow, and let it span the padding edge-to-edge. */
.card-elevated .vat-result,
.card-elevated .vat-limit {
    box-shadow: none;
    margin-left: 0;
    margin-right: 0;
}

/* Responsive hero headline — DS display token is 3.5rem at desktop, ramp down on mobile. */
.section-brand .display-3,
.section-brand .display-4,
.hero .display-4 {
    line-height: 1.12;
}

@media (max-width: 767.98px) {
    .display-3 {
        font-size: 2.5rem;
    }

    .display-4 {
        font-size: 2.25rem;
    }
}

@media (max-width: 575.98px) {
    .display-3 {
        font-size: 2.1rem;
    }

    .display-4 {
        font-size: 1.9rem;
    }
}

/* Fixed glassy header offset */
body {
    padding-top: 0;
}

.back-to-top {
    position: fixed;
    bottom: 25px;
    right: 25px;
    z-index: 1030;
}

/* ---- Dashboard app shell (light shell, sidebar + topbar — DS "dashboard" surface) ---- */
.dash-shell {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background: var(--vp-surface-muted);
}

.dash-side {
    width: 100%;
    flex: none;
    background: #fff;
    border-bottom: 1px solid #efeaea;
}

.dash-main {
    flex: 1;
    min-width: 0;
}

.dash-topbar {
    background: rgba(255, 255, 255, .85);
    backdrop-filter: saturate(160%) blur(10px);
    -webkit-backdrop-filter: saturate(160%) blur(10px);
    border-bottom: 1px solid #efeaea;
    z-index: 1020;
}

.dash-avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: var(--vp-crimson-50);
    color: var(--vp-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: .8rem;
    flex: none;
}

.quota-bar {
    height: 8px;
    border-radius: 50rem;
    background: var(--vp-crimson-50);
    overflow: hidden;
}

.quota-bar > span {
    display: block;
    height: 100%;
    background: var(--vp-gradient-gold);
}

@media (min-width: 821px) {
    .dash-shell {
        flex-direction: row;
    }

    .dash-side {
        width: 260px;
        border-bottom: 0;
        border-right: 1px solid #efeaea;
        position: sticky;
        top: 0;
        height: 100vh;
    }
}
