/* Hand-rolled utility CSS for the classes used in RAPIDÉ nforce site.
   Mirrors Tailwind defaults for: layout, flex/grid, sizing, spacing, type,
   color (only `text-white`, `text-right`), borders, transitions, and the
   custom bracketed values we use. Static — no runtime generation. */

*, *::before, *::after { box-sizing: border-box; border: 0 solid #e5e7eb; }
html { line-height: 1.5; -webkit-text-size-adjust: 100%; tab-size: 4; }
body { margin: 0; line-height: inherit; }
h1,h2,h3,h4,h5,h6,p { margin: 0; }
ul { list-style: none; padding: 0; margin: 0; }
button { font: inherit; color: inherit; background: transparent; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration: inherit; }
img,svg { display: block; max-width: 100%; height: auto; }

/* layout */
.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}
.inset-0{inset:0}.inset-x-0{left:0;right:0}.top-0{top:0}
.-inset-2{inset:-0.5rem}.-z-10{z-index:-10}.z-50{z-index:50}.z-\[100\]{z-index:100}
.text-center{text-align:center}
.overflow-hidden{overflow:hidden}.pointer-events-none{pointer-events:none}
.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}
.flex{display:flex}.grid{display:grid}.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}
.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-baseline{align-items:baseline}
.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}
.text-right{text-align:right}.uppercase{text-transform:uppercase}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.font-medium{font-weight:500}.font-semibold{font-weight:600}
.transition,.transition-all,.transition-colors{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}
.transition-colors{transition-property:color,background-color,border-color}
.duration-300{transition-duration:.3s}
.mx-auto{margin-left:auto;margin-right:auto}.ml-auto{margin-left:auto}.mt-auto{margin-top:auto}
.group:hover .group-hover\:text-white{color:#fff}

/* gaps */
.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-9{gap:2.25rem}.gap-10{gap:2.5rem}
.gap-x-8{column-gap:2rem}.gap-y-3{row-gap:.75rem}
.space-y-3 > * + *{margin-top:.75rem}

/* widths */
.w-1\.5{width:.375rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-14{width:3.5rem}.w-auto{width:auto}.w-full{width:100%}
/* heights */
.h-px{height:1px}.h-0\.5{height:.125rem}.h-1\.5{height:.375rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-9{height:2.25rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-14{height:3.5rem}.h-full{height:100%}
.h-\[40px\]{height:40px}.h-\[46px\]{height:46px}.h-\[50px\]{height:50px}.h-\[52px\]{height:52px}.h-\[70px\]{height:70px}.h-\[72px\]{height:72px}
.h-\[calc\(100\%-12px\)\]{height:calc(100% - 12px)}.h-\[calc\(100\%-28px\)\]{height:calc(100% - 28px)}

/* max-width */
.max-w-sm{max-width:24rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-xl{max-width:36rem}.max-w-\[1240px\]{max-width:1240px}

/* padding */
.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-7{padding:1.75rem}.p-8{padding:2rem}.p-9{padding:2.25rem}
.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-7{padding-left:1.75rem;padding-right:1.75rem}
.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-24{padding-top:6rem;padding-bottom:6rem}
.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.pt-20{padding-top:5rem}.pt-\[120px\]{padding-top:120px}.pt-\[160px\]{padding-top:160px}
.pb-1{padding-bottom:.25rem}.pb-10{padding-bottom:2.5rem}.pb-14{padding-bottom:3.5rem}.pb-16{padding-bottom:4rem}.pb-24{padding-bottom:6rem}

/* margin */
.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-7{margin-top:1.75rem}.mt-11{margin-top:2.75rem}.mt-9{margin-top:2.25rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-7{margin-bottom:1.75rem}.mb-14{margin-bottom:3.5rem}
.mx-3{margin-left:.75rem;margin-right:.75rem}

/* 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-12{grid-template-columns:repeat(12,minmax(0,1fr))}
.grid-rows-3{grid-template-rows:repeat(3,minmax(0,1fr))}
.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-5{grid-column:span 5/span 5}
.row-span-2{grid-row:span 2/span 2}

/* borders / radius */
.rounded{border-radius:.25rem}.rounded-md{border-radius:.375rem}.rounded-sm{border-radius:.125rem}.rounded-full{border-radius:9999px}
.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}
.rounded-\[8px\]{border-radius:8px}.rounded-\[10px\]{border-radius:10px}.rounded-\[12px\]{border-radius:12px}.rounded-\[16px\]{border-radius:16px}.rounded-\[18px\]{border-radius:18px}.rounded-\[20px\]{border-radius:20px}.rounded-\[24px\]{border-radius:24px}
.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}

/* type */
.text-\[6px\]{font-size:6px}.text-\[6\.5px\]{font-size:6.5px}.text-\[7px\]{font-size:7px}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[11\.5px\]{font-size:11.5px}.text-\[12px\]{font-size:12px}.text-\[12\.5px\]{font-size:12.5px}.text-\[13\.5px\]{font-size:13.5px}.text-\[14px\]{font-size:14px}.text-\[14\.5px\]{font-size:14.5px}.text-\[15px\]{font-size:15px}.text-\[15\.5px\]{font-size:15.5px}.text-\[16px\]{font-size:16px}.text-\[17px\]{font-size:17px}.text-\[18px\]{font-size:18px}.text-\[22px\]{font-size:22px}.text-\[26px\]{font-size:26px}.text-\[28px\]{font-size:28px}.text-\[40px\]{font-size:40px}.text-\[44px\]{font-size:44px}
.text-\[clamp\(44px\,6vw\,84px\)\]{font-size:clamp(44px,6vw,84px)}

.leading-\[1\.02\]{line-height:1.02}.leading-\[1\.04\]{line-height:1.04}.leading-\[1\.05\]{line-height:1.05}.leading-\[1\.08\]{line-height:1.08}.leading-\[1\.55\]{line-height:1.55}.leading-\[1\.6\]{line-height:1.6}
.tracking-\[-0\.01em\]{letter-spacing:-0.01em}.tracking-\[-0\.02em\]{letter-spacing:-0.02em}
.tracking-\[0\.12em\]{letter-spacing:.12em}.tracking-\[0\.14em\]{letter-spacing:.14em}.tracking-\[0\.16em\]{letter-spacing:.16em}.tracking-\[0\.18em\]{letter-spacing:.18em}.tracking-\[0\.2em\]{letter-spacing:.2em}.tracking-\[0\.22em\]{letter-spacing:.22em}

.hover\:text-white:hover{color:#fff}

/* responsive */
@media (min-width: 640px){
  .sm\:inline-block{display:inline-block}
  .sm\:inline-flex{display:inline-flex}
}
@media (min-width: 768px){
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .md\:col-span-1{grid-column:span 1/span 1}
  .md\:gap-6{gap:1.5rem}
  .md\:mb-20{margin-bottom:5rem}
  .md\:p-6{padding:1.5rem}.md\:p-7{padding:1.75rem}.md\:p-9{padding:2.25rem}.md\:p-10{padding:2.5rem}
  .md\:px-5{padding-left:1.25rem;padding-right:1.25rem}.md\:px-10{padding-left:2.5rem;padding-right:2.5rem}
  .md\:py-32{padding-top:8rem;padding-bottom:8rem}
  .md\:pb-16{padding-bottom:4rem}.md\:pb-32{padding-bottom:8rem}
  .md\:pt-\[120px\]{padding-top:120px}.md\:pt-\[180px\]{padding-top:180px}
  .md\:text-\[19px\]{font-size:19px}.md\:text-\[32px\]{font-size:32px}.md\:text-\[56px\]{font-size:56px}.md\:text-\[64px\]{font-size:64px}
}
@media (min-width: 1024px){
  .lg\:flex{display:flex}
  .lg\:hidden{display:none}
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}
  .lg\:col-span-5{grid-column:span 5/span 5}
  .lg\:col-span-7{grid-column:span 7/span 7}
  .lg\:gap-14{gap:3.5rem}
}
