@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
    /* Custom design tokens used across layouts; keep in sync with Fluent theming where possible */
    --shadow-strong: 0 20px 50px rgba(15, 23, 42, 0.25);
    --shadow-soft: 0 10px 30px rgba(15, 23, 42, 0.16);
    --border-strong: 1px solid rgba(148, 163, 184, 0.7);
}

[data-theme="dark"] {
    /* Dark theme overrides for custom tokens */
    --shadow-strong: 0 24px 60px rgba(0, 0, 0, 0.7);
    --shadow-soft: 0 12px 36px rgba(0, 0, 0, 0.5);
    --border-strong: 1px solid rgba(148, 163, 184, 0.85);
}

[data-theme="dark"] body {
    background-color: #2a2b2d;
    color: #e5e7eb;
}

[data-theme="dark"] .card {
    background: #2a2b2d;
    color: #e5e7eb;
    border-color: #2a2b2d;
    box-shadow: var(--shadow-soft, 0 12px 36px rgba(0, 0, 0, 0.5));
}

[data-theme="dark"] .card .card-header {
    background: #1f2937;
    color: #e5e7eb;
    border-bottom-color: #2a2b2d;
}

[data-theme="dark"] .card .card-body {
    background: transparent;
    color: #e5e7eb;
}

[data-theme="dark"] .bg-light {
    background-color: #2a2b2d !important;
    color: #e5e7eb !important;
    border-color: #2a2b2d !important;
}
* {
    box-sizing: border-box;
}

html, body {
    margin: 0;
    padding: 0;
    min-height: 100vh;
    font-family: var(--body-font, 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif);
    font-size: var(--type-ramp-base-font-size, 16px);
    line-height: var(--type-ramp-base-line-height, 1.6);
    font-weight: var(--font-weight, 400);
    color: var(--neutral-foreground-rest);
    background: var(--neutral-fill-layer-rest);
}

a, .btn-link {
    color: var(--accent-foreground-rest);
    text-decoration: none;
    transition: color 0.15s ease, text-shadow 0.15s ease;
}

a:hover, .btn-link:hover {
    color: var(--accent-foreground-hover, var(--accent-foreground-rest));
    text-shadow: 0 6px 20px rgba(0,0,0,0.08);
}

.btn-primary {
    color: var(--neutral-foreground-on-accent-rest, #ffffff);
    background-color: var(--accent-fill-rest);
    border-color: var(--accent-fill-rest);
    font-weight: 700;
    letter-spacing: 0.01em;
    border-radius: 12px;
    box-shadow: var(--shadow-card, 0 10px 24px rgba(0,0,0,0.12));
}

.btn-primary:hover {
    background-color: var(--accent-fill-hover, var(--accent-fill-rest));
    border-color: var(--accent-fill-hover, var(--accent-fill-rest));
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem rgba(0,0,0,0.1), 0 0 0 0.25rem rgba(0,0,0,0.08);
    outline: none;
}

.content {
    padding-top: 1.1rem;
    background: var(--neutral-layer-1, var(--neutral-fill-layer-rest));
    border: 1px solid var(--neutral-stroke-layer-rest, var(--neutral-stroke-1-rest));
    border-radius: 18px;
    box-shadow: var(--shadow-card, 0 10px 24px rgba(0,0,0,0.12));
    color: var(--neutral-foreground-rest);
}

h1, h2, h3, h4, h5, h6 {
    color: var(--neutral-foreground-rest);
    letter-spacing: 0.01em;
    margin-top: 0;
}

p, label, span, li {
    color: var(--neutral-foreground-rest);
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e76b6b;
}

.validation-message {
    color: #e76b6b;
}

.blazor-error-boundary {
    background: #fff1f1;
    padding: 1rem 1rem 1rem 3.7rem;
    color: #7a1b1b;
    border-radius: 14px;
    border: 1px solid #e87a7a;
    box-shadow: 0 10px 24px rgba(0,0,0,0.12);
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.strikethrough {
    text-decoration: line-through;
}

.progress-summary {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 1rem;
    gap: 1rem;
    background: var(--neutral-layer-2, var(--neutral-fill-layer-rest));
    border: 1px solid var(--neutral-stroke-layer-rest, var(--neutral-stroke-1-rest));
    border-radius: 12px;
}

.flex-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.left-div {
  /*flex: 0 0 auto;*/
}

.right-div {
  flex: 1 1 100%;
  text-align: right;
}

@media (min-width: 600px) {
  .right-div {
    flex: 1;
  }
}

.px-4 {
    padding-left: 0.8rem !important;
    padding-right: 0.8rem !important;
}

@media (max-width: 435px) {
    .flex-container {
        flex-direction: column;
        align-items: stretch;
    }

    .right-div {
        text-align: left;
    }
}

::selection {
    background: var(--accent-fill-hover, rgba(0,0,0,0.15));
    color: var(--neutral-foreground-rest);
}

.company-users-grid::part(row) {
    min-height: 52px;
}

.company-users-grid::part(cell) {
    padding-top: 10px;
    padding-bottom: 10px;
}

/* Fluent grid renders as a table; ensure taller rows without relying on ::part selectors */
.company-users-grid .fluent-data-grid-row {
    min-height: 52px;
    height: auto !important;
}

.company-users-grid th,
.company-users-grid td {
    height: 44px !important;
    padding-top: 10px;
    padding-bottom: 10px;
}