/* ============================================================
   DDR Utils — utility CSS (Tailwind-compatible class names)
   ============================================================ */

/* ============================================================
   DISPLAY
   ============================================================ */
.block        { display: block }
.inline-block { display: inline-block }
.inline       { display: inline }
.hidden       { display: none }
.flex         { display: flex }
.inline-flex  { display: inline-flex }
.grid         { display: grid }
.inline-grid  { display: inline-grid }

/* ============================================================
   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-none    { flex: none }
.flex-shrink-0 { flex-shrink: 0 }
.flex-grow    { flex-grow: 1 }

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

.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 }
.justify-evenly  { justify-content: space-evenly }

.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)) }

.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-full { grid-column: 1 / -1 }

/* ============================================================
   GAP
   ============================================================ */
.gap-0    { gap: 0 }
.gap-1    { gap: 0.25rem }
.gap-2    { gap: 0.5rem }
.gap-3    { gap: 0.75rem }
.gap-4    { gap: 1rem }
.gap-5    { gap: 1.25rem }
.gap-6    { gap: 1.5rem }
.gap-8    { gap: 2rem }
.gap-10   { gap: 2.5rem }
.gap-12   { gap: 3rem }
.gap-16   { gap: 4rem }

.gap-x-0  { column-gap: 0 }
.gap-x-1  { column-gap: 0.25rem }
.gap-x-2  { column-gap: 0.5rem }
.gap-x-3  { column-gap: 0.75rem }
.gap-x-4  { column-gap: 1rem }
.gap-x-5  { column-gap: 1.25rem }
.gap-x-6  { column-gap: 1.5rem }
.gap-x-8  { column-gap: 2rem }
.gap-x-10 { column-gap: 2.5rem }
.gap-x-12 { column-gap: 3rem }
.gap-x-16 { column-gap: 4rem }

.gap-y-0  { row-gap: 0 }
.gap-y-1  { row-gap: 0.25rem }
.gap-y-2  { row-gap: 0.5rem }
.gap-y-3  { row-gap: 0.75rem }
.gap-y-4  { row-gap: 1rem }
.gap-y-5  { row-gap: 1.25rem }
.gap-y-6  { row-gap: 1.5rem }
.gap-y-8  { row-gap: 2rem }
.gap-y-10 { row-gap: 2.5rem }
.gap-y-12 { row-gap: 3rem }
.gap-y-16 { row-gap: 4rem }

/* ============================================================
   PADDING
   ============================================================ */
.p-0    { padding: 0 }
.p-1    { padding: 0.25rem }
.p-2    { padding: 0.5rem }
.p-3    { padding: 0.75rem }
.p-4    { padding: 1rem }
.p-5    { padding: 1.25rem }
.p-6    { padding: 1.5rem }
.p-8    { padding: 2rem }
.p-10   { padding: 2.5rem }
.p-12   { padding: 3rem }
.p-16   { padding: 4rem }
.p-20   { padding: 5rem }
.p-24   { padding: 6rem }

.px-0   { padding-left: 0; padding-right: 0 }
.px-1   { padding-left: 0.25rem; padding-right: 0.25rem }
.px-2   { padding-left: 0.5rem; padding-right: 0.5rem }
.px-3   { padding-left: 0.75rem; padding-right: 0.75rem }
.px-4   { padding-left: 1rem; padding-right: 1rem }
.px-5   { padding-left: 1.25rem; padding-right: 1.25rem }
.px-6   { padding-left: 1.5rem; padding-right: 1.5rem }
.px-8   { padding-left: 2rem; padding-right: 2rem }
.px-10  { padding-left: 2.5rem; padding-right: 2.5rem }
.px-12  { padding-left: 3rem; padding-right: 3rem }
.px-16  { padding-left: 4rem; padding-right: 4rem }
.px-20  { padding-left: 5rem; padding-right: 5rem }
.px-24  { padding-left: 6rem; padding-right: 6rem }

