/* Share — класически с леки модерни акценти */
:root {
    --bg: #f0f2f5;
    --surface: #ffffff;
    --surface-alt: #f7f8fa;
    --border: #d5dbe3;
    --border-light: #e8ecf1;
    --text: #1e2936;
    --text-muted: #5c6b7a;
    --heading: #003366;
    --link: #1565a8;
    --link-hover: #0d4d85;
    --btn-bg: #003d73;
    --btn-hover: #002f5a;
    --danger: #b71c1c;
    --danger-bg: #fef2f2;
    --success: #2e7d32;
    --success-bg: #f1f8f2;
    --accent-soft: #e8f2fa;
    --font: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    --font-mono: ui-monospace, "SF Mono", Consolas, monospace;
    --radius: 8px;
    --radius-sm: 6px;
    --shadow: 0 1px 3px rgba(0, 40, 80, 0.06), 0 4px 12px rgba(0, 40, 80, 0.04);
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --page-max: 24rem;
    --page-max-wide: 70rem;
    --header-h: 3.75rem;
}

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

html {
    -webkit-text-size-adjust: 100%;
}

body.app {
    margin: 0;
    min-height: 100vh;
    min-height: 100dvh;
    font-family: var(--font);
    font-size: 14px;
    line-height: 1.55;
    color: var(--text);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
}

.app-shell {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
}

/* —— Header —— */
.chrome {
    position: sticky;
    top: 0;
    z-index: 100;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-md);
    min-height: var(--header-h);
    padding: 0.65rem clamp(var(--space-md), 3vw, var(--space-xl));
    padding-top: max(0.65rem, env(safe-area-inset-top));
    background: var(--heading);
    border-bottom: none;
    box-shadow: 0 2px 8px rgba(0, 30, 60, 0.15);
}

.chrome__brand {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    min-width: 0;
}

.chrome__logo {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    line-height: 0;
    padding: 5px;
    background: #ffffff;
    border-radius: 6px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.18);
}

.chrome__logo:focus-visible {
    outline: 1px dotted #fff;
    outline-offset: 2px;
}

.chrome__eyebrow {
    margin: 0;
    font-size: 11px;
    color: #b8c9d9;
}

.chrome__title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    color: #ffffff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chrome__title--solo {
    min-width: 0;
}

.chrome__actions {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.site-logo {
    display: block;
    object-fit: contain;
}

.site-logo--sm {
    width: 40px;
    height: 40px;
}

.site-logo--md {
    width: 64px;
    height: 64px;
}

.btn-logout--pill {
    padding: 0.4rem 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.1);
    color: #e8eef4;
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s;
}

.btn-logout--pill:hover {
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
}

.lang-switch {
    display: flex;
    gap: 2px;
}

.lang-switch__btn {
    min-width: 2.25rem;
    padding: 0.35rem 0.6rem;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-sm);
    background: transparent;
    color: #c5d5e4;
    font-size: 0.75rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

.lang-switch__btn:hover {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.lang-switch__btn.is-active {
    background: #fff;
    border-color: #fff;
    color: var(--heading);
}

/* —— Page —— */
.page {
    flex: 1;
    width: 100%;
    max-width: var(--page-max-wide);
    margin: 0 auto;
    padding: var(--space-lg) clamp(var(--space-md), 3vw, var(--space-xl));
    padding-bottom: max(var(--space-xl), env(safe-area-inset-bottom));
}

.page--dashboard {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.page--login {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: var(--space-lg);
    justify-content: flex-start;
    padding-top: clamp(3rem, 18vh, 9rem);
}

.login-layout {
    width: 100%;
    max-width: 28rem;
    margin-inline: auto;
}

.login-alert {
    margin-bottom: var(--space-lg);
    text-align: center;
}

.login-tagline {
    margin: 0 auto var(--space-lg);
    max-width: 36rem;
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1.45;
    text-align: center;
    color: var(--heading);
}

.page-alert {
    margin: 0;
}

.page-hero {
    margin: 0;
    padding: var(--space-lg);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    border-left: 4px solid var(--heading);
    box-shadow: var(--shadow);
}

.page-hero__title {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--heading);
}

.page-hero__hello {
    font-weight: normal;
    color: var(--text-muted);
}

.page-hero__name {
    color: var(--heading);
}

.page-hero__subtitle {
    margin: 0.35rem 0 0;
    max-width: 42rem;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--text-muted);
}

