/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: May 04 2026 | 00:10:19 */
 /* ============================================================
   ARRECIFE 50 AÑOS — CSS GLOBAL
   ============================================================ */

@import "https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,900;1,300;1,400&display=swap";

/* ===== RESET Y VARIABLES ===== */
*, :before, :after {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --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-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style: ;
    box-sizing: border-box;
    border-width: 0;
    border-style: solid;
    border-color: #e5e7eb
}

::backdrop {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --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-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}
/*******
html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
    font-feature-settings: normal;
    font-variation-settings: normal;
    -webkit-tap-highlight-color: transparent
}


body {
    margin: 0;
    line-height: inherit
}

hr {
    height: 0;
    color: inherit;
    border-top-width: 1px
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit
}

a {
    color: inherit;
    text-decoration: inherit
}

b, strong {
    font-weight: bolder
}

code, kbd, samp, pre {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
    font-feature-settings: normal;
    font-variation-settings: normal;
    font-size: 1em
}

small {
    font-size: 80%
}

sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse
}

button, input, optgroup, select, textarea {
    font-family: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    font-size: 100%;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
    margin: 0;
    padding: 0
}

button, select {
    text-transform: none
}

button, input:where([type=button]), input:where([type=reset]), input:where([type=submit]) {
    -webkit-appearance: button;
    background-color: transparent;
    background-image: none
}

:-moz-focusring {
    outline: auto
}

:-moz-ui-invalid {
    box-shadow: none
}

progress {
    vertical-align: baseline
}

*/

.ali-vert {
    display: flex;
    flex-direction: column;
	justify-content: center;
}
p, img {
	margin-left: auto !important;
	margin-right: auto !important;
}

::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

summary {
    display: list-item
}

blockquote, dl, dd, h1, h2, h3, h4, h5, h6, hr, figure, p, pre {
    margin: 0
}

fieldset {
    margin: 0;
    padding: 0
}

legend {
    padding: 0
}

ol, ul, menu {
    list-style: none;
    margin: 0;
    padding: 0
}

dialog {
    padding: 0
}

textarea {
    resize: vertical
}

input::-moz-placeholder, textarea::-moz-placeholder {
    opacity: 1;
    color: #9ca3af
}

input::placeholder, textarea::placeholder {
    opacity: 1;
    color: #9ca3af
}

button, [role=button] {
    cursor: pointer
}

:disabled {
    cursor: default
}

img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle
}

img, video {
    max-width: 100%;
    height: auto
}

[hidden]:where(:not([hidden=until-found])) {
    display: none
}

/* ===== ROOT ===== */
:root {
    --background: 0 0% 100%;
    --foreground: 0 0% 10.2%;
    --card: 0 0% 100%;
    --card-foreground: 0 0% 10.2%;
    --popover: 0 0% 100%;
    --popover-foreground: 0 0% 10.2%;
    --primary: 195 100% 19.6%;
    --primary-foreground: 0 0% 100%;
    --secondary: 40 4% 95.3%;
    --secondary-foreground: 0 0% 10.2%;
    --muted: 40 4% 95.3%;
    --muted-foreground: 40 2% 33.3%;
    --accent: 202 100% 40.8%;
    --accent-foreground: 0 0% 100%;
    --destructive: 0 84.2% 60.2%;
    --destructive-foreground: 0 0% 100%;
    --border: 40 6% 88%;
    --input: 40 6% 88%;
    --ring: 195 100% 19.6%;
    --radius: .5rem;
    --arrecife-blue: 195 100% 19.6%;
    --arrecife-accent: 202 100% 40.8%;
    --arrecife-gold: 43 65% 52.2%;
    --arrecife-gold-light: 48 90% 87.1%;
    --arrecife-gold-dark: 43 100% 33.3%;
    --arrecife-gold-deep: 24 55% 23.5%;
    --arrecife-black: 240 2% 10.4%;
    --arrecife-white: 0 0% 100%;
    --arrecife-surface: 40 10% 95.3%;
    --arrecife-footer: 198 100% 8.2%;
    --sidebar-background: 0 0% 98%;
    --sidebar-foreground: 240 5.3% 26.1%;
    --sidebar-primary: 240 5.9% 10%;
    --sidebar-primary-foreground: 0 0% 98%;
    --sidebar-accent: 240 4.8% 95.9%;
    --sidebar-accent-foreground: 240 5.9% 10%;
    --sidebar-border: 220 13% 91%;
    --sidebar-ring: 217.2 91.2% 59.8%
}

* {
    border-color: hsl(var(--border))
}

body {
    background-color: hsl(var(--background));
    color: hsl(var(--foreground));
    font-family: Poppins, sans-serif
}

/* ===== POSITION ===== */
.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
}

.pointer-events-none { pointer-events: none }
.pointer-events-auto { pointer-events: auto }
.visible { visibility: visible }
.invisible { visibility: hidden }
.fixed { position: fixed }
.absolute { position: absolute }
.relative { position: relative }
.inset-0 { top: 0; right: 0; bottom: 0; left: 0 }
.inset-x-0 { left: 0; right: 0 }
.inset-y-0 { top: 0; bottom: 0 }
.-bottom-12 { bottom: -3rem }
.-left-12 { left: -3rem }
.-right-12 { right: -3rem }
.-top-12 { top: -3rem }
.-top-8 { top: -2rem }
.bottom-0 { bottom: 0 }
.bottom-3 { bottom: .75rem }
.left-0 { left: 0 }
.left-1 { left: .25rem }
.left-1\/2 { left: 50% }
.left-2 { left: .5rem }
.left-\[50\%\] { left: 50% }
.left-\[7px\] { left: 7px }
.right-0 { right: 0 }
.right-1 { right: .25rem }
.right-2 { right: .5rem }
.right-3 { right: .75rem }
.right-4 { right: 1rem }
.top-0 { top: 0 }
.top-1\.5 { top: .375rem }
.top-1\/2 { top: 50% }
.top-16 { top: 4rem }
.top-2 { top: .5rem }
.top-3\.5 { top: .875rem }
.top-4 { top: 1rem }
.top-\[1px\] { top: 1px }
.top-\[50\%\] { top: 50% }
.top-\[60\%\] { top: 60% }
.top-full { top: 100% }
.z-10 { z-index: 10 }
.z-20 { z-index: 20 }
.z-50 { z-index: 50 }
.z-\[100\] { z-index: 100 }
.z-\[1\] { z-index: 1 }
.order-first { order: -9999 }