.py-0   { padding-top: 0; padding-bottom: 0 }
.py-1   { padding-top: 0.25rem; padding-bottom: 0.25rem }
.py-2   { padding-top: 0.5rem; padding-bottom: 0.5rem }
.py-3   { padding-top: 0.75rem; padding-bottom: 0.75rem }
.py-4   { padding-top: 1rem; padding-bottom: 1rem }
.py-5   { padding-top: 1.25rem; padding-bottom: 1.25rem }
.py-6   { padding-top: 1.5rem; padding-bottom: 1.5rem }
.py-8   { padding-top: 2rem; padding-bottom: 2rem }
.py-10  { padding-top: 2.5rem; padding-bottom: 2.5rem }
.py-12  { padding-top: 3rem; padding-bottom: 3rem }
.py-16  { padding-top: 4rem; padding-bottom: 4rem }
.py-20  { padding-top: 5rem; padding-bottom: 5rem }
.py-24  { padding-top: 6rem; padding-bottom: 6rem }

.pt-0   { padding-top: 0 }
.pt-1   { padding-top: 0.25rem }
.pt-2   { padding-top: 0.5rem }
.pt-3   { padding-top: 0.75rem }
.pt-4   { padding-top: 1rem }
.pt-5   { padding-top: 1.25rem }
.pt-6   { padding-top: 1.5rem }
.pt-8   { padding-top: 2rem }
.pt-10  { padding-top: 2.5rem }
.pt-12  { padding-top: 3rem }
.pt-16  { padding-top: 4rem }
.pt-20  { padding-top: 5rem }
.pt-24  { padding-top: 6rem }

.pb-0   { padding-bottom: 0 }
.pb-1   { padding-bottom: 0.25rem }
.pb-2   { padding-bottom: 0.5rem }
.pb-3   { padding-bottom: 0.75rem }
.pb-4   { padding-bottom: 1rem }
.pb-5   { padding-bottom: 1.25rem }
.pb-6   { padding-bottom: 1.5rem }
.pb-8   { padding-bottom: 2rem }
.pb-10  { padding-bottom: 2.5rem }
.pb-12  { padding-bottom: 3rem }
.pb-16  { padding-bottom: 4rem }
.pb-20  { padding-bottom: 5rem }
.pb-24  { padding-bottom: 6rem }

.pl-0   { padding-left: 0 }
.pl-1   { padding-left: 0.25rem }
.pl-2   { padding-left: 0.5rem }
.pl-3   { padding-left: 0.75rem }
.pl-4   { padding-left: 1rem }
.pl-5   { padding-left: 1.25rem }
.pl-6   { padding-left: 1.5rem }
.pl-8   { padding-left: 2rem }
.pl-10  { padding-left: 2.5rem }
.pl-12  { padding-left: 3rem }
.pl-16  { padding-left: 4rem }
.pl-20  { padding-left: 5rem }
.pl-24  { padding-left: 6rem }

.pr-0   { padding-right: 0 }
.pr-1   { padding-right: 0.25rem }
.pr-2   { padding-right: 0.5rem }
.pr-3   { padding-right: 0.75rem }
.pr-4   { padding-right: 1rem }
.pr-5   { padding-right: 1.25rem }
.pr-6   { padding-right: 1.5rem }
.pr-8   { padding-right: 2rem }
.pr-10  { padding-right: 2.5rem }
.pr-12  { padding-right: 3rem }
.pr-16  { padding-right: 4rem }
.pr-20  { padding-right: 5rem }
.pr-24  { padding-right: 6rem }

/* ============================================================
   MARGIN
   ============================================================ */
.m-0    { margin: 0 }
.m-1    { margin: 0.25rem }
.m-2    { margin: 0.5rem }
.m-3    { margin: 0.75rem }
.m-4    { margin: 1rem }
.m-5    { margin: 1.25rem }
.m-6    { margin: 1.5rem }
.m-8    { margin: 2rem }
.m-10   { margin: 2.5rem }
.m-12   { margin: 3rem }
.m-16   { margin: 4rem }
.m-20   { margin: 5rem }
.m-24   { margin: 6rem }
.m-auto { margin: auto }

