/* =========================
   SPACING SYSTEM ASSAI
   Padding + Margin Helper
   ========================= */

/* BASE SCALE */
:root {
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 40px;
  --sp-8: 48px;
}

/* =========================
   PADDING
   ========================= */
.p-1 { padding: var(--sp-1) !important; }
.p-2 { padding: var(--sp-2) !important; }
.p-3 { padding: var(--sp-3) !important; }
.p-4 { padding: var(--sp-4) !important; }
.p-5 { padding: var(--sp-5) !important; }
.p-6 { padding: var(--sp-6) !important; }

.pt-1 { padding-top: var(--sp-1) !important; }
.pt-2 { padding-top: var(--sp-2) !important; }
.pt-3 { padding-top: var(--sp-3) !important; }
.pt-4 { padding-top: var(--sp-4) !important; }
.pt-5 { padding-top: var(--sp-5) !important; }

.pb-1 { padding-bottom: var(--sp-1) !important; }
.pb-2 { padding-bottom: var(--sp-2) !important; }
.pb-3 { padding-bottom: var(--sp-3) !important; }
.pb-4 { padding-bottom: var(--sp-4) !important; }
.pb-5 { padding-bottom: var(--sp-5) !important; }

.px-1 { padding-left: var(--sp-1) !important; padding-right: var(--sp-1) !important; }
.px-2 { padding-left: var(--sp-2) !important; padding-right: var(--sp-2) !important; }
.px-3 { padding-left: var(--sp-3) !important; padding-right: var(--sp-3) !important; }
.px-4 { padding-left: var(--sp-4) !important; padding-right: var(--sp-4) !important; }
.px-5 { padding-left: var(--sp-5) !important; padding-right: var(--sp-5) !important; }

.py-1 { padding-top: var(--sp-1) !important; padding-bottom: var(--sp-1) !important; }
.py-2 { padding-top: var(--sp-2) !important; padding-bottom: var(--sp-2) !important; }
.py-3 { padding-top: var(--sp-3) !important; padding-bottom: var(--sp-3) !important; }
.py-4 { padding-top: var(--sp-4) !important; padding-bottom: var(--sp-4) !important; }
.py-5 { padding-top: var(--sp-5) !important; padding-bottom: var(--sp-5) !important; }

/* =========================
   MARGIN
   ========================= */
.m-1 { margin: var(--sp-1) !important; }
.m-2 { margin: var(--sp-2) !important; }
.m-3 { margin: var(--sp-3) !important; }
.m-4 { margin: var(--sp-4) !important; }
.m-5 { margin: var(--sp-5) !important; }
.m-6 { margin: var(--sp-6) !important; }

.mt-1 { margin-top: var(--sp-1) !important; }
.mt-2 { margin-top: var(--sp-2) !important; }
.mt-3 { margin-top: var(--sp-3) !important; }
.mt-4 { margin-top: var(--sp-4) !important; }
.mt-5 { margin-top: var(--sp-5) !important; }

.mb-1 { margin-bottom: var(--sp-1) !important; }
.mb-2 { margin-bottom: var(--sp-2) !important; }
.mb-3 { margin-bottom: var(--sp-3) !important; }
.mb-4 { margin-bottom: var(--sp-4) !important; }
.mb-5 { margin-bottom: var(--sp-5) !important; }

.mx-1 { margin-left: var(--sp-1) !important; margin-right: var(--sp-1) !important; }
.mx-2 { margin-left: var(--sp-2) !important; margin-right: var(--sp-2) !important; }
.mx-3 { margin-left: var(--sp-3) !important; margin-right: var(--sp-3) !important; }
.mx-4 { margin-left: var(--sp-4) !important; margin-right: var(--sp-4) !important; }
.mx-5 { margin-left: var(--sp-5) !important; margin-right: var(--sp-5) !important; }

.my-1 { margin-top: var(--sp-1) !important; margin-bottom: var(--sp-1) !important; }
.my-2 { margin-top: var(--sp-2) !important; margin-bottom: var(--sp-2) !important; }
.my-3 { margin-top: var(--sp-3) !important; margin-bottom: var(--sp-3) !important; }
.my-4 { margin-top: var(--sp-4) !important; margin-bottom: var(--sp-4) !important; }
.my-5 { margin-top: var(--sp-5) !important; margin-bottom: var(--sp-5) !important; }

/* =========================
   RESPONSIVE (LG / MD / SM)
   ========================= */

/* LG (>=992px) */
@media (min-width: 992px) {
  .p-lg-1 { padding: var(--sp-1) !important; }
  .p-lg-2 { padding: var(--sp-2) !important; }
  .p-lg-3 { padding: var(--sp-3) !important; }
  .p-lg-4 { padding: var(--sp-4) !important; }
  .p-lg-5 { padding: var(--sp-5) !important; }

  .m-lg-1 { margin: var(--sp-1) !important; }
  .m-lg-2 { margin: var(--sp-2) !important; }
  .m-lg-3 { margin: var(--sp-3) !important; }
  .m-lg-4 { margin: var(--sp-4) !important; }
  .m-lg-5 { margin: var(--sp-5) !important; }
}

/* MD (>=768px) */
@media (min-width: 768px) {
  .p-md-1 { padding: var(--sp-1) !important; }
  .p-md-2 { padding: var(--sp-2) !important; }
  .p-md-3 { padding: var(--sp-3) !important; }
  .p-md-4 { padding: var(--sp-4) !important; }
  .p-md-5 { padding: var(--sp-5) !important; }

  .m-md-1 { margin: var(--sp-1) !important; }
  .m-md-2 { margin: var(--sp-2) !important; }
  .m-md-3 { margin: var(--sp-3) !important; }
  .m-md-4 { margin: var(--sp-4) !important; }
  .m-md-5 { margin: var(--sp-5) !important; }
}

/* SM (<=767px) */
@media (max-width: 767px) {
  .p-sm-1 { padding: var(--sp-1) !important; }
  .p-sm-2 { padding: var(--sp-2) !important; }
  .p-sm-3 { padding: var(--sp-3) !important; }
  .p-sm-4 { padding: var(--sp-4) !important; }
  .p-sm-5 { padding: var(--sp-5) !important; }

  .m-sm-1 { margin: var(--sp-1) !important; }
  .m-sm-2 { margin: var(--sp-2) !important; }
  .m-sm-3 { margin: var(--sp-3) !important; }
  .m-sm-4 { margin: var(--sp-4) !important; }
  .m-sm-5 { margin: var(--sp-5) !important; }
}

/* GLOBAL MOBILE SAFE SPACING */
@media (max-width: 768px) {
  h1, h2, h3 {
    line-height: 1.2;
  }

  section {
    overflow-x: hidden;
  }
}