/* ===== MARGINS ===== */
.-mx-1 { margin-left: -.25rem; margin-right: -.25rem }
.mx-2 { margin-left: .5rem; margin-right: .5rem }
.mx-3\.5 { margin-left: .875rem; margin-right: .875rem }
.mx-auto { margin-left: auto; margin-right: auto }
.my-0\.5 { margin-top: .125rem; margin-bottom: .125rem }
.my-1 { margin-top: .25rem; margin-bottom: .25rem }
.my-10 { margin-top: 2.5rem; margin-bottom: 2.5rem }
.my-4 { margin-top: 1rem; margin-bottom: 1rem }
.-ml-4 { margin-left: -1rem }
.-mt-4 { margin-top: -1rem }
.mb-1 { margin-bottom: .25rem }
.mb-12 { margin-bottom: 3rem }
.mb-16 { margin-bottom: 4rem }
.mb-2 { margin-bottom: .5rem }
.mb-3 { margin-bottom: .75rem }
.mb-4 { margin-bottom: 1rem }
.mb-6 { margin-bottom: 1.5rem }
.mb-8 { margin-bottom: 2rem }
.ml-1 { margin-left: .25rem }
.ml-auto { margin-left: auto }
.mr-2 { margin-right: .5rem }
.mt-0 { margin-top: 0 }
.mt-1 { margin-top: .25rem }
.mt-1\.5 { margin-top: .375rem }
.mt-10 { margin-top: 2.5rem }
.mt-12 { margin-top: 3rem }
.mt-2 { margin-top: .5rem }
.mt-24 { margin-top: 6rem }
.mt-3 { margin-top: .75rem }
.mt-4 { margin-top: 1rem }
.mt-6 { margin-top: 1.5rem }
.mt-8 { margin-top: 2rem }
.mt-auto { margin-top: auto }

/* ===== DISPLAY & FLEX ===== */
.block { display: block }
.inline-block { display: inline-block }
.flex { display: flex }
.inline-flex { display: inline-flex }
.table { display: table }
.grid { display: grid }
.hidden { display: none }
.aspect-\[500\/380\] { aspect-ratio: 500/380 }
.aspect-square { aspect-ratio: 1 / 1 }
.aspect-video { aspect-ratio: 16 / 9 }
.size-4 { width: 1rem; height: 1rem }
.h-0\.5 { height: .125rem }
.h-1\.5 { height: .375rem }
.h-10 { height: 2.5rem }
.h-11 { height: 2.75rem }
.h-12 { height: 3rem }
.h-16 { height: 4rem }
.h-2 { height: .5rem }
.h-2\.5 { height: .625rem }
.h-20 { height: 5rem }
.h-3 { height: .75rem }
.h-3\.5 { height: .875rem }
.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-\[1px\] { height: 1px }
.h-\[220px\] { height: 220px }
.h-\[var\(--radix-navigation-menu-viewport-height\)\] { height: var(--radix-navigation-menu-viewport-height) }
.h-\[var\(--radix-select-trigger-height\)\] { height: var(--radix-select-trigger-height) }
.h-auto { height: auto }
.h-full { height: 100% }
.h-px { height: 1px }
.h-svh { height: 100svh }
.max-h-96 { max-height: 24rem }
.max-h-\[300px\] { max-height: 300px }
.max-h-screen { max-height: 100vh }
.min-h-0 { min-height: 0px }
.min-h-\[80px\] { min-height: 80px }
.min-h-screen { min-height: 100vh }
.min-h-svh { min-height: 100svh }
.w-0 { width: 0px }
.w-1 { width: .25rem }
.w-10 { width: 2.5rem }
.w-11 { width: 2.75rem }
.w-2 { width: .5rem }
.w-2\.5 { width: .625rem }
.w-20 { width: 5rem }
.w-3 { width: .75rem }
.w-3\.5 { width: .875rem }
.w-3\/4 { width: 75% }
.w-4 { width: 1rem }
.w-5 { width: 1.25rem }
.w-64 { width: 16rem }
.w-7 { width: 1.75rem }
.w-72 { width: 18rem }
.w-8 { width: 2rem }
.w-9 { width: 2.25rem }
.w-\[--sidebar-width\] { width: var(--sidebar-width) }
.w-\[100px\] { width: 100px }
.w-\[1px\] { width: 1px }
.w-\[2px\] { width: 2px }
.w-\[3px\] { width: 3px }
.w-\[600px\] { width: 600px }
.w-\[60px\] { width: 60px }
.w-auto { width: auto }
.w-full { width: 100% }
.w-max { width: max-content }
.w-px { width: 1px }
.min-w-0 { min-width: 0px }
.min-w-5 { min-width: 1.25rem }
.min-w-\[12rem\] { min-width: 12rem }
.min-w-\[8rem\] { min-width: 8rem }
.min-w-\[var\(--radix-select-trigger-width\)\] { min-width: var(--radix-select-trigger-width) }
.max-w-\[--skeleton-width\] { max-width: var(--skeleton-width) }
.max-w-\[520px\] { max-width: 520px }
.max-w-\[560px\] { max-width: 560px }
.max-w-\[600px\] { max-width: 600px }
.max-w-\[680px\] { max-width: 680px }
.max-w-\[700px\] { max-width: 700px }
.max-w-\[900px\] { max-width: 900px }
.max-w-lg { max-width: 32rem }
.max-w-max { max-width: max-content }
.flex-1 { flex: 1 1 0% }
.shrink-0 { flex-shrink: 0 }
.grow { flex-grow: 1 }
.grow-0 { flex-grow: 0 }
.basis-full { flex-basis: 100% }
.caption-bottom { caption-side: bottom }
.border-collapse { border-collapse: collapse }