.mx-0    { margin-left: 0; margin-right: 0 }
.mx-1    { margin-left: 0.25rem; margin-right: 0.25rem }
.mx-2    { margin-left: 0.5rem; margin-right: 0.5rem }
.mx-3    { margin-left: 0.75rem; margin-right: 0.75rem }
.mx-4    { margin-left: 1rem; margin-right: 1rem }
.mx-5    { margin-left: 1.25rem; margin-right: 1.25rem }
.mx-6    { margin-left: 1.5rem; margin-right: 1.5rem }
.mx-8    { margin-left: 2rem; margin-right: 2rem }
.mx-10   { margin-left: 2.5rem; margin-right: 2.5rem }
.mx-12   { margin-left: 3rem; margin-right: 3rem }
.mx-16   { margin-left: 4rem; margin-right: 4rem }
.mx-20   { margin-left: 5rem; margin-right: 5rem }
.mx-24   { margin-left: 6rem; margin-right: 6rem }
.mx-auto { margin-left: auto; margin-right: auto }

.my-0    { margin-top: 0; margin-bottom: 0 }
.my-1    { margin-top: 0.25rem; margin-bottom: 0.25rem }
.my-2    { margin-top: 0.5rem; margin-bottom: 0.5rem }
.my-3    { margin-top: 0.75rem; margin-bottom: 0.75rem }
.my-4    { margin-top: 1rem; margin-bottom: 1rem }
.my-5    { margin-top: 1.25rem; margin-bottom: 1.25rem }
.my-6    { margin-top: 1.5rem; margin-bottom: 1.5rem }
.my-8    { margin-top: 2rem; margin-bottom: 2rem }
.my-10   { margin-top: 2.5rem; margin-bottom: 2.5rem }
.my-12   { margin-top: 3rem; margin-bottom: 3rem }
.my-16   { margin-top: 4rem; margin-bottom: 4rem }
.my-20   { margin-top: 5rem; margin-bottom: 5rem }
.my-24   { margin-top: 6rem; margin-bottom: 6rem }
.my-auto { margin-top: auto; margin-bottom: auto }

.mt-0    { margin-top: 0 }
.mt-1    { margin-top: 0.25rem }
.mt-2    { margin-top: 0.5rem }
.mt-3    { margin-top: 0.75rem }
.mt-4    { margin-top: 1rem }
.mt-5    { margin-top: 1.25rem }
.mt-6    { margin-top: 1.5rem }
.mt-8    { margin-top: 2rem }
.mt-10   { margin-top: 2.5rem }
.mt-12   { margin-top: 3rem }
.mt-16   { margin-top: 4rem }
.mt-20   { margin-top: 5rem }
.mt-24   { margin-top: 6rem }
.mt-auto { margin-top: auto }

.mb-0    { margin-bottom: 0 }
.mb-1    { margin-bottom: 0.25rem }
.mb-2    { margin-bottom: 0.5rem }
.mb-3    { margin-bottom: 0.75rem }
.mb-4    { margin-bottom: 1rem }
.mb-5    { margin-bottom: 1.25rem }
.mb-6    { margin-bottom: 1.5rem }
.mb-8    { margin-bottom: 2rem }
.mb-10   { margin-bottom: 2.5rem }
.mb-12   { margin-bottom: 3rem }
.mb-16   { margin-bottom: 4rem }
.mb-20   { margin-bottom: 5rem }
.mb-24   { margin-bottom: 6rem }
.mb-auto { margin-bottom: auto }

.ml-0    { margin-left: 0 }
.ml-1    { margin-left: 0.25rem }
.ml-2    { margin-left: 0.5rem }
.ml-3    { margin-left: 0.75rem }
.ml-4    { margin-left: 1rem }
.ml-5    { margin-left: 1.25rem }
.ml-6    { margin-left: 1.5rem }
.ml-8    { margin-left: 2rem }
.ml-10   { margin-left: 2.5rem }
.ml-12   { margin-left: 3rem }
.ml-16   { margin-left: 4rem }
.ml-20   { margin-left: 5rem }
.ml-24   { margin-left: 6rem }
.ml-auto { margin-left: auto }