.dashboard-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
    align-items: start;
}

.dashboard-col {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
    min-width: 0;
}

@media (min-width: 960px) {
    .dashboard-grid {
        grid-template-columns: 1fr calc(1fr + 5px);
        gap: var(--space-xl);
    }

    .dashboard-col--side {
        position: sticky;
        top: calc(var(--header-h) + var(--space-md));
        max-height: calc(100dvh - var(--header-h) - 2rem);
    }

    .card--my-uploads {
        display: flex;
        flex-direction: column;
        max-height: inherit;
    }

    .card--my-uploads .result-list {
        overflow-y: auto;
        flex: 1;
        min-height: 0;
    }
}

/* —— Panels —— */
.panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-lg);
    box-shadow: var(--shadow);
}

.card__heading {
    margin: 0 0 var(--space-md);
    padding-bottom: var(--space-sm);
    border-bottom: 1px solid var(--border-light);
    font-size: 1rem;
    font-weight: 600;
    color: var(--heading);
}

.hint,
.card__hint {
    margin: 0 0 var(--space-md);
    font-size: 12px;
    color: var(--text-muted);
}

.hint--quota {
    margin-top: calc(-1 * var(--space-sm));
}

.card--flash {
    border-color: #90caf9;
    background: var(--accent-soft);
}

.card--login {
    text-align: center;
}

.card--login .card__heading {
    text-align: center;
}

.card--login .card__hint {
    text-align: center;
}

.card--login .login-form {
    margin: 0 auto;
    max-width: 18rem;
    text-align: left;
}

.card--login .field,
.card--login .field__label,
.card--login .field__input {
    text-align: left;
}

.field__label,
.ttl-field__label {
    display: block;
    margin-bottom: 4px;
    font-size: 12px;
    font-weight: bold;
    color: var(--text);
}

.field__input {
    width: 100%;
    padding: 0.55rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--text);
    font: inherit;
    font-size: 0.9375rem;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.field__input:focus {
    outline: none;
    border-color: var(--link);
    box-shadow: 0 0 0 3px var(--accent-soft);
}

.ttl-field {
    margin: 0 0 var(--space-md);
    padding: 0;
    border: none;
}

.ttl-field__label {
    padding: 0;
}

.ttl-field__options {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
    margin-top: var(--space-xs);
}

.ttl-option {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    cursor: pointer;
    font-size: 0.9375rem;
    color: var(--text);
    user-select: none;
}

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

.ttl-option__box {
    flex-shrink: 0;
    width: 1.125rem;
    height: 1.125rem;
    border: 2px solid var(--border);
    border-radius: 3px;
    background: var(--surface);
    transition: border-color 0.15s, background 0.15s;
}

.ttl-option__input:checked + .ttl-option__box {
    border-color: var(--btn-bg);
    background: var(--btn-bg);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath fill='none' stroke='%23fff' stroke-width='2' d='M1 5l3 3 7-7'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 10px 8px;
}

.ttl-option__input:focus-visible + .ttl-option__box {
    outline: none;
    box-shadow: 0 0 0 3px var(--accent-soft);
}

.ttl-option:hover .ttl-option__box {
    border-color: var(--link);
}

.ttl-option:has(.ttl-option__input:checked) {
    color: var(--heading);
}

.login-form .field {
    display: block;
    margin-bottom: var(--space-md);
}

.card--login .login-form .btn {
    display: block;
    width: 100%;
    margin-top: var(--space-sm);
}

/* —— Dropzone —— */
.file-dropzone {
    margin-bottom: var(--space-md);
}

.file-dropzone__input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
}

.file-dropzone__target {
    padding: var(--space-xl) var(--space-md);
    border: 2px dashed var(--border);
    border-radius: var(--radius);
    background: var(--surface-alt);
    text-align: center;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
}

.file-dropzone__target:hover,
.file-dropzone__target:focus-visible {
    outline: none;
    border-color: var(--link);
    background: var(--accent-soft);
}