/* ===== TRANSFORMS ===== */
.-translate-x-1\/2, .translate-x-[-50\%] { --tw-translate-x: -50%; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.-translate-x-px { --tw-translate-x: -1px; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.-translate-y-1\/2, .translate-y-[-50\%] { --tw-translate-y: -50%; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.-translate-y-2 { --tw-translate-y: -.5rem; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.translate-x-px { --tw-translate-x: 1px; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.translate-y-2 { --tw-translate-y: .5rem; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.-rotate-45 { --tw-rotate: -45deg; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.rotate-45 { --tw-rotate: 45deg; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.rotate-90 { --tw-rotate: 90deg; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.transform { transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }

/* ===== ANIMACIONES ===== */
@keyframes bounce-down {
    0%, to { transform: translateY(0) }
    50% { transform: translateY(8px) }
}
.animate-bounce-down { animation: bounce-down 2s ease-in-out infinite }

@keyframes pulse {
    50% { opacity: .5 }
}
.animate-pulse { animation: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite }

@keyframes timeline-pulse {
    0%, to { transform: rotate(45deg) scale(1); opacity: 1 }
    50% { transform: rotate(45deg) scale(1.15); opacity: .85 }
}
.animate-timeline-pulse { animation: timeline-pulse 2s ease-in-out infinite }

@keyframes timeline-pulse-ring {
    0% { transform: rotate(45deg) scale(1); opacity: .4 }
    to { transform: rotate(45deg) scale(2.2); opacity: 0 }
}
.animate-timeline-pulse-ring { animation: timeline-pulse-ring 2s ease-in-out infinite }

/* ===== CURSOR, USER SELECT ===== */
.cursor-default { cursor: default }
.cursor-pointer { cursor: pointer }
.touch-none { touch-action: none }
.select-none { user-select: none }
.list-none { list-style-type: none }

/* ===== 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-\[auto_1fr\] { grid-template-columns: auto 1fr }

/* ===== FLEX DIRECTION, ALIGN, JUSTIFY ===== */
.flex-row { flex-direction: row }
.flex-col { flex-direction: column }
.flex-col-reverse { flex-direction: column-reverse }
.flex-wrap { flex-wrap: wrap }
.items-start { align-items: flex-start }
.items-end { align-items: flex-end }
.items-center { align-items: center }
.items-stretch { align-items: stretch }
.justify-center { justify-content: center }
.justify-between { justify-content: space-between }

/* ===== GAPS ===== */
.gap-1 { gap: .25rem }
.gap-1\.5 { gap: .375rem }
.gap-10 { gap: 2.5rem }
.gap-12 { gap: 3rem }
.gap-16 { gap: 4rem }
.gap-2 { gap: .5rem }
.gap-4 { gap: 1rem }
.gap-5 { gap: 1.25rem }
.gap-8 { gap: 2rem }

/* ===== SPACE UTILS ===== */
.space-x-1 > :not([hidden]) ~ :not([hidden]) { --tw-space-x-reverse: 0; margin-right: calc(.25rem * var(--tw-space-x-reverse)); margin-left: calc(.25rem * calc(1 - var(--tw-space-x-reverse))) }
.space-x-4 > :not([hidden]) ~ :not([hidden]) { --tw-space-x-reverse: 0; margin-right: calc(1rem * var(--tw-space-x-reverse)); margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse))) }
.space-y-1 > :not([hidden]) ~ :not([hidden]) { --tw-space-y-reverse: 0; margin-top: calc(.25rem * calc(1 - var(--tw-space-y-reverse))); margin-bottom: calc(.25rem * var(--tw-space-y-reverse)) }
.space-y-1\.5 > :not([hidden]) ~ :not([hidden]) { --tw-space-y-reverse: 0; margin-top: calc(.375rem * calc(1 - var(--tw-space-y-reverse))); margin-bottom: calc(.375rem * var(--tw-space-y-reverse)) }
.space-y-2 > :not([hidden]) ~ :not([hidden]) { --tw-space-y-reverse: 0; margin-top: calc(.5rem * calc(1 - var(--tw-space-y-reverse))); margin-bottom: calc(.5rem * var(--tw-space-y-reverse)) }
.space-y-4 > :not([hidden]) ~ :not([hidden]) { --tw-space-y-reverse: 0; margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse))); margin-bottom: calc(1rem * var(--tw-space-y-reverse)) }

/* ===== OVERFLOW, TEXT WRAP ===== */
.overflow-auto { overflow: auto }
.overflow-hidden { overflow: hidden }
.overflow-y-auto { overflow-y: auto }
.overflow-x-hidden { overflow-x: hidden }
.hyphens-auto { hyphens: auto }
.whitespace-nowrap { white-space: nowrap }
.break-words { overflow-wrap: break-word }

/* ===== BORDERS & RADIUS ===== */
.rounded { border-radius: .25rem }
.rounded-\[2px\] { border-radius: 2px }
.rounded-\[inherit\] { border-radius: inherit }
.rounded-full { border-radius: 9999px }
.rounded-lg { border-radius: var(--radius) }
.rounded-md { border-radius: calc(var(--radius) - 2px) }
.rounded-sm { border-radius: calc(var(--radius) - 4px) }
.rounded-xl { border-radius: .75rem }
.rounded-t-\[10px\] { border-top-left-radius: 10px; border-top-right-radius: 10px }
.rounded-tl-sm { border-top-left-radius: calc(var(--radius) - 4px) }
.border { border-width: 1px }
.border-2 { border-width: 2px }
.border-\[1\.5px\] { border-width: 1.5px }
.border-y { border-top-width: 1px; border-bottom-width: 1px }
.border-b { border-bottom-width: 1px }
.border-l { border-left-width: 1px }
.border-l-4 { border-left-width: 4px }
.border-l-\[3px\] { border-left-width: 3px }
.border-r { border-right-width: 1px }
.border-t { border-top-width: 1px }
.border-t-4 { border-top-width: 4px }
.border-dashed { border-style: dashed }
.border-\[--color-border\] { border-color: var(--color-border) }
.border-\[rgba\(212\,175\,55\,0\.4\)\] { border-color: #d4af3766 }
.border-\[rgba\(212\,175\,55\,0\.5\)\] { border-color: #d4af3780 }
.border-arrecife-gold { --tw-border-opacity: 1; border-color: rgb(212 175 55 / var(--tw-border-opacity, 1)) }
.border-arrecife-gold { border-left: 4px solid #D4AF37; } /* nuevo */
.borde-dorado-ipx { border:1px solid rgba(212,175,55,0.5)} /* nuevo */
.border-border\/50 { border-color: hsl(var(--border) / .5) }
.border-destructive { border-color: hsl(var(--destructive)) }
.border-destructive\/50 { border-color: hsl(var(--destructive) / .5) }
.border-input { border-color: hsl(var(--input)) }
.border-primary { border-color: hsl(var(--primary)) }
.border-sidebar-border { border-color: hsl(var(--sidebar-border)) }
.border-transparent { border-color: transparent }
.border-white { --tw-border-opacity: 1; border-color: rgb(255 255 255 / var(--tw-border-opacity, 1)) }
.border-l-transparent { border-left-color: transparent }
.border-t-transparent { border-top-color: transparent }

/* ===== BACKGROUNDS ===== */
.bg-\[--color-bg\] { background-color: var(--color-bg) }
.bg-\[rgba\(0\,0\,0\,0\.15\)\] { background-color: #00000026 }
.bg-\[rgba\(212\,175\,55\,0\.06\)\] { background-color: #d4af370f }
.bg-\[rgba\(212\,175\,55\,0\.08\)\] { background-color: #d4af3714 }
.bg-\[rgba\(212\,175\,55\,0\.15\)\] { background-color: #d4af3726 }
.bg-accent { background-color: hsl(var(--accent)) }
.bg-arrecife-black { --tw-bg-opacity: 1; background-color: rgb(26 26 27 / var(--tw-bg-opacity, 1)) }
.bg-arrecife-blue { --tw-bg-opacity: 1; background-color: rgb(0 75 99 / var(--tw-bg-opacity, 1)) }
.bg-arrecife-blue\/95 { background-color: #004b63f2 }
.bg-arrecife-footer { --tw-bg-opacity: 1; background-color: rgb(0 30 42 / var(--tw-bg-opacity, 1)) }
.bg-arrecife-gold { --tw-bg-opacity: 1; background-color: rgb(212 175 55 / var(--tw-bg-opacity, 1)) }
.bg-arrecife-gold\/40 { background-color: #d4af3766 }
.bg-arrecife-surface { --tw-bg-opacity: 1; background-color: rgb(245 244 240 / var(--tw-bg-opacity, 1)) }
.bg-arrecife-white { --tw-bg-opacity: 1; background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1)) }
.bg-background { background-color: hsl(var(--background)) }
.bg-black\/80 { background-color: #000c }
.bg-border { background-color: hsl(var(--border)) }
.bg-card { background-color: hsl(var(--card)) }
.bg-destructive { background-color: hsl(var(--destructive)) }
.bg-foreground { background-color: hsl(var(--foreground)) }
.bg-muted { background-color: hsl(var(--muted)) }
.bg-muted\/50 { background-color: hsl(var(--muted) / .5) }
.bg-popover { background-color: hsl(var(--popover)) }
.bg-primary { background-color: hsl(var(--primary)) }
.bg-secondary { background-color: hsl(var(--secondary)) }
.bg-sidebar { background-color: hsl(var(--sidebar-background)) }
.bg-sidebar-border { background-color: hsl(var(--sidebar-border)) }
.bg-transparent { background-color: transparent }
.bg-white\/50 { background-color: #ffffff80 }
.bg-gradient-to-b { background-image: linear-gradient(to bottom, var(--tw-gradient-stops)) }
.from-arrecife-gold\/40 { --tw-gradient-from: rgb(212 175 55 / .4) var(--tw-gradient-from-position); --tw-gradient-to: rgb(212 175 55 / 0) var(--tw-gradient-to-position); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) }
.to-transparent { --tw-gradient-to: transparent var(--tw-gradient-to-position) }
.fill-current { fill: currentColor }

/* ===== OBJECT FIT ===== */
.object-contain { object-fit: contain }
.object-cover { object-fit: cover }

/* ===== PADDINGS ===== */
.p-0 { padding: 0 }
.p-1 { padding: .25rem }
.p-10 { padding: 2.5rem }
.p-10-2 { padding: 2.5rem 2.1rem } /* nuevo */
.p-2 { padding: .5rem }
.p-3 { padding: .75rem }
.p-4 { padding: 1rem }
.p-6 { padding: 1.5rem }
.p-8 { padding: 2rem }
.p-\[1px\] { padding: 1px }
.px-1 { padding-left: .25rem; padding-right: .25rem }
.px-2 { padding-left: .5rem; padding-right: .5rem }
.px-2\.5 { padding-left: .625rem; padding-right: .625rem }
.px-3 { padding-left: .75rem; padding-right: .75rem }
.px-4 { padding-left: 1rem; padding-right: 1rem }
.px-5 { padding-left: 1.25rem; padding-right: 1.25rem }
.px-6 { padding-left: 1.5rem; padding-right: 1.5rem }
.px-8 { padding-left: 2rem; padding-right: 2rem }
.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-12 { padding-top: 3rem; padding-bottom: 3rem }
.py-2 { padding-top: .5rem; padding-bottom: .5rem }
.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 }
.pb-3 { padding-bottom: .75rem }
.pb-4 { padding-bottom: 1rem }
.pl-2\.5 { padding-left: .625rem }
.pl-4 { padding-left: 1rem }
.pl-8 { padding-left: 2rem }
.pr-10 { padding-right: 2.5rem }
.pr-2 { padding-right: .5rem }
.pr-2\.5 { padding-right: .625rem }
.pr-8 { padding-right: 2rem }
.pt-0 { padding-top: 0 }
.pt-1 { padding-top: .25rem }
.pt-3 { padding-top: .75rem }
.pt-4 { padding-top: 1rem }
.pt-6 { padding-top: 1.5rem }

/* ===== TEXTO ===== */
.text-left { text-align: left }
.text-center { text-align: center }
.text-justify { text-align: justify }
.align-middle { vertical-align: middle }
.font-mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace }
.font-poppins { font-family: Poppins, sans-serif }
.text-2xl { font-size: 1.5rem; line-height: 2rem }
.text-4xl { font-size: 2.25rem; line-height: 2.5rem }
.text-\[0\.8rem\] { font-size: .8rem }
.text-\[11px\] { font-size: 11px }
.text-\[13px\] { font-size: 13px }
.text-\[15px\] { font-size: 15px }
.text-\[17px\] { font-size: 17px }
.text-\[19px\] { font-size: 19px }
.text-\[26px\] { font-size: 26px }
.text-\[32px\] { font-size: 32px }
.text-\[96px\] { font-size: 96px }
.text-base { font-size: 1rem; line-height: 1.5rem }
.text-lg { font-size: 1.125rem; line-height: 1.75rem }
.text-sm { font-size: .875rem; line-height: 1.25rem }
.text-xl { font-size: 1.25rem; line-height: 1.75rem }
.text-xs { font-size: .75rem; line-height: 1rem }
.font-black { font-weight: 900 }
.font-bold { font-weight: 700 }
.font-light { font-weight: 300 }
.font-medium { font-weight: 500 }
.font-normal { font-weight: 400 }
.font-semibold { font-weight: 600 }
.uppercase { text-transform: uppercase }
.italic { font-style: italic }
.tabular-nums { --tw-numeric-spacing: tabular-nums; font-variant-numeric: var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction) }
.leading-\[1\.75\] { line-height: 1.75 }
.leading-\[1\.7\] { line-height: 1.7 }
.leading-none { line-height: 1 }
.leading-relaxed { line-height: 1.625 }
.leading-tight { line-height: 1.25 }
.tracking-\[3px\] { letter-spacing: 3px }
.tracking-\[6px\] { letter-spacing: 6px }
.tracking-tight { letter-spacing: -.025em }
.tracking-wide { letter-spacing: .025em }
.tracking-wider { letter-spacing: .05em }
.tracking-widest { letter-spacing: .1em }

/* ===== COLORES DE TEXTO ===== */
.text-accent-foreground { color: hsl(var(--accent-foreground)) }
.text-arrecife-accent { --tw-text-opacity: 1; color: rgb(0 140 208 / var(--tw-text-opacity, 1)) }
.text-arrecife-black { --tw-text-opacity: 1; color: rgb(26 26 27 / var(--tw-text-opacity, 1)) }
.text-arrecife-blue { --tw-text-opacity: 1; color: rgb(0 75 99 / var(--tw-text-opacity, 1)) }
.text-arrecife-gold { --tw-text-opacity: 1; color: rgb(212 175 55 / var(--tw-text-opacity, 1)) }
.text-arrecife-white { --tw-text-opacity: 1; color: rgb(255 255 255 / var(--tw-text-opacity, 1)) }
.text-card-foreground { color: hsl(var(--card-foreground)) }
.text-current { color: currentColor }
.text-destructive { color: hsl(var(--destructive)) }
.text-destructive-foreground { color: hsl(var(--destructive-foreground)) }
.text-foreground { color: hsl(var(--foreground)) }
.text-foreground\/50 { color: hsl(var(--foreground) / .5) }
.text-muted-foreground { color: hsl(var(--muted-foreground)) }
.text-popover-foreground { color: hsl(var(--popover-foreground)) }
.text-primary { color: hsl(var(--primary)) }
.text-primary-foreground { color: hsl(var(--primary-foreground)) }
.text-secondary-foreground { color: hsl(var(--secondary-foreground)) }
.text-sidebar-foreground { color: hsl(var(--sidebar-foreground)) }
.text-sidebar-foreground\/70 { color: hsl(var(--sidebar-foreground) / .7) }
.underline { text-decoration-line: underline }
.underline-offset-4 { text-underline-offset: 4px }

/* ===== OPACIDAD, SOMBRAS, FILTROS ===== */
.opacity-0 { opacity: 0 }
.opacity-10 { opacity: .1 }
.opacity-100 { opacity: 1 }
.opacity-30 { opacity: .3 }
.opacity-50 { opacity: .5 }
.opacity-60 { opacity: .6 }
.opacity-70 { opacity: .7 }
.opacity-90 { opacity: .9 }
.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\] { --tw-shadow: 0 0 0 1px hsl(var(--sidebar-border)); --tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color); box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) }
.shadow-\[0_0_12px_rgba\(212\,175\,55\,0\.5\)\] { --tw-shadow: 0 0 12px rgba(212, 175, 55, .5); --tw-shadow-colored: 0 0 12px var(--tw-shadow-color); box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) }
.shadow-lg { --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color); box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) }
.shadow-md { --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color); box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) }
.shadow-none { --tw-shadow: 0 0 #0000; --tw-shadow-colored: 0 0 #0000; box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) }
.shadow-sm { --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05); --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color); box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) }
.shadow-xl { --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color); box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) }
.outline-none { outline: 2px solid transparent; outline-offset: 2px }
.outline { outline-style: solid }
.ring-0 { --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color); box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) }
.ring-2 { --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color); box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) }
.ring-ring { --tw-ring-color: hsl(var(--ring)) }
.ring-sidebar-ring { --tw-ring-color: hsl(var(--sidebar-ring)) }
.ring-offset-background { --tw-ring-offset-color: hsl(var(--background)) }
.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) }
.backdrop-blur-xl { --tw-backdrop-blur: blur(24px); backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia) }