.mr-0    { margin-right: 0 }
.mr-1    { margin-right: 0.25rem }
.mr-2    { margin-right: 0.5rem }
.mr-3    { margin-right: 0.75rem }
.mr-4    { margin-right: 1rem }
.mr-5    { margin-right: 1.25rem }
.mr-6    { margin-right: 1.5rem }
.mr-8    { margin-right: 2rem }
.mr-10   { margin-right: 2.5rem }
.mr-12   { margin-right: 3rem }
.mr-16   { margin-right: 4rem }
.mr-20   { margin-right: 5rem }
.mr-24   { margin-right: 6rem }
.mr-auto { margin-right: auto }

/* ============================================================
   WIDTH
   ============================================================ */
.w-0     { width: 0 }
.w-px    { width: 1px }
.w-auto  { width: auto }
.w-full  { width: 100% }
.w-screen { width: 100vw }
.w-fit   { width: fit-content }
.w-min   { width: min-content }
.w-max   { width: max-content }

.w-1\/2  { width: 50% }
.w-1\/3  { width: 33.333333% }
.w-2\/3  { width: 66.666667% }
.w-1\/4  { width: 25% }
.w-3\/4  { width: 75% }
.w-1\/5  { width: 20% }
.w-2\/5  { width: 40% }
.w-3\/5  { width: 60% }
.w-4\/5  { width: 80% }

.w-8     { width: 2rem }
.w-10    { width: 2.5rem }
.w-12    { width: 3rem }
.w-16    { width: 4rem }
.w-20    { width: 5rem }
.w-24    { width: 6rem }
.w-32    { width: 8rem }
.w-40    { width: 10rem }
.w-48    { width: 12rem }
.w-56    { width: 14rem }
.w-64    { width: 16rem }
.w-72    { width: 18rem }
.w-80    { width: 20rem }
.w-96    { width: 24rem }

/* ============================================================
   MAX-WIDTH
   ============================================================ */
.max-w-none  { max-width: none }
.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-7xl   { max-width: 80rem }
.max-w-full  { max-width: 100% }
.max-w-screen-sm  { max-width: 640px }
.max-w-screen-md  { max-width: 768px }
.max-w-screen-lg  { max-width: 1024px }
.max-w-screen-xl  { max-width: 1280px }
.max-w-screen-2xl { max-width: 1536px }

/* ============================================================
   MIN-WIDTH
   ============================================================ */
.min-w-0    { min-width: 0 }
.min-w-full { min-width: 100% }
.min-w-fit  { min-width: fit-content }
.min-w-min  { min-width: min-content }
.min-w-max  { min-width: max-content }

/* ============================================================
   HEIGHT
   ============================================================ */
.h-auto   { height: auto }
.h-full   { height: 100% }
.h-screen { height: 100vh }
.h-fit    { height: fit-content }

.h-1    { height: 0.25rem }
.h-2    { height: 0.5rem }
.h-3    { height: 0.75rem }
.h-4    { height: 1rem }
.h-5    { height: 1.25rem }
.h-6    { height: 1.5rem }
.h-8    { height: 2rem }
.h-10   { height: 2.5rem }
.h-12   { height: 3rem }
.h-16   { height: 4rem }
.h-20   { height: 5rem }
.h-24   { height: 6rem }
.h-32   { height: 8rem }
.h-40   { height: 10rem }
.h-48   { height: 12rem }
.h-56   { height: 14rem }
.h-64   { height: 16rem }

/* ============================================================
   TEXT & TYPOGRAPHY
   ============================================================ */
.text-xs   { font-size: 0.75rem;  line-height: 1rem }
.text-sm   { font-size: 0.875rem; line-height: 1.25rem }
.text-base { font-size: 1rem;     line-height: 1.5rem }
.text-lg   { font-size: 1.125rem; line-height: 1.75rem }
.text-xl   { font-size: 1.25rem;  line-height: 1.75rem }
.text-2xl  { font-size: 1.5rem;   line-height: 2rem }
.text-3xl  { font-size: 1.875rem; line-height: 2.25rem }
.text-4xl  { font-size: 2.25rem;  line-height: 2.5rem }
.text-5xl  { font-size: 3rem;     line-height: 1 }
.text-6xl  { font-size: 3.75rem;  line-height: 1 }