.file-dropzone--active .file-dropzone__target {
    border-color: var(--link);
    background: var(--accent-soft);
}

.file-dropzone__title {
    margin: 0 0 4px;
    font-weight: bold;
    color: var(--heading);
}

.file-dropzone__hint {
    margin: 0 0 var(--space-md);
    font-size: 12px;
    color: var(--text-muted);
}

.file-dropzone__browse {
    padding: 0.45rem 1rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--heading);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
}

.file-dropzone__browse:hover {
    background: var(--accent-soft);
    border-color: var(--link);
}

.file-dropzone__error {
    margin-top: var(--space-sm);
    font-size: 12px;
    color: var(--danger);
}

.file-dropzone--has-files .file-dropzone__target {
    padding: var(--space-md);
}

.file-queue {
    list-style: none;
    margin: var(--space-sm) 0 0;
    padding: 0;
    border: 1px solid var(--border-light);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.file-queue__item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--space-sm);
    padding: 0.55rem 0.75rem;
    border-bottom: 1px solid var(--border-light);
    background: var(--surface);
    cursor: grab;
}

.file-queue__item:last-child {
    border-bottom: none;
}

.file-queue__item--over {
    background: #eef5fb;
}

.file-queue__item--dragging {
    opacity: 0.6;
}

.file-queue__handle {
    color: var(--text-muted);
    font-size: 11px;
    cursor: grab;
}

.file-queue__name {
    font-size: 12px;
}

.file-queue__size {
    font-size: 11px;
    color: var(--text-muted);
}

.file-queue__remove {
    width: 26px;
    height: 26px;
    padding: 0;
    border: none;
    border-radius: var(--radius-sm);
    background: transparent;
    color: var(--text-muted);
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
}

.file-queue__remove:hover {
    color: var(--danger);
    border-color: var(--danger);
}

/* —— Buttons —— */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0.65rem 1.25rem;
    border: none;
    border-radius: var(--radius-sm);
    background: var(--btn-bg);
    color: #fff;
    font-family: inherit;
    font-size: 0.9375rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
}

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

#upload-submit:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.btn-icon__svg {
    display: block;
    pointer-events: none;
}

a.btn-icon {
    text-decoration: none;
    box-sizing: border-box;
}

.btn-icon--open {
    color: var(--link);
}

.btn-icon--open:hover {
    border-color: var(--link);
    background: var(--accent-soft);
    color: var(--link-hover);
}

.btn-icon--copy {
    color: var(--link);
}

.btn-icon--copy:hover,
.btn-icon--copy.is-copied {
    border-color: var(--link);
    background: var(--accent-soft);
    color: var(--link-hover);
}

.btn-icon--delete {
    color: var(--danger);
}

.btn-icon--delete:hover {
    border-color: var(--danger);
    background: var(--danger-bg);
}

.btn-icon:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px var(--accent-soft);
}

/* —— My uploads —— */
.my-uploads__head {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.my-uploads__head .card__heading {
    margin: 0;
    padding: 0;
    border: none;
}

.quota-bar {
    height: 6px;
    margin: 0 0 var(--space-md);
    overflow: hidden;
    background: #e8edf2;
    border-radius: 3px;
}

.quota-bar__fill {
    height: 100%;
    background: var(--accent, #1565c0);
    border-radius: 3px;
    transition: width 0.2s ease;
}

.quota-bar__fill--warn {
    background: #c62828;
}

.my-uploads__stats {
    margin: 0;
    font-size: 12px;
    color: var(--text-muted);
}

.pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--border-light);
}

.pagination__btn {
    padding: 0.4rem 0.85rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--surface);
    color: var(--text);
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.15s;
}

.pagination__btn:hover {
    border-color: var(--btn-bg);
    background: var(--btn-bg);
    color: #fff;
}

.pagination__btn--disabled {
    opacity: 0.45;
    pointer-events: none;
}

.pagination__status {
    font-size: 12px;
    color: var(--text-muted);
}

