/* ==========================================================================
 * 12-колоночная сетка на flexbox
 * ========================================================================== */

.container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--space-lg);
	width: 100%;
}

.row {
	display: flex;
	flex-wrap: wrap;
	margin: 0 calc(-1 * var(--space-md));
}

.col {
	flex: 1;
	padding: 0 var(--space-md);
}

.col-auto { flex: 0 0 auto; max-width: none; }
.col-1  { flex: 0 0 8.333%;  max-width: 8.333%; }
.col-2  { flex: 0 0 16.667%; max-width: 16.667%; }
.col-3  { flex: 0 0 25%;     max-width: 25%; }
.col-4  { flex: 0 0 33.333%; max-width: 33.333%; }
.col-5  { flex: 0 0 41.667%; max-width: 41.667%; }
.col-6  { flex: 0 0 50%;     max-width: 50%; }
.col-7  { flex: 0 0 58.333%; max-width: 58.333%; }
.col-8  { flex: 0 0 66.667%; max-width: 66.667%; }
.col-9  { flex: 0 0 75%;     max-width: 75%; }
.col-10 { flex: 0 0 83.333%; max-width: 83.333%; }
.col-11 { flex: 0 0 91.667%; max-width: 91.667%; }
.col-12 { flex: 0 0 100%;    max-width: 100%; }

/* --- Flex хелперы --- */
.d-flex,
.flex          { display: flex; }
.d-none        { display: none; }
.d-block       { display: block; }
.d-inline      { display: inline; }
.d-inline-block{ display: inline-block; }

.flex-col      { flex-direction: column; }
.flex-wrap     { flex-wrap: wrap; }
.flex-1        { flex: 1; }
.flex-shrink-0 { flex-shrink: 0; }

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

.ml-auto { margin-left: auto; }
.mr-auto { margin-right: auto; }

.gap-xs  { gap: var(--space-xs); }
.gap-sm  { gap: var(--space-sm); }
.gap-md  { gap: var(--space-md); }
.gap-lg  { gap: var(--space-lg); }
.gap-xl  { gap: var(--space-xl); }

/* --- Вспомогательные margin/padding --- */
.mt-xs { margin-top: var(--space-xs); }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mr-1 { margin-right: var(--space-xs); }
.mr-2 { margin-right: var(--space-sm); }
.mr-3 { margin-right: var(--space-md); }
.mr-4 { margin-right: var(--space-lg); }
.ml-1 { margin-left: var(--space-xs); }
.ml-2 { margin-left: var(--space-sm); }
.ml-3 { margin-left: var(--space-md); }
.ml-4 { margin-left: var(--space-lg); }

.pa-sm { padding: var(--space-sm); }
.pa-md { padding: var(--space-md); }
.pa-lg { padding: var(--space-lg); }
.px-sm { padding-left: var(--space-sm); padding-right: var(--space-sm); }
.px-md { padding-left: var(--space-md); padding-right: var(--space-md); }

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

/* --- Цвета текста --- */
.text-muted  { color: var(--color-text-muted); }
.text-primary { color: var(--color-primary); }
.text-success { color: var(--color-success); }
.text-danger  { color: var(--color-danger); }

/* --- Брейкпоинты --- */
@media (min-width: 760px) {
	.d-sm-none        { display: none; }
	.d-sm-block       { display: block; }
	.d-sm-inline      { display: inline; }
	.d-sm-flex        { display: flex; }
	.d-sm-inline-block{ display: inline-block; }
}

@media (min-width: 1024px) {
	.d-md-none        { display: none; }
	.d-md-block       { display: block; }
	.d-md-flex        { display: flex; }
}

@media (min-width: 1264px) {
	.d-lg-block { display: block; }
	.d-lg-flex  { display: flex; }
}