/* ===== TRANSICIONES ===== */
.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: .15s }
.transition-\[left\,right\,width\] { transition-property: left, right, width; transition-timing-function: cubic-bezier(.4, 0, .2, 1); transition-duration: .15s }
.transition-\[margin\,opa\] { transition-property: margin, opa; transition-timing-function: cubic-bezier(.4, 0, .2, 1); transition-duration: .15s }
.transition-\[width\,height\,padding\] { transition-property: width, height, padding; transition-timing-function: cubic-bezier(.4, 0, .2, 1); transition-duration: .15s }
.transition-\[width\] { transition-property: width; transition-timing-function: cubic-bezier(.4, 0, .2, 1); transition-duration: .15s }
.transition-all { transition-property: all; transition-timing-function: cubic-bezier(.4, 0, .2, 1); transition-duration: .15s }
.transition-colors { transition-property: color, background-color, border-color, text-decoration-color, fill, stroke; transition-timing-function: cubic-bezier(.4, 0, .2, 1); transition-duration: .15s }
.transition-opacity { transition-property: opacity; transition-timing-function: cubic-bezier(.4, 0, .2, 1); transition-duration: .15s }
.transition-transform { transition-property: transform; transition-timing-function: cubic-bezier(.4, 0, .2, 1); transition-duration: .15s }
.duration-1000 { transition-duration: 1s }
.duration-200 { transition-duration: .2s }
.duration-300 { transition-duration: .3s }
.duration-700 { transition-duration: .7s }
.ease-in-out { transition-timing-function: cubic-bezier(.4, 0, .2, 1) }
.ease-linear { transition-timing-function: linear }

