/* ============================================================
   PerfumerySHK — Utility Classes
   Spacing, Display, Text, Visibility Helpers
   ============================================================ */

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

/* ── Text Alignment ───────────────────────────────────────── */
.text-left    { text-align: left; }
.text-center  { text-align: center; }
.text-right   { text-align: right; }

/* ── Text Utilities ───────────────────────────────────────── */
.text-uppercase  { text-transform: uppercase; }
.text-capitalize { text-transform: capitalize; }
.text-gold    { color: var(--color-gold); }
.text-muted   { color: var(--text-secondary); }
.text-dim     { color: var(--text-tertiary); }
.text-success { color: var(--color-success); }
.text-danger  { color: var(--color-danger); }
.text-warning { color: var(--color-warning); }

.text-xs  { font-size: var(--text-xs); }
.text-sm  { font-size: var(--text-sm); }
.text-base{ font-size: var(--text-base); }
.text-md  { font-size: var(--text-md); }
.text-lg  { font-size: var(--text-lg); }
.text-xl  { font-size: var(--text-xl); }

.font-heading { font-family: var(--font-heading); }
.font-body    { font-family: var(--font-body); }
.font-bold    { font-weight: var(--weight-bold); }
.font-semibold{ font-weight: var(--weight-semibold); }
.font-medium  { font-weight: var(--weight-medium); }

.tracking-wide   { letter-spacing: var(--tracking-wide); }
.tracking-wider  { letter-spacing: var(--tracking-wider); }
.tracking-widest { letter-spacing: var(--tracking-widest); }

.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Spacing ──────────────────────────────────────────────── */
.m-0  { margin: 0; }
.m-auto { margin: auto; }
.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-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); }
.mx-auto { margin-left: auto; margin-right: auto; }

.p-0  { padding: 0; }
.p-2  { padding: var(--space-2); }
.p-3  { padding: var(--space-3); }
.p-4  { padding: var(--space-4); }
.p-6  { padding: var(--space-6); }
.p-8  { padding: var(--space-8); }

/* ── Width / Height ───────────────────────────────────────── */
.w-full  { width: 100%; }
.h-full  { height: 100%; }
.min-h-screen { min-height: 100vh; }

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

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

/* ── Border ───────────────────────────────────────────────── */
.border     { border: var(--border-subtle); }
.border-b   { border-bottom: var(--border-subtle); }
.border-t   { border-top: var(--border-subtle); }
.rounded    { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-full { border-radius: var(--radius-full); }

/* ── Background ───────────────────────────────────────────── */
.bg-primary   { background: var(--bg-primary); }
.bg-secondary { background: var(--bg-secondary); }
.bg-surface   { background: var(--bg-surface); }
.bg-gold      { background: var(--color-gold); }

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

/* ── Object Fit ───────────────────────────────────────────── */
.object-cover   { object-fit: cover; }
.object-contain { object-fit: contain; }

/* ── Aspect Ratio ─────────────────────────────────────────── */
.aspect-square   { aspect-ratio: 1 / 1; }
.aspect-portrait { aspect-ratio: 3 / 4; }
.aspect-landscape{ aspect-ratio: 4 / 3; }
.aspect-wide     { aspect-ratio: 16 / 9; }

/* ── Cursor ───────────────────────────────────────────────── */
.cursor-pointer  { cursor: pointer; }
.pointer-events-none { pointer-events: none; }

/* ── Responsive Visibility ────────────────────────────────── */
@media (max-width: 768px) {
  .hide-mobile { display: none !important; }
}

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

@media (max-width: 480px) {
  .hide-small { display: none !important; }
}

/* ── Animations ───────────────────────────────────────────── */
.animate-fadeIn    { animation: fadeIn var(--duration-slow) var(--ease-out); }
.animate-fadeInUp  { animation: fadeInUp var(--duration-slow) var(--ease-out); }
.animate-slideUp   { animation: slideUp var(--duration-slow) var(--ease-out); }
.animate-scaleIn   { animation: scaleIn var(--duration-slow) var(--ease-spring); }

/* Intersection Observer animated elements */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity var(--duration-slower) var(--ease-out),
              transform var(--duration-slower) var(--ease-out);
}

.reveal--visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal--delay-1 { transition-delay: 100ms; }
.reveal--delay-2 { transition-delay: 200ms; }
.reveal--delay-3 { transition-delay: 300ms; }
.reveal--delay-4 { transition-delay: 400ms; }

/* ── Divider ──────────────────────────────────────────────── */
.divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
  margin: var(--space-8) 0;
}

.divider--gold {
  background: linear-gradient(90deg, transparent, rgba(212,175,55,0.3), transparent);
}
