/* Akriveia Utilities (Tailwind-free) */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
html{line-height:1.5;-webkit-text-size-adjust:100%}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{color:inherit;text-decoration:inherit}
button,input,select,textarea{font:inherit}
:root{--tw-gradient-from:#000;--tw-gradient-to:rgba(0,0,0,0);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.absolute{position:absolute}
.after\:absolute::after{position:absolute}
.after\:bg-blue-900::after{background-color:#1e3a8a}
.after\:bottom-0::after{bottom:0}
.after\:duration-300::after{transition-duration:300ms}
.after\:h-\[2px\]::after{height:2px}
.after\:left-0::after{left:0}
.after\:transition-all::after{transition:all 150ms cubic-bezier(0.4,0,0.2,1)}
.after\:w-0::after{width:0}
.backdrop-blur{backdrop-filter:blur(8px)}
.backdrop-blur-sm{backdrop-filter:blur(4px)}
.bg-\[\#0D1B2A\]{background-color:#0D1B2A}
.bg-\[\#1B263B\]{background-color:#1B263B}
.bg-black{background-color:#000000}
.bg-black\/50{background-color:rgba(0,0,0,0.5)}
.bg-blue-100{background-color:#dbeafe}
.bg-blue-900{background-color:#1e3a8a}
.bg-gradient-to-b{background-image:linear-gradient(to bottom, var(--tw-gradient-stops))}
.bg-gradient-to-br{background-image:linear-gradient(to bottom right, var(--tw-gradient-stops))}
.bg-gradient-to-r{background-image:linear-gradient(to right, var(--tw-gradient-stops))}
.bg-gray-50{background-color:#f9fafb}
.bg-gray-800{background-color:#1f2937}
.bg-gray-900{background-color:#111827}
.bg-green-500{background-color:#22c55e}
.bg-opacity-30{opacity:0.3}
.bg-opacity-50{opacity:0.5}
.bg-white{background-color:#ffffff}
.block{display:block}
.border{border-width:1px;border-style:solid}
.border-dashed{border-style:dashed}
.border-gray-100{border-color:#f3f4f6}
.border-gray-200{border-color:#e5e7eb}
.border-gray-300{border-color:#d1d5db}
.border-t{border-top-width:1px;border-style:solid}
.bottom-20{bottom:5rem}
.bottom-4{bottom:1rem}
.bottom-6{bottom:1.5rem}
.disabled\:opacity-70:disabled{opacity:0.7}
.duration-300{transition-duration:300ms}
.fixed{position:fixed}
.flex{display:flex}
.flex-1{flex:1 1 0%}
.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.focus\:border-blue-900:focus{border-color:#1e3a8a}
.focus\:outline-blue-500:focus{outline-color:#3b82f6}
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}
.focus\:ring-blue-900:focus{box-shadow:0 0 0 3px rgba(30,58,138,0.35)}
.font-bold{font-weight:700}
.font-medium{font-weight:500}
.font-semibold{font-weight:600}
.from-\[\#0D1B2A\]{--tw-gradient-from:#0D1B2A;--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to, rgba(255,255,255,0))}
.from-black{--tw-gradient-from:#000000;--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to, rgba(255,255,255,0))}
.from-blue-900{--tw-gradient-from:#1e3a8a;--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to, rgba(255,255,255,0))}
.from-white{--tw-gradient-from:#ffffff;--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to, rgba(255,255,255,0))}
.gap-1{gap:0.25rem}
.gap-10{gap:2.5rem}
.gap-12{gap:3rem}
.gap-16{gap:4rem}
.gap-2{gap:0.5rem}
.gap-3{gap:0.75rem}
.gap-4{gap:1rem}
.gap-6{gap:1.5rem}
.gap-8{gap:2rem}
.gap-x-4{column-gap:1rem}
.gap-y-2{row-gap:0.5rem}
.grid{display:grid}
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.group:hover .group-hover\:opacity-100{opacity:1}
.group:hover .group-hover\:pointer-events-auto{pointer-events:auto}
.group:hover .group-hover\:scale-100{transform:scale(1)}
.h-1{height:0.25rem}
.h-16{height:4rem}
.h-24{height:6rem}
.h-32{height:8rem}
.h-4{height:1rem}
.h-5{height:1.25rem}
.h-6{height:1.5rem}
.h-72{height:18rem}
.h-96{height:24rem}
.h-\[375px\]{height:375px}
.h-\[480px\]{height:480px}
.h-full{height:100%}
.hidden{display:none}
.hover\:after\:w-full:hover::after{width:100%}
.hover\:bg-\[\#1B263B\]:hover{background-color:#1B263B}
.hover\:bg-black:hover{background-color:#000000}
.hover\:bg-blue-100:hover{background-color:#dbeafe}
.hover\:bg-blue-800:hover{background-color:#1e40af}
.hover\:bg-gray-100:hover{background-color:#f3f4f6}
.hover\:bg-green-600:hover{background-color:#16a34a}
.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -2px rgba(0,0,0,0.05)}
.hover\:shadow-xl:hover{box-shadow:0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04)}
.hover\:text-black:hover{color:#000000}
.hover\:text-blue-600:hover{color:#2563eb}
.hover\:text-blue-700:hover{color:#1d4ed8}
.hover\:underline:hover{text-decoration:underline}
.inline-flex{display:inline-flex}
.inset-0{top:0;right:0;bottom:0;left:0}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.justify-between{justify-content:space-between}
.justify-center{justify-content:center}
.justify-end{justify-content:flex-end}
.leading-loose{line-height:2}
.leading-relaxed{line-height:1.625}
.leading-tight{line-height:1.25}
.left-0{left:0}
.left-4{left:1rem}
.left-6{left:1.5rem}
.max-w-2xl{max-width:42rem}
.max-w-3xl{max-width:48rem}
.max-w-4xl{max-width:56rem}
.max-w-5xl{max-width:64rem}
.max-w-7xl{max-width:80rem}
.max-w-\[600px\]{max-width:600px}
.max-w-\[720px\]{max-width:720px}
.max-w-md{max-width:28rem}
.max-w-prose{max-width:65ch}
.max-w-sm{max-width:24rem}
.max-w-xl{max-width:36rem}
.mb-1{margin-bottom:0.25rem}
.mb-12{margin-bottom:3rem}
.mb-2{margin-bottom:0.5rem}
.mb-4{margin-bottom:1rem}
.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}
@media (min-width:768px){.bottom-24{bottom:6rem}
}
@media (min-width:768px){.flex{display:flex}
}
@media (min-width:768px){.flex-row{flex-direction:row}
}
@media (min-width:768px){.flex-row-reverse{flex-direction:row-reverse}
}
@media (min-width:768px){.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (min-width:768px){.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (min-width:768px){.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (min-width:768px){.h-\[500px\]{height:500px}
}
@media (min-width:768px){.hidden{display:none}
}
@media (min-width:768px){.inline{display:inline}
}
@media (min-width:768px){.items-start{align-items:flex-start}
}
@media (min-width:768px){.justify-end{justify-content:flex-end}
}
@media (min-width:768px){.left-6{left:1.5rem}
}
@media (min-width:768px){.right-6{right:1.5rem}
}
@media (min-width:768px){.text-4xl{font-size:2.25rem;line-height:1.25}
}
@media (min-width:768px){.text-5xl{font-size:3rem;line-height:1.25}
}
@media (min-width:768px){.text-left{text-align:left}
}
@media (min-width:768px){.text-sm{font-size:0.875rem;line-height:1.25}
}
.min-h-screen{min-height:100vh}
.ml-1{margin-left:0.25rem}
.ml-auto{margin-left:auto}
.mt-1{margin-top:0.25rem}
.mt-2{margin-top:0.5rem}
.mt-24{margin-top:6rem}
.mt-3{margin-top:0.75rem}
.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}
.mt-8{margin-top:2rem}
.mx-auto{margin-left:auto;margin-right:auto}
.my-4{margin-top:1rem;margin-bottom:1rem}
.object-contain{object-fit:contain}
.object-cover{object-fit:cover}
.opacity-0{opacity:0}
.opacity-95{opacity:0.95}
.overflow-hidden{overflow:hidden}
.p-1{padding:0.25rem}
.p-2{padding:0.5rem}
.p-3{padding:0.75rem}
.p-4{padding:1rem}
.p-5{padding:1.25rem}
.p-6{padding:1.5rem}
.p-8{padding:2rem}
.pointer-events-none{pointer-events:none}
.pt-2{padding-top:0.5rem}
.pt-6{padding-top:1.5rem}
.pt-8{padding-top:2rem}
.pt-\[120px\]{padding-top:120px}
.pt-\[40px\]{padding-top:40px}
.px-2{padding-left:0.5rem;padding-right:0.5rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.px-8{padding-left:2rem;padding-right:2rem}
.py-1{padding-top:0.25rem;padding-bottom:0.25rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.py-2{padding-top:0.5rem;padding-bottom:0.5rem}
.py-20{padding-top:5rem;padding-bottom:5rem}
.py-24{padding-top:6rem;padding-bottom:6rem}
.py-3{padding-top:0.75rem;padding-bottom:0.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-5{padding-top:1.25rem;padding-bottom:1.25rem}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.relative{position:relative}
.right-4{right:1rem}
.right-6{right:1.5rem}
.rounded{border-radius:0.25rem}
.rounded-2xl{border-radius:1rem}
.rounded-full{border-radius:9999px}
.rounded-lg{border-radius:0.5rem}
.rounded-md{border-radius:0.375rem}
.rounded-xl{border-radius:0.75rem}
.shadow{box-shadow:0 1px 3px 0 rgba(0,0,0,0.1),0 1px 2px 0 rgba(0,0,0,0.06)}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -2px rgba(0,0,0,0.05)}
.shadow-md{box-shadow:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -1px rgba(0,0,0,0.06)}
.shadow-sm{box-shadow:0 1px 2px 0 rgba(0,0,0,0.05)}
.shadow-xl{box-shadow:0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04)}
@media (min-width:640px){.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (min-width:640px){.h-\[400px\]{height:400px}
}
.space-x-2 > :not([hidden]) ~ :not([hidden]){margin-left:0.5rem}
.space-x-6 > :not([hidden]) ~ :not([hidden]){margin-left:1.5rem}
.space-y-10 > :not([hidden]) ~ :not([hidden]){margin-top:2.5rem}
.space-y-2 > :not([hidden]) ~ :not([hidden]){margin-top:0.5rem}
.space-y-24 > :not([hidden]) ~ :not([hidden]){margin-top:6rem}
.space-y-3 > :not([hidden]) ~ :not([hidden]){margin-top:0.75rem}
.space-y-4 > :not([hidden]) ~ :not([hidden]){margin-top:1rem}
.space-y-5 > :not([hidden]) ~ :not([hidden]){margin-top:1.25rem}
.space-y-6 > :not([hidden]) ~ :not([hidden]){margin-top:1.5rem}
.space-y-8 > :not([hidden]) ~ :not([hidden]){margin-top:2rem}
.text-2xl{font-size:1.5rem;line-height:1.25}
.text-3xl{font-size:1.875rem;line-height:1.25}
.text-4xl{font-size:2.25rem;line-height:1.25}
.text-5xl{font-size:3rem;line-height:1.25}
.text-\[\#0D1B2A\]{color:#0D1B2A}
.text-base{font-size:1rem;line-height:1.25}
.text-blue-700{color:#1d4ed8}
.text-blue-800{color:#1e40af}
.text-blue-900{color:#1e3a8a}
.text-center{text-align:center}
.text-gray-300{color:#d1d5db}
.text-gray-400{color:#9ca3af}
.text-gray-500{color:#6b7280}
.text-gray-600{color:#4b5563}
.text-gray-700{color:#374151}
.text-gray-800{color:#1f2937}
.text-gray-900{color:#111827}
.text-green-700{color:#15803d}
.text-justify{text-align:justify}
.text-left{text-align:left}
.text-lg{font-size:1.125rem;line-height:1.25}
.text-red-600{color:#dc2626}
.text-red-700{color:#b91c1c}
.text-sm{font-size:0.875rem;line-height:1.25}
.text-white{color:#ffffff}
.text-xl{font-size:1.25rem;line-height:1.25}
.text-xs{font-size:0.75rem;line-height:1rem}
.to-\[\#0D1B2A\]{--tw-gradient-to:#0D1B2A}
.to-black{--tw-gradient-to:#000000}
.to-blue-700{--tw-gradient-to:#1d4ed8}
.to-white{--tw-gradient-to:#ffffff}
.top-0{top:0}
.top-4{top:1rem}
.top-full{top:100%}
.transform{transform:translateZ(0)}
.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(0.4,0,0.2,1);transition-duration:150ms}
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(0.4,0,0.2,1);transition-duration:150ms}
.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(0.4,0,0.2,1);transition-duration:150ms}
.underline{text-decoration:underline}
.via-\[\#1B263B\]{--tw-gradient-stops:var(--tw-gradient-from), #1B263B, var(--tw-gradient-to, rgba(255,255,255,0))}
.via-black{--tw-gradient-stops:var(--tw-gradient-from), #000000, var(--tw-gradient-to, rgba(255,255,255,0))}
.via-gray-50{--tw-gradient-stops:var(--tw-gradient-from), #f9fafb, var(--tw-gradient-to, rgba(255,255,255,0))}
.via-gray-900{--tw-gradient-stops:var(--tw-gradient-from), #111827, var(--tw-gradient-to, rgba(255,255,255,0))}
.w-16{width:4rem}
.w-20{width:5rem}
.w-24{width:6rem}
.w-32{width:8rem}
.w-4{width:1rem}
.w-5{width:1.25rem}
.w-6{width:1.5rem}
.w-64{width:16rem}
.w-full{width:100%}
.z-0{z-index:0}
.z-10{z-index:10}
.z-40{z-index:40}
.z-50{z-index:50}
.z-\[1000\]{z-index:1000}
.z-\[1001\]{z-index:1001}
.z-\[100\]{z-index:100}
.z-\[9999\]{z-index:9999}
/* ===== PATCH: Missing responsive + color utilities (Tailwind-free) ===== */

/* base */
.inline-block{display:inline-block}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.scroll-smooth{scroll-behavior:smooth}
.scale-95{--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x,0),var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}
.aspect-video{aspect-ratio:16/9}
.form-checkbox{appearance:auto}

/* hex colors used in your markup */
.bg-\[\#0D1B2A\]{background-color:#0D1B2A}
.bg-\[\#1B263B\]{background-color:#1B263B}
.text-\[\#0D1B2A\]{color:#0D1B2A}

/* gradient stops for hex variants */
.from-\[\#0D1B2A\]{--tw-gradient-from:#0D1B2A;--tw-gradient-to:rgba(13,27,42,0);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.via-\[\#1B263B\]{--tw-gradient-stops:var(--tw-gradient-from),#1B263B,var(--tw-gradient-to)}
.to-\[\#0D1B2A\]{--tw-gradient-to:#0D1B2A}

/* hover hex background */
.hover\:bg-\[\#1B263B\]:hover{background-color:#1B263B}

/* font weight */
.font-extrabold{font-weight:800}

/* simple animations referenced by your classes */
@keyframes slide-in{0%{opacity:0;transform:translateY(16px)}100%{opacity:1;transform:none}}
.animate-slide-in{animation:slide-in .7s ease both}

@keyframes pulse-gradient{0%,100%{opacity:1}50%{opacity:.6}}
.animate-pulse-gradient{animation:pulse-gradient 2.2s ease-in-out infinite}

/* responsive: sm (>=640px) */
@media (min-width:640px){
  .sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sm\:h-\[400px\]{height:400px}
}

/* responsive: md (>=768px) */
@media (min-width:768px){
  .md\:flex{display:flex}
  .md\:hidden{display:none}
  .md\:inline{display:inline}
  .md\:flex-row{flex-direction:row}
  .md\:flex-row-reverse{flex-direction:row-reverse}

  .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\:items-start{align-items:flex-start}
  .md\:justify-end{justify-content:flex-end}

  .md\:text-left{text-align:left}
  .md\:text-sm{font-size:.875rem;line-height:1.25rem}
  .md\:text-4xl{font-size:2.25rem;line-height:2.5rem}
  .md\:text-5xl{font-size:3rem;line-height:1}

  .md\:h-\[500px\]{height:500px}

  .md\:left-6{left:1.5rem}
  .md\:right-6{right:1.5rem}
  .md\:bottom-24{bottom:6rem}
}