/*
 * SNDESK Design System 2026
 * Source: /SNDeskVisual2026.png
 * Usage: <link rel="stylesheet" href="{{ asset('css/sndesk-design-system.css') }}">
 */

:root {
    color-scheme: light;

    --sndesk-brand-primary: #0f7ade;
    --sndesk-brand-primary-strong: #0d6fc9;
    --sndesk-brand-primary-deep: #0a5ba6;
    --sndesk-brand-cyan: #50cdf9;
    --sndesk-ink: #2c3e50;
    --sndesk-text-muted: #5c6880;
    --sndesk-slate: #737f9b;
    --sndesk-slate-light: #99acc6;
    --sndesk-border: #c0cfe2;
    --sndesk-sky-soft: #e7f3fe;
    --sndesk-surface-muted: #f5f5f7;
    --sndesk-surface: #ffffff;

    --sndesk-danger: #dd4b6b;
    --sndesk-danger-strong: #b93655;
    --sndesk-danger-soft: #fce9ee;
    --sndesk-warning: #faaf3c;
    --sndesk-warning-soft: #fff4de;
    --sndesk-pending: #f9d53e;
    --sndesk-health: #8ec541;
    --sndesk-success: #23aa58;
    --sndesk-success-strong: #16763c;
    --sndesk-success-soft: #e4f6eb;
    --sndesk-purple: #8557ce;
    --sndesk-pink: #ea71b9;

    --sndesk-font-heading: "Source Serif 4", Georgia, serif;
    --sndesk-font-body: "DM Sans", Arial, sans-serif;

    --sndesk-space-1: 0.25rem;
    --sndesk-space-2: 0.5rem;
    --sndesk-space-3: 0.75rem;
    --sndesk-space-4: 1rem;
    --sndesk-space-6: 1.5rem;
    --sndesk-space-8: 2rem;
    --sndesk-space-12: 3rem;
    --sndesk-space-16: 4rem;

    --sndesk-radius-sm: 0.5rem;
    --sndesk-radius-md: 0.75rem;
    --sndesk-radius-lg: 1rem;
    --sndesk-shadow-card: 0 8px 24px rgb(44 62 80 / 8%);
    --sndesk-shadow-overlay: 0 20px 48px rgb(44 62 80 / 18%);

    --sndesk-sidebar-width: 15.5rem;
    --sndesk-sidebar-collapsed: 4.5rem;
    --sndesk-topbar-height: 4rem;
    --sndesk-content-max: 90rem;
    --sndesk-control-height: 2.75rem;
    --sndesk-transition: 160ms ease;
}

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

html {
    min-width: 20rem;
    background: var(--sndesk-surface-muted);
}

body {
    margin: 0;
    color: var(--sndesk-ink);
    background: var(--sndesk-surface-muted);
    font-family: var(--sndesk-font-body);
    font-size: 1rem;
    line-height: 1.5;
    text-rendering: optimizeLegibility;
}

h1,
h2,
.sndesk-display {
    margin: 0;
    color: var(--sndesk-ink);
    font-family: var(--sndesk-font-heading);
    font-weight: 700;
    letter-spacing: -0.02em;
}

h1 {
    font-size: clamp(2rem, 4vw, 2.5rem);
    line-height: 1.2;
}

h2 {
    font-size: 1.5rem;
    line-height: 1.333;
}

h3 {
    margin: 0;
    color: var(--sndesk-ink);
    font-size: 1.25rem;
    line-height: 1.4;
}

a {
    color: var(--sndesk-brand-primary-strong);
    text-decoration-thickness: 0.08em;
    text-underline-offset: 0.18em;
}

a:hover {
    color: var(--sndesk-brand-primary-deep);
}

:where(a, button, input, select, textarea, [tabindex]):focus-visible {
    outline: 3px solid var(--sndesk-brand-primary);
    outline-offset: 3px;
}

