/*
 * Utilities — hand-written subset matching Tailwind v4 class names.
 *
 * Design rule: one class does one thing. Values reference tokens.css.
 * State variants (hover, focus, disabled) live in component CSS files, not here.
 */

/* ─── Display ──────────────────────────────────────── */
.block         { display: block; }
.inline-block  { display: inline-block; }
.inline        { display: inline; }
.flex          { display: flex; }
.inline-flex   { display: inline-flex; }
.grid          { display: grid; }
.inline-grid   { display: inline-grid; }
.hidden        { display: none; }

/* ─── Flex ─────────────────────────────────────────── */
.flex-row       { flex-direction: row; }
.flex-col       { flex-direction: column; }
.flex-wrap      { flex-wrap: wrap; }
.flex-nowrap    { flex-wrap: nowrap; }
.flex-1         { flex: 1 1 0%; }
.flex-auto      { flex: 1 1 auto; }
.flex-initial   { flex: 0 1 auto; }
.flex-none      { flex: none; }
.grow           { flex-grow: 1; }
.grow-0         { flex-grow: 0; }
.shrink         { flex-shrink: 1; }
.shrink-0       { flex-shrink: 0; }

.items-start    { align-items: flex-start; }
.items-center   { align-items: center; }
.items-end      { align-items: flex-end; }
.items-baseline { align-items: baseline; }
.items-stretch  { align-items: stretch; }

.justify-start   { justify-content: flex-start; }
.justify-center  { justify-content: center; }
.justify-end     { justify-content: flex-end; }
.justify-between { justify-content: space-between; }
.justify-around  { justify-content: space-around; }

.self-start    { align-self: flex-start; }
.self-center   { align-self: center; }
.self-end      { align-self: flex-end; }
.self-stretch  { align-self: stretch; }