/* —— File list —— */
.result-list {
    border: 1px solid var(--border-light);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.result-item {
    padding: var(--space-md);
    border-bottom: 1px solid var(--border-light);
    background: var(--surface);
    transition: background 0.12s;
}

.result-item:last-child {
    border-bottom: none;
}

.result-item:hover {
    background: var(--surface-alt);
}

.result-item__label {
    font-size: 11px;
    font-weight: bold;
    color: var(--text-muted);
}

.result-item__value--name {
    font-weight: bold;
    color: var(--text);
    word-break: break-word;
}

.result-item__meta {
    margin: 4px 0 8px;
    font-size: 11px;
    color: var(--text-muted);
}

.result-item__meta span:not(:last-child)::after {
    content: " | ";
    color: var(--border);
}

.result-item__actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    padding-top: 8px;
    border-top: 1px dotted var(--border-light);
}

.result-item__link {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: var(--space-sm);
}

.result-item__toolbar {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    gap: var(--space-xs);
    margin-top: var(--space-xs);
}

.result-item__delete {
    margin: 0;
}

.download-link {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--link);
    word-break: break-all;
}

.download-link:hover {
    color: var(--link-hover);
}

.result-list--compact .result-item__meta {
    display: none;
}

@media (min-width: 768px) {
    .result-item__actions {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: flex-start;
        gap: var(--space-sm);
    }

    .result-item__actions {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        justify-content: space-between;
        gap: var(--space-sm);
    }

    .result-item__toolbar {
        margin-top: 0;
    }

    .download-link {
        flex: 1;
        min-width: 0;
    }
}

/* —— Alerts —— */
.alert {
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-sm);
    border: 1px solid;
    font-size: 0.875rem;
}

.alert-error {
    background: var(--danger-bg);
    border-color: #c99;
    color: var(--danger);
}

.alert-success {
    background: var(--success-bg);
    border-color: #9c9;
    color: var(--success);
}

.alert ul {
    margin: 0;
    padding-left: 1.25rem;
}

/* —— Footer —— */
.site-footer {
    margin-top: auto;
    padding: var(--space-lg);
    background: var(--surface);
    border-top: 1px solid var(--border);
}