.font-thin       { font-weight: 100 }
.font-extralight { font-weight: 200 }
.font-light      { font-weight: 300 }
.font-normal     { font-weight: 400 }
.font-medium     { font-weight: 500 }
.font-semibold   { font-weight: 600 }
.font-bold       { font-weight: 700 }
.font-extrabold  { font-weight: 800 }
.font-black      { font-weight: 900 }

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

.leading-none    { line-height: 1 }
.leading-tight   { line-height: 1.25 }
.leading-snug    { line-height: 1.375 }
.leading-normal  { line-height: 1.5 }
.leading-relaxed { line-height: 1.625 }
.leading-loose   { line-height: 2 }

.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 }

.underline    { text-decoration-line: underline }
.no-underline { text-decoration-line: none }
.line-through { text-decoration-line: line-through }

.truncate     { overflow: hidden; text-overflow: ellipsis; white-space: nowrap }
.text-wrap    { text-wrap: wrap }
.text-nowrap  { white-space: nowrap }
.whitespace-normal  { white-space: normal }
.whitespace-nowrap  { white-space: nowrap }
.whitespace-pre     { white-space: pre }
.whitespace-pre-wrap { white-space: pre-wrap }

/* ============================================================
   POSITION & OVERFLOW
   ============================================================ */
.static   { position: static }
.relative { position: relative }
.absolute { position: absolute }
.fixed    { position: fixed }
.sticky   { position: sticky }

.overflow-auto    { overflow: auto }
.overflow-hidden  { overflow: hidden }
.overflow-visible { overflow: visible }
.overflow-scroll  { overflow: scroll }
.overflow-x-auto  { overflow-x: auto }
.overflow-y-auto  { overflow-y: auto }
.overflow-x-hidden { overflow-x: hidden }
.overflow-y-hidden { overflow-y: hidden }

/* ============================================================
   BOX SIZING & MISC
   ============================================================ */
.box-border  { box-sizing: border-box }
.box-content { box-sizing: content-box }

.cursor-pointer { cursor: pointer }
.cursor-default { cursor: default }
.cursor-not-allowed { cursor: not-allowed }

.select-none { user-select: none }
.select-text { user-select: text }
.select-all  { user-select: all }

.pointer-events-none { pointer-events: none }
.pointer-events-auto { pointer-events: auto }

.opacity-0   { opacity: 0 }
.opacity-25  { opacity: 0.25 }
.opacity-50  { opacity: 0.5 }
.opacity-75  { opacity: 0.75 }
.opacity-100 { opacity: 1 }

.rounded-none { border-radius: 0 }
.rounded-sm   { border-radius: 0.125rem }
.rounded      { border-radius: 0.25rem }
.rounded-md   { border-radius: 0.375rem }
.rounded-lg   { border-radius: 0.5rem }
.rounded-xl   { border-radius: 0.75rem }
.rounded-2xl  { border-radius: 1rem }
.rounded-full { border-radius: 9999px }

.border-0 { border-width: 0 }
.border   { border-width: 1px }
.border-2 { border-width: 2px }
.border-4 { border-width: 4px }

.list-none { list-style-type: none }
.list-disc { list-style-type: disc }
.list-decimal { list-style-type: decimal }

/* ============================================================
   BOX SHADOW
   ============================================================ */
.shadow-none { box-shadow: none }
.shadow-sm   { box-shadow: 0 1px 2px 0 rgba(0,0,0,.05) }
.shadow      { box-shadow: 0 1px 3px 0 rgba(0,0,0,.1), 0 1px 2px -1px rgba(0,0,0,.1) }
.shadow-md   { box-shadow: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -2px rgba(0,0,0,.1) }
.shadow-lg   { box-shadow: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -4px rgba(0,0,0,.1) }
.shadow-xl   { box-shadow: 0 20px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.1) }
.shadow-2xl  { box-shadow: 0 25px 50px -12px rgba(0,0,0,.25) }
.shadow-inner { box-shadow: inset 0 2px 4px 0 rgba(0,0,0,.05) }

