@import url('https://fonts.googleapis.com/css2?family=Geist:wght@100..900&display=swap');

html {
    font-family: 'Geist', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    /* Ocultar scrollbar */
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE e Edge */
}

html::-webkit-scrollbar {
    display: none; /* Chrome, Safari e Opera */
}

body {
    font-family: 'Geist', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    /* Ocultar scrollbar */
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE e Edge */
}

body::-webkit-scrollbar {
    display: none; /* Chrome, Safari e Opera */
}

input, button, label, p, a, div {
    font-family: 'Geist', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.font-sans {
    font-family: 'Geist', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.font-display {
    font-family: 'Geist', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

h1, h2, h3, h4, h5, h6 {
    font-family: inherit;
}

:root {
    --color-primary-50: #eff6ff;
    --color-primary-100: #dbeafe;
    --color-primary-200: #bfdbfe;
    --color-primary-300: #93c5fd;
    --color-primary-400: #60a5fa;
    --color-primary-500: #4BFF7A;
    --color-primary-600: #4BFF7A;
    --color-primary-700: #33D45E;
    --color-primary-800: #000503;
    --color-primary-900: #000000;
}

/*:root {*/
/*    --color-primary-50: #f5f3ff;    */
/*    --color-primary-100: #dbeafe;*/
/*    --color-primary-200: #bfdbfe;*/
/*    --color-primary-300: #93c5fd;*/
/*    --color-primary-400: #60a5fa;*/
/*    --color-primary-500: #8b5cf6;*/
/*    --color-primary-600: #7c3aed;*/
/*    --color-primary-700: #6d28d9; */
/*    --color-primary-800: #000503;*/
/*    --color-primary-900: #000000;*/
/*}*/

.bg-primary-50 { background-color: var(--color-primary-50); }
.bg-primary-100 { background-color: var(--color-primary-100); }
.bg-primary-200 { background-color: var(--color-primary-200); }
.bg-primary-300 { background-color: var(--color-primary-300); }
.bg-primary-400 { background-color: var(--color-primary-400); }
.bg-primary-500 { background-color: var(--color-primary-500); }
.bg-primary-600 { background-color: var(--color-primary-600); }
.bg-primary-700 { background-color: var(--color-primary-700); }
.bg-primary-800 { background-color: var(--color-primary-800); }
.bg-primary-900 { background-color: var(--color-primary-900); }

.text-primary-50 { color: var(--color-primary-50); }
.text-primary-100 { color: var(--color-primary-100); }
.text-primary-200 { color: var(--color-primary-200); }
.text-primary-300 { color: var(--color-primary-300); }
.text-primary-400 { color: var(--color-primary-400); }
.text-primary-500 { color: var(--color-primary-500); }
.text-primary-600 { color: var(--color-primary-600); }
.text-primary-700 { color: var(--color-primary-700); }
.text-primary-800 { color: var(--color-primary-800); }
.text-primary-900 { color: var(--color-primary-900); }

.border-primary-50 { border-color: var(--color-primary-50); }
.border-primary-100 { border-color: var(--color-primary-100); }
.border-primary-200 { border-color: var(--color-primary-200); }
.border-primary-300 { border-color: var(--color-primary-300); }
.border-primary-400 { border-color: var(--color-primary-400); }
.border-primary-500 { border-color: var(--color-primary-500); }
.border-primary-600 { border-color: var(--color-primary-600); }
.border-primary-700 { border-color: var(--color-primary-700); }
.border-primary-800 { border-color: var(--color-primary-800); }
.border-primary-900 { border-color: var(--color-primary-900); }

.ring-primary-50 { --tw-ring-color: var(--color-primary-50); }
.ring-primary-100 { --tw-ring-color: var(--color-primary-100); }
.ring-primary-200 { --tw-ring-color: var(--color-primary-200); }
.ring-primary-300 { --tw-ring-color: var(--color-primary-300); }
.ring-primary-400 { --tw-ring-color: var(--color-primary-400); }
.ring-primary-500 { --tw-ring-color: var(--color-primary-500); }
.ring-primary-600 { --tw-ring-color: var(--color-primary-600); }
.ring-primary-700 { --tw-ring-color: var(--color-primary-700); }
.ring-primary-800 { --tw-ring-color: var(--color-primary-800); }
.ring-primary-900 { --tw-ring-color: var(--color-primary-900); }

.hover\:bg-primary-50:hover { background-color: var(--color-primary-50); }
.hover\:bg-primary-100:hover { background-color: var(--color-primary-100); }
.hover\:bg-primary-200:hover { background-color: var(--color-primary-200); }
.hover\:bg-primary-300:hover { background-color: var(--color-primary-300); }
.hover\:bg-primary-400:hover { background-color: var(--color-primary-400); }
.hover\:bg-primary-500:hover { background-color: var(--color-primary-500); }
.hover\:bg-primary-600:hover { background-color: var(--color-primary-600); }
.hover\:bg-primary-700:hover { background-color: var(--color-primary-700); }
.hover\:bg-primary-800:hover { background-color: var(--color-primary-800); }
.hover\:bg-primary-900:hover { background-color: var(--color-primary-900); }

.hover\:text-primary-50:hover { color: var(--color-primary-50); }
.hover\:text-primary-100:hover { color: var(--color-primary-100); }
.hover\:text-primary-200:hover { color: var(--color-primary-200); }
.hover\:text-primary-300:hover { color: var(--color-primary-300); }
.hover\:text-primary-400:hover { color: var(--color-primary-400); }
.hover\:text-primary-500:hover { color: var(--color-primary-500); }
.hover\:text-primary-600:hover { color: var(--color-primary-600); }
.hover\:text-primary-700:hover { color: var(--color-primary-700); }
.hover\:text-primary-800:hover { color: var(--color-primary-800); }
.hover\:text-primary-900:hover { color: var(--color-primary-900); }

.animate-shimmer {
    background: linear-gradient(90deg, #e5e7eb 0%, #f3f4f6 50%, #e5e7eb 100%);
    background-size: 200% 100%;
    animation: shimmer 1.5s primopay;
}
.dark .animate-shimmer {
    background: linear-gradient(90deg, #4b5563 0%, #6b7280 50%, #4b5563 100%);
    background-size: 200% 100%;
    animation: shimmer 1.5s primopay;
}
@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}
.fade-in {
    animation: fadeIn 0.3s ease forwards;
}
.bg-overlay {
    background-color: #000000;
    position: relative;
    min-height: 100vh;
}

.bg-overlay::before {
    content: '';
    position: absolute;
    /*top: 10px;*/
    /*margin-top: 5%;*/
    left: 0;
    width: 100%;
    height: calc(100% - 10px);
    background-image: url('https://i.imgur.com/EcwZXOE.gif');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0.15;
    z-index: -1;
}
.categoria-box {
  text-decoration: none;
  color: inherit;
}

/* Cores customizadas para todas as páginas */
:is(.dark .dark\:bg-gray-800) {
    --tw-bg-opacity: 1;
    background-color: #171717 !important;
}

:is(.dark .dark\:bg-gray-900) {
    --tw-bg-opacity: 1;
    background-color: #0A0A0A !important;
}

.bg-green-600 {
    --tw-bg-opacity: 1;
    background-color: #048d5f !important;
}
.text-green-400 {
    color: #048d5f !important;
}
.dark .dark\:text-green-400 {
    color: #048d5f !important;
}

.text-green-600 {
    --tw-bg-opacity: 1;
    color: #048d5f !important;
}
.dark .dark\:text-green-500 {
    --tw-bg-opacity: 1;
    color: #048d5f !important;
}

:is(.bg-green-100, .dark .bg-green-100, .hover\:bg-green-100:hover, .dark .dark\:hover\:bg-green-100:hover) {
  --tw-bg-opacity: 1;
  background-color: #048d5f1f !important;
}

:is(.text-green-200, .dark .dark\:text-green-200) {
  --tw-text-opacity: 1;
  color: #048d5f !important;
}

.text-green-800 {
    --tw-text-opacity: 1;
    color: #048d5f;
}

.bg-green-400 {
    --tw-bg-opacity: 1;
    background-color: #048d5f73 !important;
}
.dark .dark\:bg-green-400 {
    --tw-bg-opacity: 1;
    background-color: #048d5f !important;
}

:is(.dark .dark\:bg-yellow-900) {
  --tw-bg-opacity: 1;
  background-color: rgb(99 49 18 / 36%);
}

.filter-dropdown-option[data-active="true"] {
  background-color: rgb(4, 141, 97 / 64%);
  color: #048d5f;
}

:is(.dark .dark\:text-red-200) {
    --tw-text-opacity: 1;
    color: rgb(185 10 10);
}

.text-red-800 {
    color: rgb(201 14 14);
}

:is(.dark .dark\:bg-red-900) {
    --tw-bg-opacity: 1;
    background-color: rgb(119 29 29 / 33%);
}

.dark .filter-dropdown-option[data-active="true"] {
    background-color: rgb(4, 141, 97 / 64%);
    color: #048d5f;
}

.dark .filter-dropdown-option:hover {
    background-color: #202020 !important;
}

.bg-green-600\/var\(--tw-bg-opacity\) {
    background-color: #048d5f !important;
}

.text-green-800 {
    --tw-text-opacity: 1;
    color: #048d5f;
}

.bg-yellow-500 {
    background-color: #FFEB3B !important;
}

.dark .dark\:border-t {
    border-top: 1px solid #313232 !important;
}

.bg-yellow-500\/10 {
    background-color: #ecb00b14 !important;
    color: #ffc800 !important;
    border: 1px solid #ffd4006b !important;
}

:is(.dark .dark\:bg-gray-800\/50) {
    background-color: #171717 !important;
}

#main-content {
    background: radial-gradient(ellipse at 90% 90%, rgba(4, 141, 97, 0.08) 0%, rgba(4, 141, 97, 0.02) 35%, transparent 50%);
    background-attachment: fixed;
    background-repeat: no-repeat;
    background-size: cover;
}

main {
    min-height: 100%;
}

:is(.dark .bg-green-100) {
    --tw-bg-opacity: 1;
    background-color: #048d5f2c !important;
}
.dark .dark\:bg-gray-700 {
    background-color: #202020 !important;
}

.dark .dark\:transaction-row:hover td {
    background-color: #202020be !important;
}
.dark .dark\:transaction-row:hover {
    background-color: #202020be !important;
}
.hover\:bg-green-700:hover {
    background-color: #1da84e !important;
}

.dark .dark\:bg-green-500 {
    background-color: #048d5f !important;
}

.dark .dark\:hover\:bg-green-600:hover {
    background-color: #1da84e !important;
}

:is(.dark .dark\:border-gray-700) {
    --tw-border-opacity: 1;
    border-color: #313232 !important;
}

.dark .border-gray-700 {
    border-color: #313232 !important;
}

.dark .dark\:border-gray-600 {
    border-color: #313232 !important;
}

.dark .dark\:bg-gray-600 {
    background-color: rgb(30 38 31);
}

.categoria-box img {
  transform: scale(1.1);
  transition: transform 0.3s ease-in-out;
}

.categoria-box:hover img {
  transform: scale(1);
}

.categoria-box .overlay {
  transition: background-color 0.3s ease-in-out;
}

.categoria-box:hover .overlay {
  background-color: rgba(0, 0, 0, 0.6);
}
:root {
  --primary-600: #31C482;
  --primary-700: #2BA670;
  --primary-800: #258A5E;
}

.card-content {
  background: linear-gradient(to right, #0D1116, #111827);
}
.light .card-content {
  background: linear-gradient(to right, #F3F4F6, #E5E7EB);
}

.product-image {
  transform: none;
  transition: none;
}
.product-card:hover .product-image {
  transform: none;
}

.product-card {
  position: relative;
  overflow: hidden;
}
.product-card:hover {
  transform: none;
  box-shadow: none;
}
.product-card::before {
  display: none;
}
.product-card:hover::before {
  display: none;
}
.product-card.opacity-50:hover {
  transform: none;
  box-shadow: none;
}
.product-card.opacity-50:hover .product-image {
  transform: scale(1.1);
}
.product-card.opacity-50::before {
  display: none;
}

.buy-now-btn {
  position: relative;
  overflow: hidden;
  transition: background-color 0.3s ease-in-out;
}
.buy-now-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  animation: shine 2s primopay linear;
}
@keyframes shine {
  0% { left: -100%; }
  100% { left: 100%; }
}

input[type="text"],
input[type="number"],
input[type="email"],
input[type="password"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="search"],
input[type="tel"],
input[type="url"],
textarea,
select {
    outline: none;
}

input[type="text"]:focus,
input[type="number"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="date"]:focus,
input[type="time"]:focus,
input[type="datetime-local"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
textarea:focus,
select:focus,
input[type="text"]:focus-visible,
input[type="number"]:focus-visible,
input[type="email"]:focus-visible,
input[type="password"]:focus-visible,
input[type="date"]:focus-visible,
input[type="time"]:focus-visible,
input[type="datetime-local"]:focus-visible,
input[type="search"]:focus-visible,
input[type="tel"]:focus-visible,
input[type="url"]:focus-visible,
textarea:focus-visible,
select:focus-visible {
    border-color: #048d5f !important;
    box-shadow: 0 0 0 2px rgba(4, 141, 97, 0.2) !important;
    outline: none !important;
}

input:focus,
textarea:focus,
select:focus,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
    --tw-ring-color: rgba(4, 141, 97, 0.2) !important;
}

input.focus\:border-green-500:focus,
input.focus\:ring-green-500:focus,
input.focus\:ring-green-500\/20:focus {
    border-color: #048d5f !important;
    --tw-ring-color: rgba(4, 141, 97, 0.2) !important;
    box-shadow: 0 0 0 2px rgba(4, 141, 97, 0.2) !important;
}

input:focus,
textarea:focus,
select:focus {
    border-color: #048d5f !important;
}

input:focus-visible,
textarea:focus-visible,
select:focus-visible {
    border-color: #048d5f !important;
    outline: 2px solid transparent !important;
    outline-offset: 2px !important;
    box-shadow: 0 0 0 2px rgba(4, 141, 97, 0.2) !important;
}

#period-dropdown-trigger:focus,
#period-dropdown-trigger:focus-visible,
#period-dropdown-trigger.active,
#status-dropdown-trigger:focus,
#status-dropdown-trigger:focus-visible,
#status-dropdown-trigger.active,
#type-dropdown-trigger:focus,
#type-dropdown-trigger:focus-visible,
#type-dropdown-trigger.active {
    border-color: #048d5f !important;
    box-shadow: 0 0 0 2px rgba(4, 141, 97, 0.2) !important;
    outline: none !important;
    --tw-ring-color: rgba(4, 141, 97, 0.2) !important;
}

button.focus\:ring-green-500:focus,
button[id*="dropdown-trigger"]:focus {
    border-color: #048d5f !important;
    --tw-ring-color: rgba(4, 141, 97, 0.2) !important;
    box-shadow: 0 0 0 2px rgba(4, 141, 97, 0.2) !important;
}

/* Hover do aside no tema white - apenas para itens não ativos */
#sidebar-switch li:not(.bg-green-600) > a:hover,
#sidebar-switch li:not(.bg-green-600) > button:hover,
#sidebar-switch a:not(.hover\:bg-green-700):hover,
#sidebar-switch button:not(.hover\:bg-green-700):hover {
    background-color: #f3f4f6 !important;
}

/* Hover do aside no tema dark - apenas para itens não ativos */
.dark #sidebar-switch li:not(.bg-green-600) > a:hover,
.dark #sidebar-switch li:not(.bg-green-600) > button:hover,
.dark #sidebar-switch a:not(.hover\:bg-green-700):hover,
.dark #sidebar-switch button:not(.hover\:bg-green-700):hover {
    background-color: #202020 !important;
}

/* Desabilitar hover quando o item está ativo - manter cor verde */
#sidebar-switch li.bg-green-600 > a:hover,
#sidebar-switch li.bg-green-600 > button:hover,
#sidebar-switch a.hover\:bg-green-700:hover {
    background-color: rgb(3, 109, 75) !important; /* green-700 - mantém verde no hover */
}

.dark #sidebar-switch li.bg-green-600 > a:hover,
.dark #sidebar-switch li.bg-green-600 > button:hover,
.dark #sidebar-switch a.hover\:bg-green-700:hover {
    background-color: rgb(3, 109, 75) !important; /* green-700 - mantém verde no hover */
}

#sidebar-switch .hover\:bg-gray-100:hover {
    background-color: #f3f4f6 !important;
}

.dark #sidebar-switch .hover\:bg-gray-700:hover {
    background-color: #202020 !important;
}

/* Ocultar scrollbar em todos os elementos do site */
* {
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE e Edge */
}

*::-webkit-scrollbar {
    display: none; /* Chrome, Safari e Opera */
}