/* ===== KEYFRAMES ENTER/EXIT (para animaciones de Tailwind) ===== */
@keyframes enter {
    0% { opacity: var(--tw-enter-opacity, 1); transform: translate3d(var(--tw-enter-translate-x, 0), var(--tw-enter-translate-y, 0), 0) scale3d(var(--tw-enter-scale, 1), var(--tw-enter-scale, 1), var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0)) }
}
@keyframes exit {
    to { opacity: var(--tw-exit-opacity, 1); transform: translate3d(var(--tw-exit-translate-x, 0), var(--tw-exit-translate-y, 0), 0) scale3d(var(--tw-exit-scale, 1), var(--tw-exit-scale, 1), var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0)) }
}
.animate-in { animation-name: enter; animation-duration: .15s; --tw-enter-opacity: initial; --tw-enter-scale: initial; --tw-enter-rotate: initial; --tw-enter-translate-x: initial; --tw-enter-translate-y: initial }
.fade-in-0 { --tw-enter-opacity: 0 }
.fade-in-80 { --tw-enter-opacity: .8 }
.zoom-in-95 { --tw-enter-scale: .95 }

/* ===== COMPONENTES PERSONALIZADOS ===== */
.section-padding {
    padding-top: 60px;
    padding-bottom: 60px;
    padding-left: 1.5rem;
    padding-right: 1.5rem
}
@media (min-width: 768px) {
    .section-padding { padding: 120px 80px }
}
.section-container { margin-left: auto; margin-right: auto; max-width: 1200px }
.label-style { font-size: .75rem; line-height: 1rem; font-weight: 500; text-transform: uppercase; letter-spacing: 4px }
.heading-hero { font-size: 2.25rem; line-height: 2.5rem; font-weight: 700; line-height: 1.1; letter-spacing: -.01em }
@media (min-width: 768px) { .heading-hero { font-size: 64px } }
.heading-section { font-size: 28px; font-weight: 600; line-height: 1.2; letter-spacing: -.01em }
@media (min-width: 768px) { .heading-section { font-size: 42px } }
.heading-card { font-size: 1.125rem; line-height: 1.75rem; font-weight: 600 }
@media (min-width: 768px) { .heading-card { font-size: 1.25rem; line-height: 1.75rem } }
.body-text { font-size: 15px; font-weight: 400; line-height: 1.7 }
@media (min-width: 768px) { .body-text { font-size: 17px } }
.gold-gradient-text { background: linear-gradient(135deg, #fbf2c1, #d4af37 35%, #a67c00 65%, #5e3a1a); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent }
.stat-number { font-size: 3rem; line-height: 1; font-weight: 900 }
.stat-number { padding: 0; width: 100%; } /* nuevo */
@media (min-width: 768px) { .stat-number { font-size: 72px } }

/* ===== COMPORTAMIENTO GLOBAL ===== */
html { scroll-behavior: smooth }
.reveal { opacity: 0; transform: translateY(30px); transition: opacity .8s cubic-bezier(.25, .46, .45, .94), transform .8s cubic-bezier(.25, .46, .45, .94) }
.reveal.visible { opacity: 1; transform: translateY(0) }
.timeline-reveal { opacity: 0; transition: opacity .8s cubic-bezier(.25, .46, .45, .94), transform .8s cubic-bezier(.25, .46, .45, .94) }
.timeline-reveal[data-reveal-dir=left] { transform: translate(-40px) }
.timeline-reveal[data-reveal-dir=right] { transform: translate(40px) }
.timeline-reveal[data-reveal-dir=center] { transform: translateY(30px) }
.timeline-reveal.visible { opacity: 1; transform: translate(0) }
.nav-scrolled { background: #004b63eb !important; backdrop-filter: blur(12px) }

/* ===== PSEUDO-ELEMENTOS Y ESTADOS ===== */
.file\:border-0::file-selector-button { border-width: 0px }
.file\:bg-transparent::file-selector-button { background-color: transparent }
.file\:text-sm::file-selector-button { font-size: .875rem; line-height: 1.25rem }
.file\:font-medium::file-selector-button { font-weight: 500 }
.file\:text-foreground::file-selector-button { color: hsl(var(--foreground)) }
.placeholder\:text-muted-foreground::placeholder { color: hsl(var(--muted-foreground)) }
.after\:absolute:after { content: var(--tw-content); position: absolute }
.after\:-inset-2:after { content: var(--tw-content); top: -.5rem; right: -.5rem; bottom: -.5rem; left: -.5rem }
.after\:inset-y-0:after { content: var(--tw-content); top: 0; bottom: 0 }
.after\:left-1\/2:after { content: var(--tw-content); left: 50% }
.after\:w-1:after { content: var(--tw-content); width: .25rem }
.after\:w-\[2px\]:after { content: var(--tw-content); width: 2px }
.after\:-translate-x-1\/2:after { content: var(--tw-content); --tw-translate-x: -50%; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.first\:rounded-l-md:first-child { border-top-left-radius: calc(var(--radius) - 2px); border-bottom-left-radius: calc(var(--radius) - 2px) }
.first\:border-l:first-child { border-left-width: 1px }
.last\:rounded-r-md:last-child { border-top-right-radius: calc(var(--radius) - 2px); border-bottom-right-radius: calc(var(--radius) - 2px) }
.focus-within\:relative:focus-within { position: relative }
.focus-within\:z-20:focus-within { z-index: 20 }
.hover\:-translate-y-1\.5:hover { --tw-translate-y: -.375rem; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.hover\:bg-accent:hover { background-color: hsl(var(--accent)) }
.hover\:bg-destructive\/80:hover { background-color: hsl(var(--destructive) / .8) }
.hover\:bg-destructive\/90:hover { background-color: hsl(var(--destructive) / .9) }
.hover\:bg-muted:hover { background-color: hsl(var(--muted)) }
.hover\:bg-muted\/50:hover { background-color: hsl(var(--muted) / .5) }
.hover\:bg-primary:hover { background-color: hsl(var(--primary)) }
.hover\:bg-primary\/80:hover { background-color: hsl(var(--primary) / .8) }
.hover\:bg-primary\/90:hover { background-color: hsl(var(--primary) / .9) }
.hover\:bg-secondary:hover { background-color: hsl(var(--secondary)) }
.hover\:bg-secondary\/80:hover { background-color: hsl(var(--secondary) / .8) }
.hover\:bg-sidebar-accent:hover { background-color: hsl(var(--sidebar-accent)) }
.hover\:text-accent-foreground:hover { color: hsl(var(--accent-foreground)) }
.hover\:text-arrecife-gold:hover { --tw-text-opacity: 1; color: rgb(212 175 55 / var(--tw-text-opacity, 1)) }
.hover\:text-foreground:hover { color: hsl(var(--foreground)) }
.hover\:text-muted-foreground:hover { color: hsl(var(--muted-foreground)) }
.hover\:text-primary-foreground:hover { color: hsl(var(--primary-foreground)) }
.hover\:text-primary\/90:hover { color: hsl(var(--primary) / .9) }
.hover\:text-sidebar-accent-foreground:hover { color: hsl(var(--sidebar-accent-foreground)) }
.hover\:underline:hover { text-decoration-line: underline }
.hover\:opacity-100:hover { opacity: 1 }
.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\]:hover { --tw-shadow: 0 0 0 1px hsl(var(--sidebar-accent)); --tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color); box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) }
.hover\:after\:bg-sidebar-border:hover:after { content: var(--tw-content); background-color: hsl(var(--sidebar-border)) }
.focus\:bg-accent:focus { background-color: hsl(var(--accent)) }
.focus\:bg-primary:focus { background-color: hsl(var(--primary)) }
.focus\:text-accent-foreground:focus { color: hsl(var(--accent-foreground)) }
.focus\:text-primary-foreground:focus { color: hsl(var(--primary-foreground)) }
.focus\:opacity-100:focus { opacity: 1 }
.focus\:outline-none:focus { outline: 2px solid transparent; outline-offset: 2px }
.focus\:ring-2:focus { --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color); box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) }
.focus\:ring-ring:focus { --tw-ring-color: hsl(var(--ring)) }
.focus\:ring-offset-2:focus { --tw-ring-offset-width: 2px }
.focus-visible\:outline-none:focus-visible { outline: 2px solid transparent; outline-offset: 2px }
.focus-visible\:ring-1:focus-visible { --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color); box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) }
.focus-visible\:ring-2:focus-visible { --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color); --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color); box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) }
.focus-visible\:ring-ring:focus-visible { --tw-ring-color: hsl(var(--ring)) }
.focus-visible\:ring-sidebar-ring:focus-visible { --tw-ring-color: hsl(var(--sidebar-ring)) }
.focus-visible\:ring-offset-1:focus-visible { --tw-ring-offset-width: 1px }
.focus-visible\:ring-offset-2:focus-visible { --tw-ring-offset-width: 2px }
.focus-visible\:ring-offset-background:focus-visible { --tw-ring-offset-color: hsl(var(--background)) }
.active\:bg-sidebar-accent:active { background-color: hsl(var(--sidebar-accent)) }
.active\:text-sidebar-accent-foreground:active { color: hsl(var(--sidebar-accent-foreground)) }
.disabled\:pointer-events-none:disabled { pointer-events: none }
.disabled\:cursor-not-allowed:disabled { cursor: not-allowed }
.disabled\:opacity-50:disabled { opacity: .5 }
.group:hover .group-hover\:scale-\[1\.03\] { --tw-scale-x: 1.03; --tw-scale-y: 1.03; transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) }
.group:hover .group-hover\:fill-arrecife-gold { fill: #d4af37 }
.group:hover .group-hover\:stroke-arrecife-gold { stroke: #d4af37 }
.group:hover .group-hover\:opacity-100 { opacity: 1 }

/* ===== MEDIA QUERIES ===== */
@media (min-width: 640px) {
    .sm\:bottom-0 { bottom: 0 }
    .sm\:right-0 { right: 0 }
    .sm\:top-auto { top: auto }
    .sm\:mt-0 { margin-top: 0 }
    .sm\:flex { display: flex }
    .sm\:max-w-sm { max-width: 24rem }
    .sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) }
    .sm\:flex-row { flex-direction: row }
    .sm\:flex-col { flex-direction: column }
    .sm\:justify-end { justify-content: flex-end }
    .sm\:gap-2\.5 { gap: .625rem }
    .sm\:space-x-2 > :not([hidden]) ~ :not([hidden]) { --tw-space-x-reverse: 0; margin-right: calc(.5rem * var(--tw-space-x-reverse)); margin-left: calc(.5rem * calc(1 - var(--tw-space-x-reverse))) }
    .sm\:space-x-4 > :not([hidden]) ~ :not([hidden]) { --tw-space-x-reverse: 0; margin-right: calc(1rem * var(--tw-space-x-reverse)); margin-left: calc(1rem * calc(1 - var(--tw-space-x-reverse))) }
    .sm\:space-y-0 > :not([hidden]) ~ :not([hidden]) { --tw-space-y-reverse: 0; margin-top: calc(0px * calc(1 - var(--tw-space-y-reverse))); margin-bottom: calc(0px * var(--tw-space-y-reverse)) }
    .sm\:rounded-lg { border-radius: var(--radius) }
    .sm\:text-left { text-align: left }
}
@media (min-width: 768px) {
    .md\:absolute { position: absolute }
    .md\:order-last { order: 9999 }
    .md\:block { display: block }
    .md\:inline { display: inline }
    .md\:flex { display: flex }
    .md\:hidden { display: none }
    .md\:w-\[var\(--radix-navigation-menu-viewport-width\)\] { width: var(--radix-navigation-menu-viewport-width) }
    .md\:w-auto { width: auto }
    .md\:max-w-\[420px\] { max-width: 420px }
    .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\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) }
    .md\:grid-cols-\[1fr_auto_1fr\] { grid-template-columns: 1fr auto 1fr }
    .md\:justify-end { justify-content: flex-end }
    .md\:gap-0 { gap: 0px }
    .md\:gap-20 { gap: 5rem }
    .md\:px-10 { padding-left: 2.5rem; padding-right: 2.5rem }
    .md\:py-16 { padding-top: 4rem; padding-bottom: 4rem }
    .md\:pl-10 { padding-left: 2.5rem }
    .md\:text-left { text-align: left }
    .md\:text-right { text-align: right }
    .md\:text-2xl { font-size: 1.5rem; line-height: 2rem }
    .md\:text-6xl { font-size: 3.75rem; line-height: 1 }
    .md\:text-\[17px\] { font-size: 17px }
    .md\:text-\[22px\] { font-size: 22px }
    .md\:text-\[56px\] { font-size: 56px }
    .md\:text-sm { font-size: .875rem; line-height: 1.25rem }
    .md\:opacity-0 { opacity: 0 }
    .after\:md\:hidden:after { content: var(--tw-content); display: none }
}
@media (min-width: 1024px) {
    .lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) }
}