/* utilities.css - PRODIGI® Utility Classes                                  */

/* == 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: 0;
}

/* == Text colors ============================================================ */
.text-primary   { color: var(--prodigi-text-primary); }
.text-muted     { color: var(--prodigi-text-muted); }
.text-subtle    { color: var(--prodigi-text-subtle); }
.text-accent    { color: var(--prodigi-magenta); }
.text-cyan      { color: var(--prodigi-cyan); }
.text-white     { color: var(--prodigi-white); }

.text-gradient {
  background: var(--prodigi-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* == Typography ============================================================= */
.text-xs   { font-size: var(--prodigi-text-xs); }
.text-sm   { font-size: var(--prodigi-text-sm); }
.text-base { font-size: var(--prodigi-text-base); }
.text-lg   { font-size: var(--prodigi-text-lg); }
.text-xl   { font-size: var(--prodigi-text-xl); }
.text-2xl  { font-size: var(--prodigi-text-2xl); }
.text-3xl  { font-size: var(--prodigi-text-3xl); }
.text-4xl  { font-size: var(--prodigi-text-4xl); }
.text-5xl  { font-size: var(--prodigi-text-5xl); }

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

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

.uppercase    { text-transform: uppercase; }
.tracking-wide { letter-spacing: 0.05em; }
.tracking-wider { letter-spacing: 0.1em; }
.tracking-widest { letter-spacing: 0.2em; }

.payoff {
  text-transform: uppercase;
  letter-spacing: var(--prodigi-payoff-tracking);
  font-weight: var(--prodigi-payoff-weight);
}

.label {
  font-size: var(--prodigi-label-size);
  font-weight: var(--prodigi-label-weight);
  letter-spacing: var(--prodigi-label-tracking);
  text-transform: var(--prodigi-label-transform);
  color: var(--prodigi-magenta);
}

/* == Spacing ================================================================ */
.mt-0  { margin-top: 0; }
.mt-2  { margin-top: var(--prodigi-space-2); }
.mt-4  { margin-top: var(--prodigi-space-4); }
.mt-6  { margin-top: var(--prodigi-space-6); }
.mt-8  { margin-top: var(--prodigi-space-8); }
.mt-12 { margin-top: var(--prodigi-space-12); }
.mt-16 { margin-top: var(--prodigi-space-16); }

.mb-0  { margin-bottom: 0; }
.mb-2  { margin-bottom: var(--prodigi-space-2); }
.mb-4  { margin-bottom: var(--prodigi-space-4); }
.mb-6  { margin-bottom: var(--prodigi-space-6); }
.mb-8  { margin-bottom: var(--prodigi-space-8); }
.mb-12 { margin-bottom: var(--prodigi-space-12); }

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

.flex-col       { flex-direction: column; }
.flex-wrap      { flex-wrap: wrap; }
.items-center   { align-items: center; }
.items-start    { align-items: flex-start; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-2  { gap: var(--prodigi-space-2); }
.gap-4  { gap: var(--prodigi-space-4); }
.gap-6  { gap: var(--prodigi-space-6); }
.gap-8  { gap: var(--prodigi-space-8); }

/* == Width ================================================================== */
.w-full   { width: 100%; }
.max-w-prose { max-width: var(--prodigi-max-w-prose); }

/* == Position =============================================================== */
.relative { position: relative; }
.absolute { position: absolute; }
.overflow-hidden { overflow: hidden; }

/* == Borders ================================================================ */
.border-top    { border-top: 1px solid var(--prodigi-border); }
.border-bottom { border-bottom: 1px solid var(--prodigi-border); }

/* == Effects ================================================================ */
.glass {
  background: var(--prodigi-glass-bg);
  border: var(--prodigi-glass-border);
  backdrop-filter: var(--prodigi-glass-blur);
  -webkit-backdrop-filter: var(--prodigi-glass-blur);
}



/* == Responsive visibility ================================================== */
@media (max-width: 940px) {
  .hide-mobile { display: none; }
}

@media (min-width: 769px) {
  .hide-desktop { display: none; }
}