.footer-support {
    margin: 0 auto;
    max-width: 100%;
    padding-inline: var(--space-md);
    font-size: 11px;
    line-height: 1.4;
    text-align: center;
    color: var(--text-muted);
    white-space: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.footer-support a {
    color: var(--link);
    white-space: nowrap;
}

.footer-support a:hover {
    color: var(--link-hover);
}

.btn-help-nav {
    padding: 0.4rem 0.85rem;
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: var(--radius-sm);
    background: transparent;
    color: #e8eef4;
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

.btn-help-nav:hover {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.page--help .help-doc {
    max-width: 48rem;
    margin: 0 auto;
}

.help-doc__h1 {
    margin: 0 0 var(--space-md);
    font-size: 1.35rem;
    color: var(--heading);
}

.help-doc__h2 {
    margin: var(--space-lg) 0 var(--space-sm);
    padding-top: var(--space-sm);
    border-top: 1px solid var(--border-light);
    font-size: 1.1rem;
    color: var(--heading);
}

.help-doc__h2:first-child {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}

.help-doc__h3 {
    margin: var(--space-md) 0 var(--space-xs);
    font-size: 1rem;
    color: var(--heading);
}

.help-doc__p,
.help-doc__faq-q {
    margin: 0 0 var(--space-sm);
    color: var(--text);
}

.help-doc__faq-q {
    margin-top: var(--space-md);
}

.help-doc__ul,
.help-doc__ol {
    margin: 0 0 var(--space-md);
    padding-left: 1.35rem;
}

.help-doc__ul li,
.help-doc__ol li {
    margin-bottom: 0.35rem;
}

.help-doc__hr {
    margin: var(--space-lg) 0;
    border: none;
    border-top: 1px solid var(--border-light);
}

.help-doc__code {
    padding: 0.1em 0.35em;
    border-radius: 3px;
    background: var(--surface-alt);
    font-family: var(--font-mono);
    font-size: 0.85em;
    word-break: break-all;
}

.help-doc__table-wrap {
    margin: 0 0 var(--space-md);
    overflow-x: auto;
}

.help-doc__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.help-doc__table th,
.help-doc__table td {
    padding: 0.5rem 0.65rem;
    border: 1px solid var(--border-light);
    text-align: left;
    vertical-align: top;
}

.help-doc__table th {
    background: var(--surface-alt);
    font-weight: 600;
    color: var(--heading);
}

.help-doc a {
    color: var(--link);
}

.help-doc a:hover {
    color: var(--link-hover);
}

/* —— Admin panel —— */
.page--admin .admin-panel {
    padding: var(--space-lg);
}

.admin-table-wrap {
    overflow-x: auto;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.admin-table th,
.admin-table td {
    padding: 0.65rem 0.75rem;
    border-bottom: 1px solid var(--border);
    text-align: left;
    vertical-align: top;
}

.admin-table th {
    font-weight: 600;
    color: var(--heading);
    background: var(--surface-muted);
}

.admin-table__row--self {
    background: rgba(0, 51, 102, 0.04);
}

.admin-table--users .admin-table__email {
    min-width: 12rem;
}

.admin-table--users .admin-table__active {
    white-space: nowrap;
    width: 5rem;
}

.admin-table--users .admin-table__storage {
    white-space: nowrap;
    font-size: 0.875rem;
}

.admin-quota-panel {
    max-width: 32rem;
}

.admin-quota-summary {
    display: grid;
    gap: var(--space-sm) var(--space-md);
    margin: 0 0 var(--space-md);
}

.admin-quota-summary > div {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--space-sm);
    align-items: baseline;
}

.admin-quota-summary dt {
    margin: 0;
    font-weight: 600;
    color: var(--heading);
}

.admin-quota-summary dd {
    margin: 0;
    text-align: right;
}

.admin-quota-hint {
    margin: 0 0 var(--space-sm);
    font-size: 0.875rem;
    color: var(--text-muted);
}

.admin-quota-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--border);
}

.admin-quota-form__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.admin-quota-form__input {
    max-width: 10rem;
    padding: 0.5rem 0.65rem;
    border: 1px solid var(--border);
    border-radius: 4px;
}

.admin-quota-form__checkbox {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    cursor: pointer;
}

.admin-quota-form__actions .btn {
    width: auto;
}

.admin-table__empty {
    text-align: center;
    color: var(--text-muted);
    padding: var(--space-lg) !important;
}

.admin-table__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: center;
}

.admin-table__actions form {
    display: inline;
    margin: 0;
}

.admin-table__toolbar {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
}

.admin-table__actions .btn {
    width: auto;
    white-space: nowrap;
    text-decoration: none;
    border: 1px solid #8fa3b8;
    background: #fff;
    color: var(--heading);
    box-sizing: border-box;
}

.admin-table__actions .btn:hover {
    background: #eef2f6;
}

.admin-table__actions .btn--accent {
    border-color: var(--btn-bg);
    background: var(--btn-bg);
    color: #fff;
}

.admin-table__actions .btn--accent:hover {
    background: var(--btn-hover);
    color: #fff;
}

.admin-table__actions .btn--primary {
    border-color: var(--btn-bg);
    background: var(--btn-bg);
    color: #fff;
}

.admin-table__actions .btn--primary:hover {
    background: var(--btn-hover);
    color: #fff;
}

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

.admin-badge {
    display: inline-block;
    margin-left: 0.35rem;
    padding: 0.1rem 0.4rem;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--heading);
    background: var(--surface-muted);
    border-radius: 4px;
}

.admin-files-table__expired {
    opacity: 0.65;
}

.admin-table__date {
    white-space: nowrap;
    font-size: 0.8125rem;
    color: var(--text-muted);
}

.btn--small {
    padding: 0.3rem 0.55rem;
    font-size: 0.75rem;
    line-height: 1.2;
}

/* —— Responsive —— */
@media (max-width: 520px) {
    .chrome {
        grid-template-columns: 1fr;
    }

    .chrome__actions {
        justify-content: flex-end;
        width: 100%;
        padding-top: var(--space-sm);
        border-top: 1px solid rgba(255, 255, 255, 0.15);
    }

    .chrome__eyebrow {
        display: none;
    }
}

@media (min-width: 768px) {
    .panel {
        padding: var(--space-xl);
    }
}