/* ─── Grid ─────────────────────────────────────────── */
.grid-cols-1   { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2   { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3   { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4   { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-cols-5   { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.grid-cols-6   { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.grid-cols-12  { grid-template-columns: repeat(12, minmax(0, 1fr)); }

.col-span-1  { grid-column: span 1 / span 1; }
.col-span-2  { grid-column: span 2 / span 2; }
.col-span-3  { grid-column: span 3 / span 3; }
.col-span-4  { grid-column: span 4 / span 4; }
.col-span-6  { grid-column: span 6 / span 6; }
.col-span-12 { grid-column: span 12 / span 12; }

/* ─── Gap (use instead of space-x/space-y) ─────────── */
.gap-0    { gap: var(--space-0); }
.gap-0\.5 { gap: var(--space-0-5); }
.gap-1    { gap: var(--space-1); }
.gap-1\.5 { gap: var(--space-1-5); }
.gap-2    { gap: var(--space-2); }
.gap-2\.5 { gap: var(--space-2-5); }
.gap-3    { gap: var(--space-3); }
.gap-4    { gap: var(--space-4); }
.gap-5    { gap: var(--space-5); }
.gap-6    { gap: var(--space-6); }
.gap-8    { gap: var(--space-8); }
.gap-10   { gap: var(--space-10); }
.gap-12   { gap: var(--space-12); }

.gap-x-0  { column-gap: 0; }
.gap-x-1  { column-gap: var(--space-1); }
.gap-x-2  { column-gap: var(--space-2); }
.gap-x-3  { column-gap: var(--space-3); }
.gap-x-4  { column-gap: var(--space-4); }
.gap-x-6  { column-gap: var(--space-6); }
.gap-y-0  { row-gap: 0; }
.gap-y-1  { row-gap: var(--space-1); }
.gap-y-2  { row-gap: var(--space-2); }
.gap-y-3  { row-gap: var(--space-3); }
.gap-y-4  { row-gap: var(--space-4); }
.gap-y-6  { row-gap: var(--space-6); }

/* ─── Padding ──────────────────────────────────────── */
.p-0    { padding: var(--space-0); }
.p-0\.5 { padding: var(--space-0-5); }
.p-1    { padding: var(--space-1); }
.p-1\.5 { padding: var(--space-1-5); }
.p-2    { padding: var(--space-2); }
.p-2\.5 { padding: var(--space-2-5); }
.p-3    { padding: var(--space-3); }
.p-3\.5 { padding: var(--space-3-5); }
.p-4    { padding: var(--space-4); }
.p-5    { padding: var(--space-5); }
.p-6    { padding: var(--space-6); }
.p-8    { padding: var(--space-8); }
.p-10   { padding: var(--space-10); }
.p-12   { padding: var(--space-12); }

.px-0    { padding-inline: var(--space-0); }
.px-1    { padding-inline: var(--space-1); }
.px-2    { padding-inline: var(--space-2); }
.px-3    { padding-inline: var(--space-3); }
.px-4    { padding-inline: var(--space-4); }
.px-5    { padding-inline: var(--space-5); }
.px-6    { padding-inline: var(--space-6); }
.px-8    { padding-inline: var(--space-8); }

.py-0    { padding-block: var(--space-0); }
.py-1    { padding-block: var(--space-1); }
.py-1\.5 { padding-block: var(--space-1-5); }
.py-2    { padding-block: var(--space-2); }
.py-2\.5 { padding-block: var(--space-2-5); }
.py-3    { padding-block: var(--space-3); }
.py-4    { padding-block: var(--space-4); }
.py-5    { padding-block: var(--space-5); }
.py-6    { padding-block: var(--space-6); }
.py-8    { padding-block: var(--space-8); }

.pt-0 { padding-top: 0; } .pt-1 { padding-top: var(--space-1); } .pt-2 { padding-top: var(--space-2); } .pt-3 { padding-top: var(--space-3); } .pt-4 { padding-top: var(--space-4); } .pt-6 { padding-top: var(--space-6); } .pt-8 { padding-top: var(--space-8); }
.pr-0 { padding-right: 0; } .pr-1 { padding-right: var(--space-1); } .pr-2 { padding-right: var(--space-2); } .pr-3 { padding-right: var(--space-3); } .pr-4 { padding-right: var(--space-4); } .pr-6 { padding-right: var(--space-6); } .pr-8 { padding-right: var(--space-8); }
.pb-0 { padding-bottom: 0; } .pb-1 { padding-bottom: var(--space-1); } .pb-2 { padding-bottom: var(--space-2); } .pb-3 { padding-bottom: var(--space-3); } .pb-4 { padding-bottom: var(--space-4); } .pb-6 { padding-bottom: var(--space-6); } .pb-8 { padding-bottom: var(--space-8); }
.pl-0 { padding-left: 0; } .pl-1 { padding-left: var(--space-1); } .pl-2 { padding-left: var(--space-2); } .pl-3 { padding-left: var(--space-3); } .pl-4 { padding-left: var(--space-4); } .pl-6 { padding-left: var(--space-6); } .pl-8 { padding-left: var(--space-8); }

/* ─── Margin ───────────────────────────────────────── */
.m-0    { margin: 0; }
.m-auto { margin: auto; }
.mx-0    { margin-inline: 0; }
.mx-1    { margin-inline: var(--space-1); }
.mx-2    { margin-inline: var(--space-2); }
.mx-4    { margin-inline: var(--space-4); }
.mx-auto { margin-inline: auto; }
.my-0    { margin-block: 0; }
.my-1    { margin-block: var(--space-1); }
.my-2    { margin-block: var(--space-2); }
.my-4    { margin-block: var(--space-4); }
.my-6    { margin-block: var(--space-6); }
.my-8    { margin-block: var(--space-8); }
.mt-0 { margin-top: 0; } .mt-1 { margin-top: var(--space-1); } .mt-2 { margin-top: var(--space-2); } .mt-3 { margin-top: var(--space-3); } .mt-4 { margin-top: var(--space-4); } .mt-6 { margin-top: var(--space-6); } .mt-8 { margin-top: var(--space-8); }
.mb-0 { margin-bottom: 0; } .mb-1 { margin-bottom: var(--space-1); } .mb-2 { margin-bottom: var(--space-2); } .mb-3 { margin-bottom: var(--space-3); } .mb-4 { margin-bottom: var(--space-4); } .mb-6 { margin-bottom: var(--space-6); } .mb-8 { margin-bottom: var(--space-8); }
.ml-0 { margin-left: 0; } .ml-1 { margin-left: var(--space-1); } .ml-2 { margin-left: var(--space-2); } .ml-auto { margin-left: auto; }
.mr-0 { margin-right: 0; } .mr-1 { margin-right: var(--space-1); } .mr-2 { margin-right: var(--space-2); } .mr-auto { margin-right: auto; }

/* ─── Sizing ───────────────────────────────────────── */
.w-full   { width: 100%; }
.w-screen { width: 100vw; }
.w-fit    { width: fit-content; }
.w-auto   { width: auto; }
.w-0      { width: 0; }
.w-4      { width: var(--space-4); }
.w-5      { width: var(--space-5); }
.w-6      { width: var(--space-6); }
.w-8      { width: var(--space-8); }
.w-10     { width: var(--space-10); }
.w-12     { width: var(--space-12); }
.w-16     { width: var(--space-16); }
.w-20     { width: var(--space-20); }
.w-24     { width: var(--space-24); }
.w-32     { width: var(--space-32); }
.w-48     { width: 12rem; }
.w-64     { width: 16rem; }
.w-80     { width: 20rem; }
.w-96     { width: 24rem; }

.h-full   { height: 100%; }
.h-screen { height: 100vh; }
.h-fit    { height: fit-content; }
.h-auto   { height: auto; }
.h-0      { height: 0; }
.h-4      { height: var(--space-4); }
.h-5      { height: var(--space-5); }
.h-6      { height: var(--space-6); }
.h-8      { height: var(--space-8); }
.h-10     { height: var(--space-10); }
.h-12     { height: var(--space-12); }
.h-16     { height: var(--space-16); }
.h-20     { height: var(--space-20); }
.h-24     { height: var(--space-24); }
.h-32     { height: var(--space-32); }
.h-64     { height: 16rem; }
.h-96     { height: 24rem; }

/* size-* = equal width & height (shadcn convention) */
.size-3    { width: var(--space-3);  height: var(--space-3); }
.size-3\.5 { width: var(--space-3-5); height: var(--space-3-5); }
.size-4    { width: var(--space-4);  height: var(--space-4); }
.size-5    { width: var(--space-5);  height: var(--space-5); }
.size-6    { width: var(--space-6);  height: var(--space-6); }
.size-8    { width: var(--space-8);  height: var(--space-8); }
.size-10   { width: var(--space-10); height: var(--space-10); }
.size-12   { width: var(--space-12); height: var(--space-12); }

.max-w-xs   { max-width: 20rem; }
.max-w-sm   { max-width: 24rem; }
.max-w-md   { max-width: 28rem; }
.max-w-lg   { max-width: 32rem; }
.max-w-xl   { max-width: 36rem; }
.max-w-2xl  { max-width: 42rem; }
.max-w-3xl  { max-width: 48rem; }
.max-w-4xl  { max-width: 56rem; }
.max-w-5xl  { max-width: 64rem; }
.max-w-6xl  { max-width: 72rem; }
.max-w-full { max-width: 100%; }

.min-h-0      { min-height: 0; }
.min-h-full   { min-height: 100%; }
.min-h-screen { min-height: 100vh; }

/* ─── Typography ───────────────────────────────────── */
.text-xs   { font-size: var(--text-xs);   line-height: calc(var(--text-xs)   + 0.25rem); }
.text-sm   { font-size: var(--text-sm);   line-height: calc(var(--text-sm)   + 0.375rem); }
.text-base { font-size: var(--text-base); line-height: calc(var(--text-base) + 0.5rem); }
.text-lg   { font-size: var(--text-lg);   line-height: calc(var(--text-lg)   + 0.5rem); }
.text-xl   { font-size: var(--text-xl);   line-height: calc(var(--text-xl)   + 0.5rem); }
.text-2xl  { font-size: var(--text-2xl);  line-height: calc(var(--text-2xl)  + 0.5rem); }
.text-3xl  { font-size: var(--text-3xl);  line-height: 1.2; }
.text-4xl  { font-size: var(--text-4xl);  line-height: 1.15; }

.font-normal    { font-weight: 400; }
.font-medium    { font-weight: 500; }
.font-semibold  { font-weight: 600; }
.font-bold      { font-weight: 700; }

.leading-none    { line-height: var(--leading-none); }
.leading-tight   { line-height: var(--leading-tight); }
.leading-snug    { line-height: var(--leading-snug); }
.leading-normal  { line-height: var(--leading-normal); }
.leading-relaxed { line-height: var(--leading-relaxed); }

.tracking-tight   { letter-spacing: var(--tracking-tight); }
.tracking-normal  { letter-spacing: var(--tracking-normal); }
.tracking-wide    { letter-spacing: var(--tracking-wide); }

.text-left    { text-align: left; }
.text-center  { text-align: center; }
.text-right   { text-align: right; }
.text-justify { text-align: justify; }

.uppercase   { text-transform: uppercase; }
.lowercase   { text-transform: lowercase; }
.capitalize  { text-transform: capitalize; }
.normal-case { text-transform: none; }

.italic     { font-style: italic; }
.not-italic { font-style: normal; }

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

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

/* ─── Text color ───────────────────────────────────── */
.text-foreground            { color: var(--color-foreground); }
.text-muted-foreground      { color: var(--color-muted-foreground); }
.text-primary               { color: var(--color-primary); }
.text-primary-foreground    { color: var(--color-primary-foreground); }
.text-secondary-foreground  { color: var(--color-secondary-foreground); }
.text-accent-foreground     { color: var(--color-accent-foreground); }
.text-destructive           { color: var(--color-destructive); }
.text-destructive-foreground{ color: var(--color-destructive-foreground); }
.text-success               { color: var(--color-success); }
.text-success-foreground    { color: var(--color-success-foreground); }
.text-warning               { color: var(--color-warning); }
.text-warning-foreground    { color: var(--color-warning-foreground); }
.text-info                  { color: var(--color-info); }
.text-card-foreground       { color: var(--color-card-foreground); }
.text-popover-foreground    { color: var(--color-popover-foreground); }
.text-inherit               { color: inherit; }

/* ─── Background ───────────────────────────────────── */
.bg-background   { background-color: var(--color-background); }
.bg-card         { background-color: var(--color-card); }
.bg-popover      { background-color: var(--color-popover); }
.bg-primary      { background-color: var(--color-primary); }
.bg-secondary    { background-color: var(--color-secondary); }
.bg-muted        { background-color: var(--color-muted); }
.bg-accent       { background-color: var(--color-accent); }
.bg-destructive  { background-color: var(--color-destructive); }
.bg-success      { background-color: var(--color-success); }
.bg-warning      { background-color: var(--color-warning); }
.bg-info         { background-color: var(--color-info); }
.bg-transparent  { background-color: transparent; }

/* ─── Border ───────────────────────────────────────── */
.border      { border-width: 1px; border-style: solid; border-color: var(--color-border); }
.border-0    { border-width: 0; }
.border-2    { border-width: 2px; border-style: solid; border-color: var(--color-border); }
.border-t    { border-top-width: 1px;    border-top-style: solid;    border-top-color: var(--color-border); }
.border-r    { border-right-width: 1px;  border-right-style: solid;  border-right-color: var(--color-border); }
.border-b    { border-bottom-width: 1px; border-bottom-style: solid; border-bottom-color: var(--color-border); }
.border-l    { border-left-width: 1px;   border-left-style: solid;   border-left-color: var(--color-border); }

.border-border      { border-color: var(--color-border); }
.border-primary     { border-color: var(--color-primary); }
.border-destructive { border-color: var(--color-destructive); }
.border-transparent { border-color: transparent; }

.rounded-none { border-radius: var(--radius-none); }
.rounded-sm   { border-radius: var(--radius-sm); }
.rounded      { border-radius: var(--radius-md); }
.rounded-md   { border-radius: var(--radius-md); }
.rounded-lg   { border-radius: var(--radius-lg); }
.rounded-xl   { border-radius: var(--radius-xl); }
.rounded-2xl  { border-radius: var(--radius-2xl); }
.rounded-full { border-radius: var(--radius-full); }

/* ─── Shadow ───────────────────────────────────────── */
.shadow-none { box-shadow: none; }
.shadow-xs   { box-shadow: var(--shadow-xs); }
.shadow-sm   { box-shadow: var(--shadow-sm); }
.shadow      { box-shadow: var(--shadow-md); }
.shadow-md   { box-shadow: var(--shadow-md); }
.shadow-lg   { box-shadow: var(--shadow-lg); }
.shadow-xl   { box-shadow: var(--shadow-xl); }

/* ─── Position ─────────────────────────────────────── */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed    { position: fixed; }
.sticky   { position: sticky; }
.static   { position: static; }

.inset-0  { inset: 0; }
.top-0    { top: 0; }
.right-0  { right: 0; }
.bottom-0 { bottom: 0; }
.left-0   { left: 0; }

/* ─── Overflow ─────────────────────────────────────── */
.overflow-hidden   { overflow: hidden; }
.overflow-auto     { overflow: auto; }
.overflow-x-auto   { overflow-x: auto; }
.overflow-y-auto   { overflow-y: auto; }
.overflow-x-hidden { overflow-x: hidden; }
.overflow-y-hidden { overflow-y: hidden; }

/* ─── Cursor & interactivity ───────────────────────── */
.cursor-pointer      { cursor: pointer; }
.cursor-not-allowed  { cursor: not-allowed; }
.cursor-default      { cursor: default; }
.pointer-events-none { pointer-events: none; }
.pointer-events-auto { pointer-events: auto; }
.select-none         { user-select: none; }
.select-text         { user-select: text; }

/* ─── Whitespace & text truncation ─────────────────── */
.whitespace-nowrap  { white-space: nowrap; }
.whitespace-normal  { white-space: normal; }
.truncate           { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.break-words        { overflow-wrap: break-word; }

/* ─── Opacity ──────────────────────────────────────── */
.opacity-0   { opacity: 0; }
.opacity-25  { opacity: 0.25; }
.opacity-50  { opacity: 0.5; }
.opacity-75  { opacity: 0.75; }
.opacity-100 { opacity: 1; }

/* ─── Transition ───────────────────────────────────── */
.transition {
    transition-property: color, background-color, border-color, opacity, box-shadow, transform;
    transition-duration: var(--duration-normal);
    transition-timing-function: var(--ease-in-out);
}
.transition-colors {
    transition-property: color, background-color, border-color;
    transition-duration: var(--duration-normal);
    transition-timing-function: var(--ease-in-out);
}
.transition-opacity {
    transition: opacity var(--duration-normal) var(--ease-in-out);
}
.transition-none { transition: none; }

/* ─── Focus ring (reusable interactive focus) ─────── */
.focus-ring:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--color-background), 0 0 0 4px var(--color-ring);
}

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

/* ─── Print ────────────────────────────────────────── */
.print\:hidden { /* applied via @media print */ }
@media print {
    .print\:hidden { display: none !important; }
    .print\:block  { display: block !important; }
}
