/* ── Google Fonts (Inter) — local ────────────────────────── */
@import url('../fonts/inter-fontface.css');

/* ── Base Reset ─────────────────────────────────────────── */
*, ::before, ::after {
  box-sizing: border-box;
  border-width: 0;
  border-style: solid;
  /* CSS custom properties usadas pelas utilities de transform / filter */
  --tw-translate-x: 0;   --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;        --tw-skew-y: 0;
  --tw-scale-x: 1;       --tw-scale-y: 1;
  --tw-transform: translateX(var(--tw-translate-x)) translateY(var(--tw-translate-y))
                  rotate(var(--tw-rotate))
                  skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y))
                  scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  --tw-blur:; --tw-brightness:; --tw-contrast:;
  --tw-grayscale:; --tw-invert:; --tw-saturate:; --tw-sepia:; --tw-drop-shadow:;
  --tw-backdrop-blur:;
  --tw-shadow: 0 0 #0000;
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
}
html {
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  tab-size: 4;
  font-family: 'Inter', sans-serif;
  scroll-behavior: auto;
}
body { margin: 0; line-height: inherit; }
h1,h2,h3,h4,h5,h6 { font-size: inherit; font-weight: inherit; margin: 0; }
p { margin: 0; }
a { color: inherit; text-decoration: inherit; }
button { cursor: pointer; background: transparent; border: 0; padding: 0; font: inherit; color: inherit; }
img, svg, video { display: block; vertical-align: middle; max-width: 100%; }
picture { display: block; }
.carousel-slide picture { width: 100%; height: 100%; }
[hidden] { display: none; }

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

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

/* ── Inset / TRBL ─────────────────────────────────────────── */
.inset-0  { top:0;right:0;bottom:0;left:0; }
.top-0    { top: 0; }
.top-8    { top: 2rem; }
.top-1\/2 { top: 50%; }
.bottom-0 { bottom: 0; }
.bottom-8 { bottom: 2rem; }
.left-0   { left: 0; }
.left-6   { left: 1.5rem; }
.left-8   { left: 2rem; }
.left-1\/2 { left: 50%; }
.left-1\/4 { left: 25%; }
.right-0  { right: 0; }
.right-6  { right: 1.5rem; }
.right-8  { right: 2rem; }
.right-1\/4  { right: 25%; }
.right-full  { right: 100%; }
.-bottom-8   { bottom: -2rem; }
.-right-4    { right: -1rem; }

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

/* ── Z-index ───────────────────────────────────────────────── */
.z-0 { z-index: 0; }
.z-10 { z-index: 10; }
.z-20 { z-index: 20; }
.z-30 { z-index: 30; }
.z-50 { z-index: 50; }

/* ── Flex ──────────────────────────────────────────────────── */
.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; }
.justify-between { justify-content: space-between; }
.justify-center  { justify-content: center; }
.shrink-0     { flex-shrink: 0; }

/* ── Grid ──────────────────────────────────────────────────── */
.grid-cols-1  { grid-template-columns: repeat(1,minmax(0,1fr)); }