::selection {
    color: var(--sndesk-ink);
    background: var(--sndesk-brand-cyan);
}

.sndesk-app-shell {
    display: grid;
    grid-template-columns: var(--sndesk-sidebar-width) minmax(0, 1fr);
    min-height: 100dvh;
}

.sndesk-sidebar {
    position: sticky;
    top: 0;
    z-index: 30;
    display: flex;
    flex-direction: column;
    height: 100dvh;
    padding: var(--sndesk-space-6) var(--sndesk-space-4);
    background: var(--sndesk-surface);
    border-right: 1px solid var(--sndesk-border);
}

.sndesk-main {
    min-width: 0;
}

.sndesk-topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    min-height: var(--sndesk-topbar-height);
    padding: 0 var(--sndesk-space-6);
    background: rgb(255 255 255 / 92%);
    border-bottom: 1px solid var(--sndesk-border);
    backdrop-filter: blur(12px);
}

.sndesk-content {
    width: min(100%, var(--sndesk-content-max));
    margin-inline: auto;
    padding: var(--sndesk-space-8) var(--sndesk-space-6) var(--sndesk-space-12);
}

.sndesk-page-header {
    display: flex;
    gap: var(--sndesk-space-6);
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: var(--sndesk-space-8);
}

.sndesk-page-description {
    max-width: 70ch;
    margin: var(--sndesk-space-2) 0 0;
    color: var(--sndesk-text-muted);
}

.sndesk-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: var(--sndesk-space-6);
}

.sndesk-card {
    padding: var(--sndesk-space-6);
    background: var(--sndesk-surface);
    border: 1px solid var(--sndesk-border);
    border-radius: var(--sndesk-radius-md);
    box-shadow: var(--sndesk-shadow-card);
}

.sndesk-button {
    display: inline-flex;
    min-height: var(--sndesk-control-height);
    align-items: center;
    justify-content: center;
    gap: var(--sndesk-space-2);
    padding: var(--sndesk-space-2) var(--sndesk-space-4);
    border: 1px solid transparent;
    border-radius: var(--sndesk-radius-sm);
    font: 600 0.875rem/1.25rem var(--sndesk-font-body);
    cursor: pointer;
    transition: background-color var(--sndesk-transition), border-color var(--sndesk-transition), color var(--sndesk-transition), transform var(--sndesk-transition);
}

.sndesk-button:active {
    transform: translateY(1px);
}

.sndesk-button:disabled,
.sndesk-button[aria-disabled="true"] {
    cursor: not-allowed;
    opacity: 0.56;
}

.sndesk-button--primary {
    color: var(--sndesk-surface);
    background: var(--sndesk-brand-primary-strong);
}

.sndesk-button--primary:hover {
    background: var(--sndesk-brand-primary-deep);
}

.sndesk-button--secondary {
    color: var(--sndesk-brand-primary-strong);
    background: var(--sndesk-surface);
    border-color: var(--sndesk-brand-primary);
}

.sndesk-button--secondary:hover {
    background: var(--sndesk-sky-soft);
}

.sndesk-button--danger {
    color: var(--sndesk-surface);
    background: var(--sndesk-danger-strong);
}

.sndesk-field {
    display: grid;
    gap: var(--sndesk-space-2);
}

.sndesk-label {
    color: var(--sndesk-ink);
    font-size: 0.875rem;
    font-weight: 600;
}

.sndesk-input,
.sndesk-select,
.sndesk-textarea {
    width: 100%;
    min-height: var(--sndesk-control-height);
    padding: var(--sndesk-space-2) var(--sndesk-space-3);
    color: var(--sndesk-ink);
    background: var(--sndesk-surface);
    border: 1px solid var(--sndesk-slate-light);
    border-radius: var(--sndesk-radius-sm);
    font: inherit;
}

.sndesk-input::placeholder,
.sndesk-textarea::placeholder {
    color: var(--sndesk-slate);
}