/* ============================================================
   Z-INDEX
   ============================================================ */
.z-0    { z-index: 0 }
.z-10   { z-index: 10 }
.z-20   { z-index: 20 }
.z-30   { z-index: 30 }
.z-40   { z-index: 40 }
.z-50   { z-index: 50 }
.z-auto { z-index: auto }

/* ============================================================
   TRANSITION
   ============================================================ */
.transition-none     { transition-property: none }
.transition          { transition-property: color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter; transition-timing-function: cubic-bezier(.4,0,.2,1); transition-duration: 150ms }
.transition-colors   { transition-property: color,background-color,border-color,text-decoration-color,fill,stroke; transition-timing-function: cubic-bezier(.4,0,.2,1); transition-duration: 150ms }
.transition-opacity  { transition-property: opacity; transition-timing-function: cubic-bezier(.4,0,.2,1); transition-duration: 150ms }
.transition-shadow   { transition-property: box-shadow; transition-timing-function: cubic-bezier(.4,0,.2,1); transition-duration: 150ms }
.transition-transform { transition-property: transform; transition-timing-function: cubic-bezier(.4,0,.2,1); transition-duration: 150ms }

.duration-75   { transition-duration: 75ms }
.duration-100  { transition-duration: 100ms }
.duration-150  { transition-duration: 150ms }
.duration-200  { transition-duration: 200ms }
.duration-300  { transition-duration: 300ms }
.duration-500  { transition-duration: 500ms }
.duration-700  { transition-duration: 700ms }

.ease-linear   { transition-timing-function: linear }
.ease-in       { transition-timing-function: cubic-bezier(.4,0,1,1) }
.ease-out      { transition-timing-function: cubic-bezier(0,0,.2,1) }
.ease-in-out   { transition-timing-function: cubic-bezier(.4,0,.2,1) }

/* ============================================================
   ASPECT RATIO
   ============================================================ */
.aspect-auto    { aspect-ratio: auto }
.aspect-square  { aspect-ratio: 1 / 1 }
.aspect-video   { aspect-ratio: 16 / 9 }
.aspect-4\/3    { aspect-ratio: 4 / 3 }
.aspect-3\/2    { aspect-ratio: 3 / 2 }

/* ============================================================
   OBJECT FIT
   ============================================================ */
.object-contain    { object-fit: contain }
.object-cover      { object-fit: cover }
.object-fill       { object-fit: fill }
.object-none       { object-fit: none }
.object-scale-down { object-fit: scale-down }

.object-center { object-position: center }
.object-top    { object-position: top }
.object-bottom { object-position: bottom }
.object-left   { object-position: left }
.object-right  { object-position: right }

/* ============================================================
   CHOICES.JS DROPDOWN (portal-режим)
   ============================================================ */
/* Search input — на всю ширину дропдауна */
.choices__list--dropdown .choices__input,
.choices__list--dropdown .choices__search input {
    width: 100% !important;
    box-sizing: border-box;
}

/* ============================================================
   CHOICES.JS DROPDOWN SCROLLBAR
   ============================================================ */
.ddr-choices-list::-webkit-scrollbar {
    width: var(--ddr-sb-size, 4px);
}
.ddr-choices-list::-webkit-scrollbar-track {
    background: var(--ddr-sb-track, transparent);
}
.ddr-choices-list::-webkit-scrollbar-thumb {
    background: var(--ddr-sb-thumb, rgba(0, 0, 0, 0.18));
    border-radius: var(--ddr-sb-radius, 4px);
}
.ddr-choices-list::-webkit-scrollbar-thumb:hover {
    background: var(--ddr-sb-hover, rgba(0, 0, 0, 0.30));
}