/* ── Gap / Space ───────────────────────────────────────────── */
.gap-1 { gap: 0.25rem; }
.space-x-1 > :not([hidden]) ~ :not([hidden]) { margin-left: 0.25rem; }
.space-y-1 > :not([hidden]) ~ :not([hidden]) { margin-top: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.space-x-2 > :not([hidden]) ~ :not([hidden]) { margin-left: 0.5rem; }
.space-y-2 > :not([hidden]) ~ :not([hidden]) { margin-top: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.space-x-3 > :not([hidden]) ~ :not([hidden]) { margin-left: 0.75rem; }
.space-y-3 > :not([hidden]) ~ :not([hidden]) { margin-top: 0.75rem; }
.gap-4 { gap: 1rem; }
.space-x-4 > :not([hidden]) ~ :not([hidden]) { margin-left: 1rem; }
.space-y-4 > :not([hidden]) ~ :not([hidden]) { margin-top: 1rem; }
.gap-6 { gap: 1.5rem; }
.space-x-6 > :not([hidden]) ~ :not([hidden]) { margin-left: 1.5rem; }
.space-y-6 > :not([hidden]) ~ :not([hidden]) { margin-top: 1.5rem; }
.gap-8 { gap: 2rem; }
.space-x-8 > :not([hidden]) ~ :not([hidden]) { margin-left: 2rem; }
.space-y-8 > :not([hidden]) ~ :not([hidden]) { margin-top: 2rem; }
.gap-10 { gap: 2.5rem; }
.space-x-10 > :not([hidden]) ~ :not([hidden]) { margin-left: 2.5rem; }
.space-y-10 > :not([hidden]) ~ :not([hidden]) { margin-top: 2.5rem; }
.gap-12 { gap: 3rem; }
.space-x-12 > :not([hidden]) ~ :not([hidden]) { margin-left: 3rem; }
.space-y-12 > :not([hidden]) ~ :not([hidden]) { margin-top: 3rem; }
.gap-16 { gap: 4rem; }
.space-x-16 > :not([hidden]) ~ :not([hidden]) { margin-left: 4rem; }
.space-y-16 > :not([hidden]) ~ :not([hidden]) { margin-top: 4rem; }

/* ── Padding ───────────────────────────────────────────────── */
.p-0  { padding: 0; }
.px-0 { padding-left: 0; padding-right: 0; }
.py-0 { padding-top: 0; padding-bottom: 0; }
.pt-0 { padding-top: 0; }
.pb-0 { padding-bottom: 0; }
.p-0\.5  { padding: 0.125rem; }
.px-0\.5 { padding-left: 0.125rem; padding-right: 0.125rem; }
.py-0\.5 { padding-top: 0.125rem; padding-bottom: 0.125rem; }
.pt-0\.5 { padding-top: 0.125rem; }
.pb-0\.5 { padding-bottom: 0.125rem; }
.p-1  { padding: 0.25rem; }
.px-1 { padding-left: 0.25rem; padding-right: 0.25rem; }
.py-1 { padding-top: 0.25rem; padding-bottom: 0.25rem; }
.pt-1 { padding-top: 0.25rem; }
.pb-1 { padding-bottom: 0.25rem; }
.p-1\.5  { padding: 0.375rem; }
.px-1\.5 { padding-left: 0.375rem; padding-right: 0.375rem; }
.py-1\.5 { padding-top: 0.375rem; padding-bottom: 0.375rem; }
.pt-1\.5 { padding-top: 0.375rem; }
.pb-1\.5 { padding-bottom: 0.375rem; }
.p-2  { padding: 0.5rem; }
.px-2 { padding-left: 0.5rem; padding-right: 0.5rem; }
.py-2 { padding-top: 0.5rem; padding-bottom: 0.5rem; }
.pt-2 { padding-top: 0.5rem; }
.pb-2 { padding-bottom: 0.5rem; }
.p-2\.5  { padding: 0.625rem; }
.px-2\.5 { padding-left: 0.625rem; padding-right: 0.625rem; }
.py-2\.5 { padding-top: 0.625rem; padding-bottom: 0.625rem; }
.pt-2\.5 { padding-top: 0.625rem; }
.pb-2\.5 { padding-bottom: 0.625rem; }
.p-3  { padding: 0.75rem; }
.px-3 { padding-left: 0.75rem; padding-right: 0.75rem; }
.py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
.pt-3 { padding-top: 0.75rem; }
.pb-3 { padding-bottom: 0.75rem; }
.p-3\.5  { padding: 0.875rem; }
.px-3\.5 { padding-left: 0.875rem; padding-right: 0.875rem; }
.py-3\.5 { padding-top: 0.875rem; padding-bottom: 0.875rem; }
.pt-3\.5 { padding-top: 0.875rem; }
.pb-3\.5 { padding-bottom: 0.875rem; }
.p-4  { padding: 1rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.py-4 { padding-top: 1rem; padding-bottom: 1rem; }
.pt-4 { padding-top: 1rem; }
.pb-4 { padding-bottom: 1rem; }
.p-5  { padding: 1.25rem; }
.px-5 { padding-left: 1.25rem; padding-right: 1.25rem; }
.py-5 { padding-top: 1.25rem; padding-bottom: 1.25rem; }
.pt-5 { padding-top: 1.25rem; }
.pb-5 { padding-bottom: 1.25rem; }
.p-6  { padding: 1.5rem; }
.px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
.py-6 { padding-top: 1.5rem; padding-bottom: 1.5rem; }
.pt-6 { padding-top: 1.5rem; }
.pb-6 { padding-bottom: 1.5rem; }
.p-7  { padding: 1.75rem; }
.px-7 { padding-left: 1.75rem; padding-right: 1.75rem; }
.py-7 { padding-top: 1.75rem; padding-bottom: 1.75rem; }
.pt-7 { padding-top: 1.75rem; }
.pb-7 { padding-bottom: 1.75rem; }
.p-8  { padding: 2rem; }
.px-8 { padding-left: 2rem; padding-right: 2rem; }
.py-8 { padding-top: 2rem; padding-bottom: 2rem; }
.pt-8 { padding-top: 2rem; }
.pb-8 { padding-bottom: 2rem; }
.p-16  { padding: 4rem; }
.px-16 { padding-left: 4rem; padding-right: 4rem; }
.py-16 { padding-top: 4rem; padding-bottom: 4rem; }
.pt-16 { padding-top: 4rem; }
.pb-16 { padding-bottom: 4rem; }
.p-24  { padding: 6rem; }
.px-24 { padding-left: 6rem; padding-right: 6rem; }
.py-24 { padding-top: 6rem; padding-bottom: 6rem; }
.pt-24 { padding-top: 6rem; }
.pb-24 { padding-bottom: 6rem; }
.p-28  { padding: 7rem; }
.px-28 { padding-left: 7rem; padding-right: 7rem; }
.py-28 { padding-top: 7rem; padding-bottom: 7rem; }
.pt-28 { padding-top: 7rem; }
.pb-28 { padding-bottom: 7rem; }
.p-32  { padding: 8rem; }
.px-32 { padding-left: 8rem; padding-right: 8rem; }
.py-32 { padding-top: 8rem; padding-bottom: 8rem; }
.pt-32 { padding-top: 8rem; }
.pb-32 { padding-bottom: 8rem; }

/* ── Margin ────────────────────────────────────────────────── */
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.ml-0 { margin-left: 0; }
.mr-0 { margin-right: 0; }
.mt-0\.5 { margin-top: 0.125rem; }
.mb-0\.5 { margin-bottom: 0.125rem; }
.ml-0\.5 { margin-left: 0.125rem; }
.mr-0\.5 { margin-right: 0.125rem; }
.mt-1 { margin-top: 0.25rem; }
.mb-1 { margin-bottom: 0.25rem; }
.ml-1 { margin-left: 0.25rem; }
.mr-1 { margin-right: 0.25rem; }
.mt-1\.5 { margin-top: 0.375rem; }
.mb-1\.5 { margin-bottom: 0.375rem; }
.ml-1\.5 { margin-left: 0.375rem; }
.mr-1\.5 { margin-right: 0.375rem; }
.mt-2 { margin-top: 0.5rem; }
.mb-2 { margin-bottom: 0.5rem; }
.ml-2 { margin-left: 0.5rem; }
.mr-2 { margin-right: 0.5rem; }
.mt-3 { margin-top: 0.75rem; }
.mb-3 { margin-bottom: 0.75rem; }
.ml-3 { margin-left: 0.75rem; }
.mr-3 { margin-right: 0.75rem; }
.mt-4 { margin-top: 1rem; }
.mb-4 { margin-bottom: 1rem; }
.ml-4 { margin-left: 1rem; }
.mr-4 { margin-right: 1rem; }
.mt-5 { margin-top: 1.25rem; }
.mb-5 { margin-bottom: 1.25rem; }
.ml-5 { margin-left: 1.25rem; }
.mr-5 { margin-right: 1.25rem; }
.mt-6 { margin-top: 1.5rem; }
.mb-6 { margin-bottom: 1.5rem; }
.ml-6 { margin-left: 1.5rem; }
.mr-6 { margin-right: 1.5rem; }
.mt-8 { margin-top: 2rem; }
.mb-8 { margin-bottom: 2rem; }
.ml-8 { margin-left: 2rem; }
.mr-8 { margin-right: 2rem; }
.mt-10 { margin-top: 2.5rem; }
.mb-10 { margin-bottom: 2.5rem; }
.ml-10 { margin-left: 2.5rem; }
.mr-10 { margin-right: 2.5rem; }
.mt-16 { margin-top: 4rem; }
.mb-16 { margin-bottom: 4rem; }
.ml-16 { margin-left: 4rem; }
.mr-16 { margin-right: 4rem; }
.mt-20 { margin-top: 5rem; }
.mb-20 { margin-bottom: 5rem; }
.ml-20 { margin-left: 5rem; }
.mr-20 { margin-right: 5rem; }
.mx-auto { margin-left: auto; margin-right: auto; }

/* ── Width ─────────────────────────────────────────────────── */
.w-0      { width: 0px; }
.w-3      { width: 0.75rem; }
.w-4      { width: 1rem; }
.w-5      { width: 1.25rem; }
.w-6      { width: 1.5rem; }
.w-7      { width: 1.75rem; }
.w-8      { width: 2rem; }
.w-9      { width: 2.25rem; }
.w-10     { width: 2.5rem; }
.w-12     { width: 3rem; }
.w-16     { width: 4rem; }
.w-24     { width: 6rem; }
.w-auto   { width: auto; }
.w-full   { width: 100%; }
.w-\[500px\] { width: 500px; }
.w-\[600px\] { width: 600px; }
.w-1\/2  { width: 50%; }

/* ── Height ────────────────────────────────────────────────── */
.h-1      { height: 0.25rem; }
.h-3      { height: 0.75rem; }
.h-4      { height: 1rem; }
.h-5      { height: 1.25rem; }
.h-6      { height: 1.5rem; }
.h-7      { height: 1.75rem; }
.h-8      { height: 2rem; }
.h-9      { height: 2.25rem; }
.h-10     { height: 2.5rem; }
.h-12     { height: 3rem; }
.h-16     { height: 4rem; }
.h-20     { height: 5rem; }
.h-24     { height: 6rem; }
.h-56     { height: 14rem; }
.h-full   { height: 100%; }
.h-screen { height: 100vh; }
.h-\[2px\]   { height: 2px; }
.h-\[3px\]   { height: 3px; }
.h-\[420px\] { height: 420px; }
.h-\[450px\] { height: 450px; }
.h-\[500px\] { height: 500px; }
.h-\[550px\] { height: 550px; }
.h-\[600px\] { height: 600px; }

/* ── Max Width ─────────────────────────────────────────────── */
.max-w-xs      { max-width: 20rem; }
.max-w-sm      { max-width: 24rem; }
.max-w-xl      { max-width: 36rem; }
.max-w-2xl     { max-width: 42rem; }
.max-w-3xl     { max-width: 48rem; }
.max-w-7xl     { max-width: 80rem; }
.max-w-\[280px\] { max-width: 280px; }

/* ── Typography ────────────────────────────────────────────── */
.text-xs { font-size: 0.75rem; line-height: 1.5; }
.text-sm { font-size: 0.875rem; line-height: 1.5; }
.text-base { font-size: 1rem; line-height: 1.5; }
.text-lg { font-size: 1.125rem; line-height: 1.5; }
.text-xl { font-size: 1.25rem; line-height: 1.5; }
.text-2xl { font-size: 1.5rem; line-height: 1.5; }
.text-3xl { font-size: 1.875rem; line-height: 1.5; }
.text-4xl { font-size: 2.25rem; line-height: 1.5; }
.text-5xl { font-size: 3rem; line-height: 1.5; }
.text-6xl { font-size: 3.75rem; line-height: 1.5; }
.text-8xl { font-size: 6rem; line-height: 1.5; }
.text-\[8px\]  { font-size: 8px; }
.text-\[9px\]  { font-size: 9px; }
.text-\[10px\] { font-size: 10px; }
.text-\[12px\] { font-size: 12px; }
.text-\[14px\] { font-size: 14px; }
.text-\[26px\] { font-size: 26px; }
.font-light     { font-weight: 300; }
.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; }
.font-sans      { font-family: 'Inter', sans-serif; }
.italic         { font-style: italic; }
.uppercase      { text-transform: uppercase; }
.text-left      { text-align: left; }
.text-center    { text-align: center; }
.leading-none    { line-height: 1; }
.leading-tight   { line-height: 1.25; }
.leading-relaxed { line-height: 1.625; }
.tracking-tight   { letter-spacing: -0.05em; }
.tracking-wide    { letter-spacing: 0.025em; }
.tracking-wider   { letter-spacing: 0.05em; }
.tracking-widest  { letter-spacing: 0.1em; }
.antialiased { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.truncate       { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.whitespace-nowrap { white-space: nowrap; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border-width: 0; }

/* ── Text Colors ────────────────────────────────────────────── */
.text-white { color: #fff; }
.text-transparent { color: transparent; }
.text-slate-100 { color: rgb(241 245 249); }
.text-slate-300 { color: rgb(203 213 225); }
.text-slate-400 { color: rgb(148 163 184); }
.text-slate-500 { color: rgb(100 116 139); }
.text-slate-600 { color: rgb(71 85 105); }
.text-ice-400 { color: rgb(34 211 238); }
.text-ice-500 { color: rgb(6 182 212); }
.text-red-400 { color: rgb(248 113 113); }
.text-red-500 { color: rgb(239 68 68); }
.text-emerald-400 { color: rgb(52 211 153); }
.text-purple-400 { color: rgb(192 132 252); }
.text-dark-950 { color: rgb(2 6 23); }
.text-white\/60 { color: rgb(255 255 255 / 0.6); }
.text-white\/70 { color: rgb(255 255 255 / 0.7); }
.text-white\/\[0\.01\] { color: rgb(255 255 255 / 0.01); }

/* ── Background Colors ─────────────────────────────────────── */
.bg-dark-900 { background-color: rgb(15 23 42); }
.bg-dark-950 { background-color: rgb(2 6 23); }
.bg-dark-800 { background-color: rgb(30 41 59); }
.bg-ice-400 { background-color: rgb(34 211 238); }
.bg-ice-500 { background-color: rgb(6 182 212); }
.bg-ice-950 { background-color: rgb(8 51 68); }
.bg-emerald-500 { background-color: rgb(16 185 129); }
.bg-purple-500 { background-color: rgb(168 85 247); }
.bg-red-500 { background-color: rgb(239 68 68); }
.bg-\[\#25D366\]      { background-color: #25D366; }
.bg-\[\#25D366\]\/\[0\.01\] { background-color: rgb(37 211 102 / 0.01); }
.bg-dark-950\/40  { background-color: rgb(2 6 23 / 0.4); }
.bg-dark-950\/80  { background-color: rgb(2 6 23 / 0.8); }
.bg-dark-950\/90  { background-color: rgb(2 6 23 / 0.9); }
.bg-ice-500\/5    { background-color: rgb(6 182 212 / 0.05); }
.bg-ice-500\/\[0\.01\] { background-color: rgb(6 182 212 / 0.01); }
.bg-ice-500\/\[0\.02\] { background-color: rgb(6 182 212 / 0.02); }
.bg-ice-950\/50   { background-color: rgb(8 51 68 / 0.5); }
.bg-ice-950\/60   { background-color: rgb(8 51 68 / 0.6); }
.bg-emerald-950\/50 { background-color: rgb(2 44 34 / 0.5); }
.bg-purple-950\/50 { background-color: rgb(59 7 100 / 0.5); }
.bg-red-950\/50   { background-color: rgb(69 10 10 / 0.5); }
.bg-red-950\/70   { background-color: rgb(69 10 10 / 0.7); }
.bg-white\/10  { background-color: rgb(255 255 255 / 0.1); }
.bg-white\/20  { background-color: rgb(255 255 255 / 0.2); }
.bg-white\/5   { background-color: rgb(255 255 255 / 0.05); }
.bg-white\/\[0\.01\] { background-color: rgb(255 255 255 / 0.01); }

/* ── Gradients ─────────────────────────────────────────────── */
.bg-gradient-to-t  { background-image: linear-gradient(to top, var(--tw-gradient-stops)); }
.bg-gradient-to-r  { background-image: linear-gradient(to right, var(--tw-gradient-stops)); }
.bg-gradient-to-br { background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)); }
.bg-gradient-to-tr { background-image: linear-gradient(to top right, var(--tw-gradient-stops)); }
.bg-clip-text      { -webkit-background-clip: text; background-clip: text; }
.text-transparent  { color: transparent; }
.from-dark-900 { --tw-gradient-from: rgb(15 23 42); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent); }
.from-dark-950 { --tw-gradient-from: rgb(2 6 23); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent); }
.from-emerald-400 { --tw-gradient-from: rgb(52 211 153); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent); }
.from-ice-400 { --tw-gradient-from: rgb(34 211 238); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent); }
.from-purple-400 { --tw-gradient-from: rgb(192 132 252); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent); }
.from-red-400 { --tw-gradient-from: rgb(248 113 113); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent); }
.from-transparent { --tw-gradient-from: transparent; --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent); }
.from-white { --tw-gradient-from: #fff; --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to, transparent); }
.to-blue-400 { --tw-gradient-to: rgb(96 165 250); }
.to-dark-900\/60 { --tw-gradient-to: rgb(15 23 42 / 0.6); }
.to-dark-950 { --tw-gradient-to: rgb(2 6 23); }
.to-dark-950\/40 { --tw-gradient-to: rgb(2 6 23 / 0.4); }
.to-green-400 { --tw-gradient-to: rgb(74 222 128); }
.to-ice-300 { --tw-gradient-to: rgb(103 232 249); }
.to-orange-400 { --tw-gradient-to: rgb(251 146 60); }
.to-transparent { --tw-gradient-to: transparent; }
.to-violet-400 { --tw-gradient-to: rgb(167 139 250); }
.via-dark-950\/70 { --tw-gradient-stops: var(--tw-gradient-from), rgb(2 6 23 / 0.7), var(--tw-gradient-to, transparent); }
.via-white\/15 { --tw-gradient-stops: var(--tw-gradient-from), rgb(255 255 255 / 0.15), var(--tw-gradient-to, transparent); }
.via-\[\#F25A24\] { --tw-gradient-stops: var(--tw-gradient-from), rgb(242 90 36), var(--tw-gradient-to, transparent); }

/* ── Border ────────────────────────────────────────────────── */
.border   { border-width: 1px; }
.border-2 { border-width: 2px; }
.border-t { border-top-width: 1px; }
.border-b { border-bottom-width: 1px; }
.border-b-2 { border-bottom-width: 2px; }
.border-transparent { border-color: transparent; }
.border-white\/5 { border-color: rgb(255 255 255 / 0.05); }
.border-white\/10 { border-color: rgb(255 255 255 / 0.1); }
.border-white\/15 { border-color: rgb(255 255 255 / 0.15); }
.border-ice-500 { border-color: rgb(6 182 212); }
.border-ice-500\/10 { border-color: rgb(6 182 212 / 0.1); }
.border-ice-500\/20 { border-color: rgb(6 182 212 / 0.2); }
.border-ice-500\/30 { border-color: rgb(6 182 212 / 0.3); }
.border-emerald-500\/20 { border-color: rgb(16 185 129 / 0.2); }
.border-purple-500\/20 { border-color: rgb(168 85 247 / 0.2); }
.border-red-500\/20 { border-color: rgb(239 68 68 / 0.2); }
.border-red-500\/40 { border-color: rgb(239 68 68 / 0.4); }

/* ── Border Radius ─────────────────────────────────────────── */
.rounded-full      { border-radius: 9999px; }
.rounded-lg        { border-radius: 0.5rem; }
.rounded-xl        { border-radius: 0.75rem; }
.rounded-2xl       { border-radius: 1rem; }
.rounded-3xl       { border-radius: 1.5rem; }
.rounded-\[2rem\]  { border-radius: 2rem; }
.rounded-\[2\.5rem\] { border-radius: 2.5rem; }

/* ── Shadow ────────────────────────────────────────────────── */
.shadow-lg  { box-shadow: 0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1); }
.shadow-xl  { box-shadow: 0 20px 25px -5px rgb(0 0 0/.1),0 8px 10px -6px rgb(0 0 0/.1); }
.shadow-2xl { box-shadow: 0 25px 50px -12px rgb(0 0 0/.25); }
.shadow-ice-500\/20  { box-shadow: 0 10px 15px -3px rgb(6 182 212 / 0.2); }
.shadow-red-950\/50  { box-shadow: 0 10px 15px -3px rgb(69 10 10 / 0.5); }
.shadow-\[\#25D366\]\/10 { box-shadow: 0 10px 15px -3px rgb(37 211 102 / 0.1); }
.shadow-\[\#25D366\]\/20 { box-shadow: 0 20px 25px -5px rgb(37 211 102 / 0.2); }

/* ── Opacity ───────────────────────────────────────────────── */
.opacity-0    { opacity: 0; }

/* ── Filter / Backdrop ─────────────────────────────────────── */
.filter { filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow); }
.blur-\[120px\] { --tw-blur: blur(120px); filter: var(--tw-blur); }
.blur-\[140px\] { --tw-blur: blur(140px); filter: var(--tw-blur); }
.brightness-\[0\.35\] { --tw-brightness: brightness(0.35); filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast); }
.brightness-\[0\.9\]  { --tw-brightness: brightness(0.9);  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast); }
.contrast-\[1\.05\]   { --tw-contrast: contrast(1.05);    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast); }
.backdrop-blur-md { -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); }
.backdrop-blur-sm { -webkit-backdrop-filter: blur(4px);  backdrop-filter: blur(4px); }