.sndesk-input[aria-invalid="true"],
.sndesk-select[aria-invalid="true"],
.sndesk-textarea[aria-invalid="true"] {
    border-color: var(--sndesk-danger-strong);
}

.sndesk-help,
.sndesk-field-error {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.25rem;
}

.sndesk-help {
    color: var(--sndesk-text-muted);
}

.sndesk-field-error {
    color: var(--sndesk-danger-strong);
}

.sndesk-badge {
    display: inline-flex;
    min-height: 1.75rem;
    align-items: center;
    gap: var(--sndesk-space-1);
    padding: 0.25rem 0.625rem;
    color: var(--sndesk-ink);
    background: var(--sndesk-sky-soft);
    border: 1px solid var(--sndesk-border);
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1rem;
}

.sndesk-badge--success {
    color: var(--sndesk-success-strong);
    background: var(--sndesk-success-soft);
    border-color: var(--sndesk-success);
}

.sndesk-badge--warning {
    color: var(--sndesk-ink);
    background: var(--sndesk-warning-soft);
    border-color: var(--sndesk-warning);
}

.sndesk-badge--danger {
    color: var(--sndesk-danger-strong);
    background: var(--sndesk-danger-soft);
    border-color: var(--sndesk-danger);
}

.sndesk-table-wrap {
    overflow-x: auto;
    background: var(--sndesk-surface);
    border: 1px solid var(--sndesk-border);
    border-radius: var(--sndesk-radius-md);
}

.sndesk-table {
    width: 100%;
    border-collapse: collapse;
    font-variant-numeric: tabular-nums;
}

.sndesk-table th,
.sndesk-table td {
    min-height: 3rem;
    padding: var(--sndesk-space-3) var(--sndesk-space-4);
    text-align: left;
    border-bottom: 1px solid var(--sndesk-border);
}

.sndesk-table th {
    color: var(--sndesk-text-muted);
    background: var(--sndesk-surface-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.sndesk-table tbody tr:hover {
    background: var(--sndesk-sky-soft);
}

.sndesk-table tbody tr:last-child td {
    border-bottom: 0;
}

.sndesk-alert {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--sndesk-space-3);
    padding: var(--sndesk-space-4);
    color: var(--sndesk-ink);
    background: var(--sndesk-sky-soft);
    border: 1px solid var(--sndesk-brand-primary);
    border-radius: var(--sndesk-radius-sm);
}

.sndesk-alert--success {
    background: var(--sndesk-success-soft);
    border-color: var(--sndesk-success);
}

.sndesk-alert--danger {
    background: var(--sndesk-danger-soft);
    border-color: var(--sndesk-danger);
}

.sndesk-numeric {
    font-variant-numeric: tabular-nums;
}

.sndesk-muted {
    color: var(--sndesk-text-muted);
}

@media (max-width: 63.99rem) {
    .sndesk-app-shell {
        grid-template-columns: var(--sndesk-sidebar-collapsed) minmax(0, 1fr);
    }

    .sndesk-content {
        padding-inline: var(--sndesk-space-4);
    }

    .sndesk-grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
        gap: var(--sndesk-space-4);
    }
}

@media (max-width: 47.99rem) {
    .sndesk-app-shell {
        display: block;
    }

    .sndesk-sidebar {
        position: fixed;
        inset: 0 auto 0 0;
        width: min(20rem, 88vw);
        transform: translateX(-105%);
        transition: transform var(--sndesk-transition);
    }

    .sndesk-sidebar[data-open="true"] {
        transform: translateX(0);
    }

    .sndesk-topbar {
        padding-inline: var(--sndesk-space-4);
    }

    .sndesk-content {
        padding-block: var(--sndesk-space-6) var(--sndesk-space-8);
    }

    .sndesk-page-header {
        flex-direction: column;
        gap: var(--sndesk-space-4);
    }

    .sndesk-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
    }
}