/* ── Transform ─────────────────────────────────────────────── */
.transform  { transform: var(--tw-transform); }
.-translate-x-1\/2 { --tw-translate-x: -50%; transform: var(--tw-transform); }
.-translate-y-1\/2 { --tw-translate-y: -50%; transform: var(--tw-transform); }

/* ── Transition ─────────────────────────────────────────────── */
.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-all    { transition-property: all; transition-timing-function: cubic-bezier(.4,0,.2,1); transition-duration: 150ms; }
.transition-colors { transition-property: color,background-color,border-color; 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-200 { transition-duration: 200ms; }
.duration-300 { transition-duration: 300ms; }
.duration-500 { transition-duration: 500ms; }
.duration-1000 { transition-duration: 1000ms; }

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

/* ── Pointer / Cursor / Select ──────────────────────────────── */
.pointer-events-none { pointer-events: none; }
.cursor-pointer      { cursor: pointer; }
.select-none         { user-select: none; -webkit-user-select: none; }

/* ── Misc ───────────────────────────────────────────────────── */
.scroll-smooth { scroll-behavior: smooth; }
.italic        { font-style: italic; }
.group         {}

/* ── Hover ──────────────────────────────────────────────────── */
.hover\:bg-\[\#128C7E\]:hover { background-color: #128C7E; }
.hover\:bg-\[\#F25A24\]\/\[0\.02\]:hover { background-color: rgb(242 90 36 / 0.02); }
.hover\:bg-dark-900:hover { background-color: rgb(15 23 42); }
.hover\:bg-dark-950\/75:hover { background-color: rgb(2 6 23 / 0.75); }
.hover\:bg-emerald-400:hover { background-color: rgb(52 211 153); }
.hover\:bg-ice-400:hover { background-color: rgb(34 211 238); }
.hover\:bg-purple-400:hover { background-color: rgb(192 132 252); }
.hover\:bg-red-400:hover { background-color: rgb(248 113 113); }
.hover\:bg-white\/20:hover { background-color: rgb(255 255 255 / 0.2); }
.hover\:bg-white\/40:hover { background-color: rgb(255 255 255 / 0.4); }
.hover\:bg-white\/5:hover { background-color: rgb(255 255 255 / 0.05); }
.hover\:border-\[\#F25A24\]\/30:hover { border-color: rgb(242 90 36 / 0.3); }
.hover\:border-ice-500\/30:hover { border-color: rgb(6 182 212 / 0.3); }
.hover\:border-white\/25:hover { border-color: rgb(255 255 255 / 0.25); }
.hover\:text-ice-400:hover { color: rgb(34 211 238); }
.hover\:text-white:hover { color: #fff; }
.hover\:-translate-y-0\.5:hover { --tw-translate-y: -0.125rem; transform: var(--tw-transform); }
.hover\:scale-105:hover { --tw-scale-x:1.05;--tw-scale-y:1.05;transform:var(--tw-transform); }
.hover\:scale-110:hover { --tw-scale-x:1.1;--tw-scale-y:1.1;transform:var(--tw-transform); }
.hover\:shadow-\[\#128C7E\]\/20:hover { box-shadow: 0 10px 15px -3px rgb(18 140 126 / 0.2); }
.hover\:shadow-\[\#128C7E\]\/30:hover { box-shadow: 0 20px 25px -5px rgb(18 140 126 / 0.3); }
.hover\:shadow-\[\#F25A24\]\/5:hover { box-shadow: 0 10px 15px -3px rgb(242 90 36 / 0.05); }
.hover\:shadow-ice-500\/5:hover { box-shadow: 0 10px 15px -3px rgb(6 182 212 / 0.05); }

/* ── Focus ──────────────────────────────────────────────────── */
.focus\:outline-none:focus { outline: none; }

/* ── Group Hover ─────────────────────────────────────────────── */
.group:hover .group-hover\:bg-ice-500 { background-color: rgb(6 182 212); }
.group:hover .group-hover\:border-ice-400 { border-color: rgb(34 211 238); }
.group:hover .group-hover\:opacity-100 { opacity: 1; }
.group:hover .group-hover\:rotate-3 { --tw-rotate:3deg;transform:var(--tw-transform); }
.group:hover .group-hover\:scale-102 { --tw-scale-x:1.02;--tw-scale-y:1.02;transform:var(--tw-transform); }
.group:hover .group-hover\:scale-110 { --tw-scale-x:1.1;--tw-scale-y:1.1;transform:var(--tw-transform); }
.group:hover .group-hover\:shadow-lg { box-shadow:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1); }
.group:hover .group-hover\:shadow-ice-500\/20 { box-shadow:0 10px 15px -3px rgb(6 182 212 / 0.2); }
.group:hover .group-hover\:text-dark-950 { color: rgb(2 6 23); }
.group:hover .group-hover\:text-ice-300 { color: rgb(103 232 249); }
.group:hover .group-hover\:text-ice-400 { color: rgb(34 211 238); }
.group:hover .group-hover\:text-ice-500\/\[0\.03\] { color: rgb(6 182 212 / 0.03); }
.group:hover .group-hover\:w-1\/2 { width: 50%; }

/* ── sm: (≥640px) ───────────────────────────────────────────── */
@media (min-width: 640px) {
  .sm\:flex-row   { flex-direction: row; }
  .sm\:grid-cols-2 { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .sm\:h-10  { height: 2.5rem; }
  .sm\:h-5   { height: 1.25rem; }
  .sm\:w-10  { width: 2.5rem; }
  .sm\:w-5   { width: 1.25rem; }
  .sm\:p-8   { padding: 2rem; }
  .sm\:px-3\.5 { padding-left:0.875rem;padding-right:0.875rem; }
  .sm\:px-6  { padding-left:1.5rem;padding-right:1.5rem; }
  .sm\:rounded-\[2rem\] { border-radius:2rem; }
  .sm\:space-x-4 > :not([hidden]) ~ :not([hidden]) { margin-left:1rem; }
  .sm\:space-y-6 > :not([hidden]) ~ :not([hidden]) { margin-top:1.5rem; }
  .sm\:space-y-8 > :not([hidden]) ~ :not([hidden]) { margin-top:2rem; }
  .sm\:text-4xl { font-size:2.25rem;line-height:2.5rem; }
  .sm\:text-5xl { font-size:3rem;line-height:1; }
  .sm\:text-lg  { font-size:1.125rem;line-height:1.75rem; }
  .sm\:text-sm  { font-size:0.875rem;line-height:1.25rem; }
  .sm\:tracking-widest { letter-spacing:0.1em; }
}

/* ── md: (≥768px) ───────────────────────────────────────────── */
@media (min-width: 768px) {
  .md\:flex        { display: flex; }
  .md\:grid-cols-2 { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .md\:p-16        { padding: 4rem; }
}

/* ── lg: (≥1024px) ──────────────────────────────────────────── */
@media (min-width: 1024px) {
  .lg\:block          { display: block; }
  .lg\:flex           { display: flex; }
  .lg\:hidden         { display: none; }
  .lg\:col-span-5     { grid-column: span 5/span 5; }
  .lg\:col-span-7     { grid-column: span 7/span 7; }
  .lg\:grid-cols-12   { grid-template-columns: repeat(12,minmax(0,1fr)); }
  .lg\:grid-cols-3    { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .lg\:pt-0           { padding-top: 0; }
  .lg\:text-6xl       { font-size:3.75rem;line-height:1; }
}

/* ── Carousel ───────────────────────────────────────────────────────── */
.carousel-slide {
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1);
}
.active-slide {
  opacity: 1 !important;
  pointer-events: auto !important;
}

/* ── Card Flip ───────────────────────────────────────────────────────── */
.card-container { perspective: 1000px; }
.card-inner {
  transform-style: preserve-3d;
  transition: transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}
.card-flipped .card-inner { transform: rotateY(180deg); }
.card-front, .card-back {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.card-back { transform: rotateY(180deg); }

/* ── Logo ────────────────────────────────────────────────────────────── */
.logo-container {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  font-family: 'Arial Black', 'Impact', sans-serif;
  transform: skewX(-4deg);
}
.logo-dida {
  font-size: 2.2em;
  font-weight: 900;
  font-style: italic;
  line-height: 0.8;
  letter-spacing: -0.07em;
  text-transform: uppercase;
  background: linear-gradient(180deg,#fff 0%,#e5e7eb 25%,#9ca3af 60%,#4b5563 90%,#111827 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(1px 2.5px 1.5px rgba(0,0,0,.95));
  display: block;
}
.logo-refrigeracao {
  font-size: 0.65em;
  font-weight: 900;
  font-style: italic;
  line-height: 1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: #fff;
  text-shadow:
    -1.5px -1.5px 0 #111827, 1.5px -1.5px 0 #111827,
    -1.5px  1.5px 0 #111827, 1.5px  1.5px 0 #111827,
    -1.5px  0px   0 #111827, 1.5px  0px   0 #111827,
     0px   -1.5px 0 #111827, 0px    1.5px 0 #111827,
     1.5px  1.5px 2px rgba(0,0,0,.8);
  margin-top: 0.15em;
  display: block;
}
