*,
:after,
:before {
    --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: rgba(59, 130, 246, 0.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: ;
}
::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: rgba(59, 130, 246, 0.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: ;
}
/*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com*/
*,
:after,
:before {
    box-sizing: border-box;
    border: 0 solid #e5e7eb;
}
:after,
:before {
    --tw-content: '';
}
:host,
html {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    font-family: Inter, sans-serif;
    font-feature-settings: normal;
    font-variation-settings: normal;
    -webkit-tap-highlight-color: transparent;
}
body {
    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,
pre,
samp {
    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: -0.25em;
}
sup {
    top: -0.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;
}
::-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,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
p,
pre {
    margin: 0;
}
fieldset {
    margin: 0;
}
fieldset,
legend {
    padding: 0;
}
menu,
ol,
ul {
    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;
}
[role='button'],
button {
    cursor: pointer;
}
:disabled {
    cursor: default;
}
audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
    display: block;
    vertical-align: middle;
}
img,
video {
    max-width: 100%;
    height: auto;
}
[hidden]:where(:not([hidden='until-found'])) {
    display: none;
}
.\!container {
    width: 100% !important;
}
.container {
    width: 100%;
}
@media (min-width: 640px) {
    .\!container {
        max-width: 640px !important;
    }
    .container {
        max-width: 640px;
    }
}
@media (min-width: 768px) {
    .\!container {
        max-width: 768px !important;
    }
    .container {
        max-width: 768px;
    }
}
@media (min-width: 1024px) {
    .\!container {
        max-width: 1024px !important;
    }
    .container {
        max-width: 1024px;
    }
}
@media (min-width: 1280px) {
    .\!container {
        max-width: 1280px !important;
    }
    .container {
        max-width: 1280px;
    }
}
@media (min-width: 1536px) {
    .\!container {
        max-width: 1536px !important;
    }
    .container {
        max-width: 1536px;
    }
}
.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;
}
.\!visible {
    visibility: visible !important;
}
.visible {
    visibility: visible;
}
.static {
    position: static;
}
.fixed {
    position: fixed;
}
.absolute {
    position: absolute;
}
.relative {
    position: relative;
}
.sticky {
    position: sticky;
}
.-bottom-5 {
    bottom: -1.25rem;
}
.-right-2\.5 {
    right: -0.625rem;
}
.bottom-4 {
    bottom: 1rem;
}
.left-0 {
    left: 0;
}
.left-1\/2 {
    left: 50%;
}
.right-0 {
    right: 0;
}
.right-4 {
    right: 1rem;
}
.top-0 {
    top: 0;
}
.z-10 {
    z-index: 10;
}
.z-50 {
    z-index: 50;
}
.z-\[60\] {
    z-index: 60;
}
.-mx-4 {
    margin-left: -1rem;
    margin-right: -1rem;
}
.mx-auto {
    margin-left: auto;
    margin-right: auto;
}
.my-12 {
    margin-top: 3rem;
    margin-bottom: 3rem;
}
.my-24 {
    margin-top: 6rem;
    margin-bottom: 6rem;
}
.-mt-4 {
    margin-top: -1rem;
}
.mb-1 {
    margin-bottom: 0.25rem;
}
.mb-12 {
    margin-bottom: 3rem;
}
.mb-2 {
    margin-bottom: 0.5rem;
}
.mb-3 {
    margin-bottom: 0.75rem;
}
.mb-6 {
    margin-bottom: 1.5rem;
}
.mb-8 {
    margin-bottom: 2rem;
}
.ml-3 {
    margin-left: 0.75rem;
}
.ml-4 {
    margin-left: 1rem;
}
.mt-1 {
    margin-top: 0.25rem;
}
.mt-1\.5 {
    margin-top: 0.375rem;
}
.mt-12 {
    margin-top: 3rem;
}
.mt-2 {
    margin-top: 0.5rem;
}
.mt-3 {
    margin-top: 0.75rem;
}
.mt-4 {
    margin-top: 1rem;
}
.mt-8 {
    margin-top: 2rem;
}
.line-clamp-4 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
}
.block {
    display: block;
}
.inline-block {
    display: inline-block;
}
.inline {
    display: inline;
}
.flex {
    display: flex;
}
.inline-flex {
    display: inline-flex;
}
.\!grid {
    display: grid !important;
}
.grid {
    display: grid;
}
.hidden {
    display: none;
}
.h-32 {
    height: 8rem;
}
.h-4 {
    height: 1rem;
}
.h-6 {
    height: 1.5rem;
}
.h-64 {
    height: 16rem;
}
.h-full {
    height: 100%;
}
.max-h-\[80vh\] {
    max-height: 80vh;
}
.min-h-\[200px\] {
    min-height: 200px;
}
.w-4 {
    width: 1rem;
}
.w-6 {
    width: 1.5rem;
}
.w-64 {
    width: 16rem;
}
.w-96 {
    width: 24rem;
}
.w-full {
    width: 100%;
}
.max-w-2xl {
    max-width: 42rem;
}
.flex-1 {
    flex: 1 1 0%;
}
.-translate-x-1\/2 {
    --tw-translate-x: -50%;
}
.-translate-x-1\/2,
.transform {
    transform: translate(var(--tw-translate-x), 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));
}
.resize-none {
    resize: none;
}
.resize {
    resize: both;
}
.flex-col {
    flex-direction: column;
}
.flex-wrap {
    flex-wrap: wrap;
}
.items-start {
    align-items: flex-start;
}
.items-center {
    align-items: center;
}
.justify-center {
    justify-content: center;
}
.justify-between {
    justify-content: space-between;
}
.gap-1 {
    gap: 0.25rem;
}
.gap-12 {
    gap: 3rem;
}
.gap-2 {
    gap: 0.5rem;
}
.gap-3 {
    gap: 0.75rem;
}
.gap-4 {
    gap: 1rem;
}
.gap-5 {
    gap: 1.25rem;
}
.gap-8 {
    gap: 2rem;
}
.space-x-6 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-right: calc(1.5rem * var(--tw-space-x-reverse));
    margin-left: calc(1.5rem * (1 - var(--tw-space-x-reverse)));
}
.space-x-8 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-right: calc(2rem * var(--tw-space-x-reverse));
    margin-left: calc(2rem * (1 - var(--tw-space-x-reverse)));
}
.space-y-4 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1rem * (1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}
.space-y-8 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2rem * (1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2rem * var(--tw-space-y-reverse));
}
.space-x-reverse > :not([hidden]) ~ :not([hidden]) {
    --tw-space-x-reverse: 1;
}
.overflow-hidden {
    overflow: hidden;
}
.scroll-smooth {
    scroll-behavior: smooth;
}
.rounded {
    border-radius: 0.25rem;
}
.rounded-full {
    border-radius: 9999px;
}
.rounded-lg {
    border-radius: 0.5rem;
}
.rounded-md {
    border-radius: 0.375rem;
}
.rounded-t {
    border-top-left-radius: 0.25rem;
    border-top-right-radius: 0.25rem;
}
.rounded-t-lg {
    border-top-left-radius: 0.5rem;
    border-top-right-radius: 0.5rem;
}
.border {
    border-width: 1px;
}
.border-4 {
    border-width: 4px;
}
.border-r-2 {
    border-right-width: 2px;
}
.border-t {
    border-top-width: 1px;
}
.border-brand-card {
    --tw-border-opacity: 1;
    border-color: rgb(30 30 30 / var(--tw-border-opacity, 1));
}
.border-gray-700 {
    --tw-border-opacity: 1;
    border-color: rgb(55 65 81 / var(--tw-border-opacity, 1));
}
.border-gray-800 {
    --tw-border-opacity: 1;
    border-color: rgb(31 41 55 / var(--tw-border-opacity, 1));
}
.bg-black {
    --tw-bg-opacity: 1;
    background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}
.bg-brand-card {
    --tw-bg-opacity: 1;
    background-color: rgb(30 30 30 / var(--tw-bg-opacity, 1));
}
.bg-brand-dark {
    --tw-bg-opacity: 1;
    background-color: rgb(18 18 18 / var(--tw-bg-opacity, 1));
}
.bg-brand-dark\/70 {
    background-color: hsla(0, 0%, 7%, 0.7);
}
.bg-brand-red {
    --tw-bg-opacity: 1;
    background-color: rgb(217 35 35 / var(--tw-bg-opacity, 1));
}
.bg-brand-red\/5 {
    background-color: rgba(217, 35, 35, 0.05);
}
.bg-brand-red\/80 {
    background-color: rgba(217, 35, 35, 0.8);
}
.bg-gray-700 {
    --tw-bg-opacity: 1;
    background-color: rgb(55 65 81 / var(--tw-bg-opacity, 1));
}
.bg-gray-800 {
    --tw-bg-opacity: 1;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}
.bg-red-700 {
    --tw-bg-opacity: 1;
    background-color: rgb(185 28 28 / var(--tw-bg-opacity, 1));
}
.object-cover {
    -o-object-fit: cover;
    object-fit: cover;
}
.p-2 {
    padding: 0.5rem;
}
.p-3 {
    padding: 0.75rem;
}
.p-4 {
    padding: 1rem;
}
.p-8 {
    padding: 2rem;
}
.px-2 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}
.px-3 {
    padding-left: 0.75rem;
    padding-right: 0.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: 0.125rem;
    padding-bottom: 0.125rem;
}
.py-1 {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}
.py-12 {
    padding-top: 3rem;
    padding-bottom: 3rem;
}
.py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}
.py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}
.py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}
.pb-2 {
    padding-bottom: 0.5rem;
}
.pb-4 {
    padding-bottom: 1rem;
}
.pr-8 {
    padding-right: 2rem;
}
.pt-8 {
    padding-top: 2rem;
}
.text-center {
    text-align: center;
}
.font-arabic {
    font-family:
        IBM Plex Sans Arabic,
        Cairo,
        Tahoma,
        sans-serif;
}
.font-mono {
    font-family:
        ui-monospace,
        SFMono-Regular,
        Menlo,
        Monaco,
        Consolas,
        Liberation Mono,
        Courier New,
        monospace;
}
.font-sans {
    font-family: Inter, sans-serif;
}
.text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
}
.text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
}
.text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
}
.text-\[10px\] {
    font-size: 10px;
}
.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
}
.text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
}
.text-xs {
    font-size: 0.75rem;
    line-height: 1rem;
}
.font-bold {
    font-weight: 700;
}
.font-extrabold {
    font-weight: 800;
}
.font-semibold {
    font-weight: 600;
}
.uppercase {
    text-transform: uppercase;
}
.leading-relaxed {
    line-height: 1.625;
}
.leading-snug {
    line-height: 1.375;
}
.leading-tight {
    line-height: 1.25;
}
.tracking-wide {
    letter-spacing: 0.025em;
}
.text-brand-gray {
    --tw-text-opacity: 1;
    color: rgb(160 160 160 / var(--tw-text-opacity, 1));
}
.text-brand-light-gray {
    --tw-text-opacity: 1;
    color: rgb(245 245 245 / var(--tw-text-opacity, 1));
}
.text-brand-red {
    --tw-text-opacity: 1;
    color: rgb(217 35 35 / var(--tw-text-opacity, 1));
}
.text-gray-200 {
    --tw-text-opacity: 1;
    color: rgb(229 231 235 / var(--tw-text-opacity, 1));
}
.text-gray-300 {
    --tw-text-opacity: 1;
    color: rgb(209 213 219 / var(--tw-text-opacity, 1));
}
.text-gray-400 {
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}
.text-gray-500 {
    --tw-text-opacity: 1;
    color: rgb(107 114 128 / var(--tw-text-opacity, 1));
}
.text-green-400 {
    --tw-text-opacity: 1;
    color: rgb(74 222 128 / var(--tw-text-opacity, 1));
}
.text-red-400 {
    --tw-text-opacity: 1;
    color: rgb(248 113 113 / var(--tw-text-opacity, 1));
}
.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.opacity-60 {
    opacity: 0.6;
}
.shadow {
    --tw-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
    --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
}
.shadow,
.shadow-lg {
    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 rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
    --tw-shadow-colored:
        0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
}
.shadow-xl {
    --tw-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 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);
}
.shadow-black\/20 {
    --tw-shadow-color: rgba(0, 0, 0, 0.2);
    --tw-shadow: var(--tw-shadow-colored);
}
.outline-none {
    outline: 2px solid transparent;
    outline-offset: 2px;
}
.outline {
    outline-style: solid;
}
.ring {
    --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(3px + var(--tw-ring-offset-width))
        var(--tw-ring-color);
}
.ring,
.ring-4 {
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}
.ring-4 {
    --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(4px + var(--tw-ring-offset-width))
        var(--tw-ring-color);
}
.ring-brand-red\/60 {
    --tw-ring-color: rgba(217, 35, 35, 0.6);
}
.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-lg {
    --tw-backdrop-blur: blur(16px);
    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);
}
.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: 0.15s;
}
.transition-all {
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.15s;
}
.transition-colors {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.15s;
}
.transition-opacity {
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 0.15s;
}
.duration-300 {
    transition-duration: 0.3s;
}
:root {
    --color-bg: #121212;
    --color-text: #f5f5f5;
    --color-card: #1e1e1e;
    --color-accent: #d92323;
    --color-gray: #a0a0a0;
    --color-gray-border: #2a2a2a;
}
:root.light {
    --color-bg: #fff;
    --color-text: #121212;
    --color-card: #f5f5f5;
    --color-accent: #d92323;
    --color-gray: #555;
    --color-gray-border: #ddd;
}
body {
    font-family: Inter, Arial, sans-serif;
    margin: 0;
    padding: 0;
    background: var(--color-bg);
    color: var(--color-text);
}
.section-head {
    --sh-fz: clamp(1.25rem, 0.85rem + 1vw, 1.7rem);
    font-family:
        Plus Jakarta Sans,
        Inter,
        system-ui,
        sans-serif;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    position: relative;
    display: block;
    width: 100%;
    margin: 0 0 1.25rem;
    padding: 0.9rem 1.1rem 1rem;
    background: linear-gradient(90deg, rgba(217, 35, 35, 0.22), rgba(217, 35, 35, 0) 70%);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    border-top: 1px solid hsla(0, 0%, 100%, 0.06);
    border-bottom: 1px solid hsla(0, 0%, 100%, 0.06);
    color: #fff;
    opacity: 0;
    transform: translateY(18px);
    filter: blur(6px);
    transition:
        opacity 0.7s cubic-bezier(0.22, 0.61, 0.36, 1),
        transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1),
        filter 0.9s ease;
}
.section-head[data-inview='true'] {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}
.section-head .sh-core {
    font-size: var(--sh-fz);
    font-weight: 800;
}
.section-head .sh-accent {
    background: linear-gradient(90deg, #fff, #ffb4b4 45%, #ffdad9);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    position: relative;
}
.section-head .sh-accent[data-rotating] {
    position: relative;
    display: inline-block;
}
.section-head .sh-accent[data-rotating].sh-rotate-out {
    animation: shWordOut 0.5s forwards;
}
.section-head .sh-accent[data-rotating].sh-rotate-in {
    animation: shWordIn 0.5s forwards;
}
@keyframes shWordOut {
    0% {
        opacity: 1;
        transform: translateY(0) rotateX(0);
    }
    to {
        opacity: 0;
        transform: translateY(-55%) rotateX(55deg);
    }
}
@keyframes shWordIn {
    0% {
        opacity: 0;
        transform: translateY(55%) rotateX(-55deg);
    }
    to {
        opacity: 1;
        transform: translateY(0) rotateX(0);
    }
}
@keyframes shAccentGlow {
    0%,
    to {
        opacity: 0;
    }
    45% {
        opacity: 0.9;
    }
}
@media (prefers-reduced-motion: reduce) {
    .section-head {
        transition: none !important;
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }
}
:root.light .section-head {
    color: #121212;
    background: linear-gradient(90deg, rgba(217, 35, 35, 0.12), rgba(217, 35, 35, 0) 70%);
}
:root.light .section-head .sh-accent {
    filter: drop-shadow(0 0 1px rgba(0, 0, 0, 0.15));
}
.bg-brand-dark {
    background-color: var(--color-bg) !important;
}
.bg-brand-card {
    background-color: var(--color-card) !important;
}
.text-brand-light-gray {
    color: var(--color-text) !important;
}
.text-brand-gray {
    color: var(--color-gray) !important;
}
.text-brand-red {
    color: var(--color-accent) !important;
}
.border-gray-800 {
    border-color: var(--color-gray-border) !important;
}
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}
.focus\:not-sr-only:focus,
.sr-only:active,
.sr-only:focus {
    position: static;
    width: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    clip: auto;
}
.gradient-text {
    background: linear-gradient(90deg, #d92323, #ff6b6b);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.card-hover-effect {
    transition:
        transform 0.3s ease,
        box-shadow 0.3s ease;
}
.card-hover-effect:hover {
    transform: translateY(-8px);
    box-shadow:
        0 20px 25px -5px rgba(217, 35, 35, 0.1),
        0 10px 10px -5px rgba(217, 35, 35, 0.08);
}
.projects-carousel-wrapper {
    position: relative;
    padding: 0 2.5rem;
}
.projects-row {
    display: flex;
    gap: 0;
    overflow: visible;
    will-change: transform;
}
.projects-row::-webkit-scrollbar {
    height: 8px;
}
.projects-row::-webkit-scrollbar-track {
    background: transparent;
}
.projects-row::-webkit-scrollbar-thumb {
    background: hsla(0, 0%, 100%, 0.12);
    border-radius: 4px;
}
.projects-row > .project-card {
    flex: 0 0 clamp(240px, 38vw, 340px);
    scroll-snap-align: start;
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--color-card);
    border: 1px solid var(--color-gray-border);
    border-radius: 0.75rem;
    overflow: hidden;
    transition:
        transform 0.35s ease,
        box-shadow 0.35s ease;
}
.projects-row > .project-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 24px -6px rgba(217, 35, 35, 0.25);
}
.project-card img {
    height: 140px;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
}
.project-card.has-lid img {
    display: none;
}
.project-card .project-lid {
    height: 150px;
    background: var(--lid-bg, var(--color-card));
    border: 1px solid var(--color-gray-border);
    border-bottom: none;
    border-radius: 0.75rem 0.75rem 0 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    font-size: clamp(1rem, 0.6rem + 1.2vw, 1.6rem);
    font-weight: 600;
    letter-spacing: -0.5px;
    color: #111;
    overflow: hidden;
    cursor: default;
    transition:
        transform 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
        box-shadow 0.45s ease;
    background-size: cover;
    background-position: 50%;
}
.project-card .project-lid:before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0.55));
    opacity: 0.4;
    pointer-events: none;
    transition: opacity 0.4s ease;
}
.project-card .project-lid:hover:before {
    opacity: 0.25;
}
.project-card .project-lid.is-dark {
    color: #f5f5f5;
}
.project-card .project-lid .proj-gh {
    position: absolute;
    top: 0.55rem;
    right: 0.55rem;
    color: hsla(0, 0%, 100%, 0.8);
    width: 20px;
    height: 20px;
}
.project-card .project-lid:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}
.project-card .project-body {
    background: var(--color-card);
    border: 1px solid var(--color-gray-border);
    border-radius: 0 0 0.75rem 0.75rem;
    margin-top: -14px;
    padding: 1.25rem 1rem 1.1rem;
    position: relative;
    z-index: 1;
    box-shadow: 0 4px 10px -2px rgba(0, 0, 0, 0.4);
    transition: box-shadow 0.4s ease;
}
.project-card .project-lid:hover,
.project-card:hover .project-lid {
    transform: translateY(-18px);
    box-shadow:
        0 18px 28px -10px rgba(217, 35, 35, 0.45),
        0 10px 18px -8px rgba(0, 0, 0, 0.5);
}
.project-card:hover .project-body {
    box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.55);
}
@media (prefers-reduced-motion: reduce) {
    .project-card .project-lid {
        transition: none;
    }
}
.project-card .project-body {
    padding: 0.85rem 1rem 1rem;
}
.project-card h3 {
    font-size: 1.05rem;
    line-height: 1.25rem;
}
.project-card p {
    font-size: 0.75rem;
    line-height: 1.05rem;
    margin-top: 0.25rem;
}
.project-card .tech-tags {
    margin-top: 0.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}
.project-card .tech-tags span {
    background: #2a2a2a;
    font-size: 0.55rem;
    padding: 0.25rem 0.5rem;
    border-radius: 999px;
    letter-spacing: 0.25px;
}
.proj-nav-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid hsla(0, 0%, 100%, 0.15);
    color: #fff;
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    cursor: pointer;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    transition:
        background 0.25s ease,
        transform 0.25s ease;
    z-index: 5;
}
.proj-nav-btn:focus-visible,
.proj-nav-btn:hover {
    background: rgba(217, 35, 35, 0.75);
    outline: none;
}
.proj-nav-btn:active {
    transform: translateY(-50%) scale(0.9);
}
.proj-nav-btn.left-0 {
    left: 0.25rem;
}
.proj-nav-btn.right-0 {
    right: 0.25rem;
}
@media (max-width: 640px) {
    .projects-carousel-wrapper {
        padding: 0 1.75rem;
    }
    .projects-row > .project-card {
        flex-basis: clamp(220px, 70vw, 300px);
    }
    .project-card img {
        height: 120px;
    }
}
.projects-carousel-wrapper[data-auto='true'] .projects-row {
    overflow: hidden;
    -webkit-mask-image: linear-gradient(90deg, transparent, #fff 6%, #fff 94%, transparent);
    mask-image: linear-gradient(90deg, transparent, #fff 6%, #fff 94%, transparent);
    position: relative;
}
.projects-row[data-infinite-init='true'] {
    display: flex;
    width: -moz-max-content;
    width: max-content;
    gap: 0;
}
.projects-row.auto-scroll-track {
    display: flex;
    width: -moz-max-content;
    width: max-content;
    animation: projects-auto-scroll 90s linear infinite;
}
@keyframes projects-auto-scroll {
    0% {
        transform: translateX(0);
    }
    to {
        transform: translateX(-33.333%);
    }
}
.fade-in-section {
    opacity: 0;
    transform: translateY(20px);
    transition:
        opacity 0.6s ease-out,
        transform 0.6s ease-out;
}
.fade-in-section.is-visible {
    opacity: 1;
    transform: translateY(0);
}
#hero-canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}
.hero-content {
    position: relative;
    z-index: 1;
}
.typewriter-cursor {
    display: inline-block;
    width: 3px;
    height: 1em;
    background-color: var(--color-accent);
    animation: blink 0.7s infinite;
}
@keyframes blink {
    50% {
        opacity: 0;
    }
}
.skills-matrix {
    --arc-cell: 108px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 2.25rem 2.6rem;
    padding: 1rem 0.5rem 1.75rem;
    max-width: 1250px;
    margin: 0 auto;
    position: relative;
}
.skills-matrix:before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at 50% 40%, rgba(217, 35, 35, 0.08), transparent 65%);
}
.skill-arc {
    width: var(--arc-cell);
    text-align: center;
    position: relative;
    opacity: 0;
    transform: translateY(16px) scale(0.96);
    filter: blur(4px);
    transition:
        opacity 0.7s cubic-bezier(0.22, 0.61, 0.36, 1),
        transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1),
        filter 0.9s ease;
}
.skill-arc.reveal {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
}
.skill-arc.reveal:after {
    content: '';
    position: absolute;
    top: 8px;
    left: 50%;
    width: 74px;
    height: 74px;
    margin-left: -37px;
    border-radius: 50%;
    background: radial-gradient(
        circle at 50% 50%,
        rgba(217, 35, 35, 0.5),
        rgba(217, 35, 35, 0) 60%
    );
    filter: blur(10px);
    opacity: 0;
    animation: halo-pulse 2.4s ease-out forwards;
    pointer-events: none;
}
.skill-arc[data-selected='true'].reveal:after {
    animation: halo-pulse-selected 2.4s ease-out forwards;
}
.skill-arc:nth-child(odd).reveal {
    transition-delay: 0.05s;
}
.skill-arc:nth-child(3n).reveal {
    transition-delay: 0.1s;
}
.skill-arc figure {
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.skill-arc .arc-svg {
    display: block;
    margin: 0 auto;
    width: 82px;
    height: 82px;
    filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.4));
}
.skill-arc .ring-outer {
    stroke: linear-gradient(#d92323, #ff5858);
    stroke: #2b2b2b;
    stroke-width: 4;
    fill: none;
    opacity: 0.55;
}
.skill-arc .ring-track {
    stroke: #262626;
    stroke-width: 8;
    fill: none;
}
.skill-arc .ring-progress {
    stroke: var(--color-accent);
    stroke-width: 8;
    fill: none;
    stroke-linecap: round;
    transition: stroke-dashoffset 1.3s cubic-bezier(0.65, 0.05, 0.36, 1);
}
.skill-arc[data-band='low'] .ring-progress {
    stroke: #8a8a8a;
}
.skill-arc[data-band='mid'] .ring-progress {
    stroke: #ff914d;
}
.skill-arc[data-band='high'] .ring-progress {
    stroke: #ff5858;
}
.skill-arc[data-band='top'] .ring-progress {
    stroke: url(#grad-accent);
}
.skill-tooltip {
    position: fixed;
    z-index: 1200;
    background: #1e1e1e;
    color: #fff;
    font-size: 12px;
    line-height: 1.3;
    padding: 8px 10px;
    border: 1px solid #2d2d2d;
    border-radius: 8px;
    box-shadow:
        0 4px 18px -4px rgba(0, 0, 0, 0.6),
        inset 0 0 0 1px hsla(0, 0%, 100%, 0.04);
    pointer-events: none;
    opacity: 0;
    transform: translateY(4px) scale(0.96);
    transition:
        opacity 0.16s ease,
        transform 0.16s ease;
    max-width: 240px;
    font-weight: 500;
}
.skill-tooltip.show {
    opacity: 1;
    transform: translateY(0) scale(1);
}
.skill-tooltip .tt-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: 600;
    margin-bottom: 4px;
    letter-spacing: 0.3px;
}
.skill-tooltip .tt-head .pct {
    font-size: 11px;
    font-weight: 600;
    color: #ff5858;
}
.skill-tooltip .tt-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    font-size: 11px;
    opacity: 0.85;
}
.skill-tooltip .tt-meta span {
    background: #262626;
    padding: 2px 6px;
    border-radius: 999px;
}
:root.light .skill-tooltip {
    background: #fff;
    color: #111;
    border-color: #e2e2e2;
    box-shadow:
        0 4px 18px -4px rgba(0, 0, 0, 0.25),
        inset 0 0 0 1px rgba(0, 0, 0, 0.04);
}
:root.light .skill-tooltip .tt-meta span {
    background: #f1f1f1;
}
.skill-arc[data-selected='true'] .ring-progress {
    filter: drop-shadow(0 0 6px var(--color-accent)) drop-shadow(0 0 16px rgba(217, 35, 35, 0.5));
}
.skill-arc button.skill-item {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: linear-gradient(145deg, #1d1d1d, #222);
    box-shadow:
        inset 0 0 0 1px #2d2d2d,
        0 4px 10px -2px rgba(0, 0, 0, 0.6);
    margin: 0.45rem auto 0;
    padding: 0;
    position: relative;
    overflow: hidden;
}
.skill-arc button.skill-item:after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 30% 25%, hsla(0, 0%, 100%, 0.08), transparent 70%);
    opacity: 0;
    transition: opacity 0.4s ease;
}
.skill-arc button.skill-item:hover:after {
    opacity: 1;
}
.skill-arc button.skill-item:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 4px;
}
.skill-arc button.skill-item img {
    width: 36px;
    height: 36px;
    -o-object-fit: contain;
    object-fit: contain;
    animation: logo-float 5s ease-in-out infinite;
}
@keyframes logo-float {
    0%,
    to {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-6px);
    }
}
@media (prefers-reduced-motion: reduce) {
    .skill-arc button.skill-item img {
        animation: none;
    }
}
.skill-arc .skill-percent {
    font-size: 0.6rem;
    letter-spacing: 0.6px;
    color: #b5b5b5;
    display: block;
    margin-top: 0.25rem;
    font-weight: 500;
    min-height: 0.85em;
}
.skill-arc .skill-name {
    font-size: 0.66rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    display: block;
    margin-top: 0.4rem;
    color: #e5e5e5;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.progressive-arcs .skill-arc[data-selected='true'] button.skill-item {
    box-shadow:
        0 0 0 1px var(--color-accent),
        0 0 14px -2px rgba(217, 35, 35, 0.55);
}
.progressive-arcs .skill-arc[data-selected='true'] .skill-name {
    color: #fff;
}
@media (max-width: 900px) {
    .skills-matrix {
        --arc-cell: 96px;
        gap: 1.9rem 2rem;
    }
    .skill-arc .arc-svg {
        width: 74px;
        height: 74px;
    }
}
@media (max-width: 640px) {
    .skills-matrix {
        --arc-cell: 86px;
        gap: 1.65rem 1.65rem;
    }
    .skill-arc button.skill-item {
        width: 54px;
        height: 54px;
    }
    .skill-arc .arc-svg {
        width: 68px;
        height: 68px;
    }
}
@media (prefers-reduced-motion: reduce) {
    .skill-arc {
        transition: none !important;
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }
}
.skill-cat-pill {
    position: relative;
    background: #1e1e1e;
    color: #bfbfbf;
    border: 1px solid #2d2d2d;
    padding: 0.45rem 0.85rem;
    font-size: 0.7rem;
    font-weight: 500;
    border-radius: 999px;
    letter-spacing: 0.5px;
    transition:
        background 0.35s,
        color 0.35s,
        border-color 0.35s,
        box-shadow 0.35s;
    cursor: pointer;
    line-height: 1;
}
.skill-cat-pill:hover {
    color: #fff;
    border-color: #3a3a3a;
}
.skill-cat-pill.active,
.skill-cat-pill[aria-pressed='true'] {
    background: linear-gradient(90deg, #d92323, #ff5858);
    color: #fff;
    border-color: #d92323;
    box-shadow:
        0 0 0 1px #d92323,
        0 0 12px -2px rgba(217, 35, 35, 0.7);
}
.skill-cat-pill:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 3px;
}
@keyframes halo-pulse {
    0% {
        opacity: 0;
        transform: scale(0.55);
    }
    40% {
        opacity: 0.85;
    }
    75% {
        opacity: 0.25;
    }
    to {
        opacity: 0;
        transform: scale(1.65);
    }
}
@keyframes halo-pulse-selected {
    0% {
        opacity: 0;
        transform: scale(0.55);
    }
    30% {
        opacity: 0.95;
    }
    60% {
        opacity: 0.35;
    }
    to {
        opacity: 0;
        transform: scale(1.9);
    }
}
.magic-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
}
.magic-gallery-item {
    background-color: var(--color-card);
    border-radius: 1rem;
    overflow: hidden;
    border: 1px solid var(--color-gray-border);
    transition:
        transform 0.4s ease,
        box-shadow 0.4s ease;
    opacity: 0;
    transform: translateY(30px) scale(0.95);
    animation: gallery-fade-in 0.6s ease-out forwards;
}
.magic-gallery-item:first-child {
    animation-delay: 0.1s;
}
.magic-gallery-item:nth-child(2) {
    animation-delay: 0.2s;
}
.magic-gallery-item:nth-child(3) {
    animation-delay: 0.3s;
}
.magic-gallery-item:nth-child(4) {
    animation-delay: 0.4s;
}
@keyframes gallery-fade-in {
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}
.magic-gallery-item:hover {
    transform: translateY(-10px) scale(1.03);
    box-shadow: 0 0 40px rgba(217, 35, 35, 0.4);
}
.magic-gallery-item img {
    width: 100%;
    height: 220px;
    -o-object-fit: cover;
    object-fit: cover;
    transition: transform 0.4s ease;
}
.magic-gallery-item:hover img {
    transform: scale(1.1);
}
.outreach-scroller {
    overflow: hidden;
    -webkit-mask-image: linear-gradient(90deg, transparent, #fff 10%, #fff 90%, transparent);
    mask-image: linear-gradient(90deg, transparent, #fff 10%, #fff 90%, transparent);
}
.outreach-scroller.filtered-mode {
    -webkit-mask-image: none;
    mask-image: none;
    overflow: visible;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2rem 0;
}
.outreach-track {
    display: flex;
    width: -moz-max-content;
    width: max-content;
    animation: outreach-scroll 60s linear infinite;
}
.filtered-mode .outreach-track {
    animation: none;
    transform: none;
    justify-content: center;
    gap: 1.5rem;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto;
}
@keyframes outreach-scroll {
    0% {
        transform: translateX(0);
    }
    to {
        transform: translateX(-50%);
    }
}
.outreach-track .project-card {
    flex: 0 0 clamp(240px, 38vw, 340px);
    height: auto;
    margin: 0 0.75rem;
    flex-shrink: 0;
    background: var(--brand-card);
    border-radius: 0.75rem;
    overflow: hidden;
    position: relative;
    transition: all 0.4s ease;
    border: 1px solid hsla(0, 0%, 100%, 0.1);
    display: flex;
    flex-direction: column;
}
.outreach-track .project-card.has-lid {
    height: 320px;
}
.outreach-track .project-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 24px -6px rgba(217, 35, 35, 0.25);
}
@media (max-width: 768px) {
    .outreach-track .project-card {
        flex: 0 0 250px;
        height: 280px;
        margin: 0 0.5rem;
    }
    .outreach-track .project-card.has-lid {
        height: 280px;
    }
    .filtered-mode .outreach-track .project-card {
        flex: 0 0 clamp(250px, 80vw, 320px);
        margin: 0 0.5rem 1rem;
    }
}
.outreach-image {
    width: 300px;
    height: 220px;
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: 1rem;
    margin: 0 1rem;
    border: 2px solid #333;
    transition:
        transform 0.4s ease,
        box-shadow 0.4s ease;
}
.outreach-image:hover {
    transform: scale(1.05);
    box-shadow: 0 0 30px rgba(217, 35, 35, 0.5);
}
.timeline {
    position: relative;
    margin: 0;
    padding: 0 0 0 1.5rem;
    list-style: none;
}
.timeline:before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0.35rem;
    width: 2px;
    background: linear-gradient(180deg, rgba(217, 35, 35, 0.7), rgba(217, 35, 35, 0.15));
}
.timeline-item {
    position: relative;
    padding: 0.25rem 0 2.2rem;
    display: flex;
}
.timeline-item:last-child {
    padding-bottom: 0.5rem;
}
.timeline-node {
    position: absolute;
    left: -1px;
    top: 0.6rem;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--color-accent);
    box-shadow:
        0 0 0 4px var(--color-card),
        0 0 0 1px #322;
}
.timeline-node.level-phd {
    background: #ff5858;
}
.timeline-node.level-masters {
    background: #ff914d;
}
.timeline-node.level-bachelors {
    background: #8a8a8a;
}
.timeline-content {
    margin-left: 1.25rem;
    flex: 1;
    position: relative;
}
.timeline-item:focus-within .timeline-node,
.timeline-item:hover .timeline-node {
    box-shadow:
        0 0 0 4px var(--color-card),
        0 0 0 1px #444,
        0 0 0 6px rgba(217, 35, 35, 0.35);
}
.degree-badge {
    font-size: 0.6rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    padding: 0.25rem 0.45rem;
    border-radius: 6px;
    background: #262626;
    color: #fff;
    box-shadow: inset 0 0 0 1px #333;
}
.degree-phd {
    background: linear-gradient(90deg, #d92323, #ff5858);
}
.degree-msc {
    background: #3a3a3a;
}
.degree-bsc {
    background: #2b2b2b;
}
.badge-live {
    background: #1f2a1f;
    color: #ff7979;
    box-shadow: inset 0 0 0 1px #3a2323;
}
.meta-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.35rem;
}
.meta-chips span {
    background: #232323;
    font-size: 0.55rem;
    letter-spacing: 0.4px;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    color: #c9c9c9;
}
@media (max-width: 640px) {
    .timeline {
        padding-left: 1rem;
    }
    .timeline-node {
        left: -2px;
    }
}
.outreach-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 0.75rem;
}
.outreach-stats .stat {
    background: #1d1d1d;
    border: 1px solid #272727;
    border-radius: 10px;
    padding: 0.55rem 0.6rem 0.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.outreach-stats .stat:after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 15%, rgba(255, 88, 88, 0.15), transparent 70%);
    opacity: 0.7;
}
.stat-value {
    display: block;
    font-size: 1.05rem;
    font-weight: 700;
    color: #ff5858;
    letter-spacing: 0.5px;
}
.stat-label {
    display: block;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.85px;
    color: #b5b5b5;
    margin-top: 0.2rem;
    font-weight: 600;
}
.outreach-cards {
    --card-bg: #1d1d1d;
}
.outreach-card {
    background: var(--card-bg);
    border: 1px solid #272727;
    border-radius: 14px;
    padding: 0.95rem 0.9rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    position: relative;
    isolation: isolate;
    transition:
        background 0.35s,
        transform 0.35s,
        box-shadow 0.4s;
    outline: none;
}
.outreach-card:before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 35% 20%, rgba(255, 88, 88, 0.18), transparent 70%);
    opacity: 0;
    transition: opacity 0.4s;
    z-index: 0;
}
.outreach-card:focus-visible,
.outreach-card:hover {
    transform: translateY(-4px);
    box-shadow:
        0 8px 28px -6px rgba(0, 0, 0, 0.6),
        0 0 0 1px rgba(217, 35, 35, 0.4);
}
.outreach-card:focus-visible:before,
.outreach-card:hover:before {
    opacity: 1;
}
.outreach-card .icon-wrap {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    background: #262626;
    border-radius: 10px;
    box-shadow: inset 0 0 0 1px #333;
}
.card-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: #fff;
    letter-spacing: 0.5px;
}
.card-desc {
    font-size: 0.7rem;
    line-height: 1.3;
    color: #bfbfbf;
}
@media (max-width: 640px) {
    .outreach-stats {
        grid-template-columns: repeat(2, minmax(90px, 1fr));
    }
    .outreach-card {
        padding: 0.85rem 0.8rem 0.9rem;
    }
}
:root.light .outreach-image {
    border-color: #ccc;
}
:root.light .magic-gallery-item:hover {
    box-shadow: 0 0 40px rgba(217, 35, 35, 0.25);
}
[dir='rtl'] body {
    direction: rtl;
    text-align: right;
}
[dir='rtl'] .hero-content {
    text-align: right !important;
}
[dir='rtl'] .outreach-track,
[dir='rtl'] .skills-track {
    direction: ltr;
}
[dir='rtl'] .typewriter-cursor {
    margin-right: 2px;
}
.pub-hero-card,
.pub-wrapper {
    position: relative;
}
.pub-hero-card {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 2.2rem;
    align-items: stretch;
}
.pub-hero-item {
    background: #1e1e1e;
    border: 1px solid #272727;
    border-radius: 22px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 10px 40px -10px rgba(217, 35, 35, 0.25);
    position: relative;
    isolation: isolate;
}
.pub-hero-item:before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 65% 35%, rgba(255, 88, 88, 0.18), transparent 70%);
    opacity: 0.65;
    pointer-events: none;
    mix-blend-mode: screen;
}
.pub-hero-media {
    aspect-ratio: 16/9;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    background: #121212;
}
.pub-hero-body {
    padding: 1.4rem 1.5rem 1.55rem;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}
.pub-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}
.pub-badge {
    font-size: 0.55rem;
    text-transform: uppercase;
    letter-spacing: 0.9px;
    font-weight: 600;
    padding: 0.35rem 0.6rem;
    border-radius: 999px;
    background: #262626;
    color: #d9d9d9;
    box-shadow: inset 0 0 0 1px #303030;
}
.pub-badge.type-guide {
    background: linear-gradient(90deg, #343434, #2a2a2a);
}
.pub-badge.type-report {
    background: linear-gradient(90deg, #d92323, #ff5858);
    color: #fff;
}
.pub-badge.type-updated {
    background: #1f2a1f;
    color: #ff8e8e;
}
.pub-title {
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.25;
    color: #fff;
    letter-spacing: 0.3px;
}
.pub-title a {
    color: inherit;
    text-decoration: none;
    background-image: linear-gradient(90deg, #ff5858, #ff5858);
    background-size: 0 2px;
    background-repeat: no-repeat;
    background-position: 0 100%;
    transition: background-size 0.5s;
}
.pub-title a:hover {
    background-size: 100% 2px;
}
.pub-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    font-size: 0.6rem;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    color: #b5b5b5;
    font-weight: 600;
}
.pub-meta-row span {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}
.pub-summary {
    font-size: 0.78rem;
    line-height: 1.5;
    color: #bfbfbf;
    max-width: 58ch;
}
.pub-actions {
    margin-top: auto;
    display: flex;
    gap: 0.6rem;
}
.pub-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.65rem;
    letter-spacing: 0.6px;
    font-weight: 600;
    padding: 0.6rem 0.85rem;
    border-radius: 10px;
    background: #262626;
    color: #eee;
    border: 1px solid #343434;
    transition:
        background 0.3s,
        box-shadow 0.35s,
        transform 0.35s;
}
.pub-btn:hover {
    background: #2e2e2e;
    box-shadow:
        0 0 0 1px #d92323,
        0 6px 24px -8px rgba(217, 35, 35, 0.45);
    transform: translateY(-2px);
}
.pub-btn.primary {
    background: linear-gradient(90deg, #d92323, #ff5858);
    border-color: #d92323;
    color: #fff;
}
.pub-btn.primary:hover {
    box-shadow:
        0 0 0 1px #d92323,
        0 8px 30px -10px rgba(217, 35, 35, 0.6);
}
.pub-grid {
    display: grid;
    gap: 1.6rem;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.pub-card {
    background: #1c1c1c;
    border: 1px solid #272727;
    border-radius: 18px;
    padding: 1.05rem 1.05rem 1.15rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    position: relative;
    overflow: hidden;
    transition:
        transform 0.45s cubic-bezier(0.22, 0.61, 0.36, 1),
        box-shadow 0.5s,
        background 0.45s;
}
.pub-card:before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 35% 20%, rgba(255, 88, 88, 0.16), transparent 70%);
    opacity: 0;
    transition: opacity 0.55s;
}
.pub-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 14px 38px -12px rgba(217, 35, 35, 0.5);
}
.pub-card:hover:before {
    opacity: 1;
}
.pub-card .cover {
    aspect-ratio: 16/10;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: 12px;
    background: #111;
}
.pub-card .pub-title {
    font-size: 1rem;
}
.pub-card .pub-summary {
    font-size: 0.68rem;
    line-height: 1.45;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pub-card .pub-meta-row {
    font-size: 0.5rem;
    gap: 0.65rem;
}
.pub-card .pub-badges {
    gap: 0.35rem;
}
.pub-featured-row {
    display: grid;
    gap: 1.4rem;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    margin-bottom: 2.5rem;
}
.pub-feature-card {
    background: #1e1e1e;
    border: 1px solid #272727;
    border-radius: 18px;
    padding: 1rem 1.15rem 1.15rem;
    display: flex;
    gap: 1rem;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    transition:
        box-shadow 0.5s,
        transform 0.45s;
}
.pub-feature-card:before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 65% 35%, rgba(255, 88, 88, 0.18), transparent 70%);
    opacity: 0;
    transition: opacity 0.5s;
    pointer-events: none;
    mix-blend-mode: screen;
}
.pub-feature-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 34px -10px rgba(217, 35, 35, 0.45);
}
.pub-feature-card:hover:before {
    opacity: 1;
}
.pub-feature-card .thumb {
    width: 150px;
    max-width: 34%;
    aspect-ratio: 4/3;
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: 14px;
    background: #111;
    flex-shrink: 0;
}
.pub-feature-card .content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}
.pub-feature-card .pub-title {
    font-size: 1.05rem;
    margin-top: 0.1rem;
}
.pub-feature-card .pub-summary {
    font-size: 0.7rem;
    line-height: 1.45;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pub-feature-card .pub-meta-row {
    font-size: 0.55rem;
}
.pub-feature-card .pub-actions {
    margin-top: auto;
}
@media (max-width: 720px) {
    .pub-feature-card {
        flex-direction: column;
    }
    .pub-feature-card .thumb {
        width: 100%;
        max-width: 100%;
        aspect-ratio: 16/9;
    }
    .pub-feature-card .pub-title {
        font-size: 1rem;
    }
}
.meta-icon {
    filter: brightness(1.15);
}
@media (max-width: 860px) {
    .pub-hero-card {
        grid-template-columns: 1fr;
    }
    .pub-title {
        font-size: 1.15rem;
    }
}
@media (max-width: 520px) {
    .pub-grid {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    }
    #publications-controls {
        display: flex;
        flex-wrap: wrap;
        gap: 0.75rem;
        align-items: center;
    }
    .pub-search-box {
        position: relative;
        flex: 1 1 260px;
    }
    .pub-search-box input {
        width: 100%;
        background: linear-gradient(145deg, #1d1d1d, #181818);
        border: 1px solid #2b2b2b;
        color: #f5f5f5;
        padding: 0.75rem 0.95rem 0.75rem 2.4rem;
        border-radius: 14px;
        font-size: 0.8rem;
        letter-spacing: 0.35px;
        box-shadow:
            0 2px 4px rgba(0, 0, 0, 0.5),
            inset 0 0 0 1px hsla(0, 0%, 100%, 0.03);
        transition:
            background 0.4s,
            box-shadow 0.4s,
            border-color 0.4s;
    }
    .pub-search-box input::-moz-placeholder {
        color: #a7a7a7;
        font-weight: 400;
    }
    .pub-search-box input::placeholder {
        color: #a7a7a7;
        font-weight: 400;
    }
    .pub-search-box .icon {
        position: absolute;
        left: 0.75rem;
        top: 50%;
        transform: translateY(-50%);
        font-size: 0.9rem;
        opacity: 0.7;
    }
    .pub-search-box input:focus {
        outline: none;
        border-color: #d92323;
        box-shadow:
            0 0 0 2px rgba(217, 35, 35, 0.5),
            0 4px 18px -4px rgba(217, 35, 35, 0.5);
        background: linear-gradient(145deg, #222, #191919);
    }
    .pub-filter-pills {
        display: flex;
        gap: 0.5rem;
        flex-wrap: wrap;
    }
    .pub-filter-pill {
        background: #202020;
        border: 1px solid #2e2e2e;
        color: #bbb;
        font-size: 0.6rem;
        text-transform: uppercase;
        letter-spacing: 0.8px;
        padding: 0.45rem 0.7rem;
        border-radius: 999px;
        cursor: pointer;
        transition:
            background 0.3s,
            color 0.3s,
            box-shadow 0.35s;
    }
    .pub-filter-pill[aria-pressed='true'] {
        background: linear-gradient(90deg, #d92323, #ff5858);
        color: #fff;
        box-shadow: 0 4px 16px -6px rgba(217, 35, 35, 0.6);
    }
    .pub-filter-pill:hover {
        background: #262626;
        color: #fff;
    }
    .equal-height-row {
        display: flex;
        align-items: stretch;
    }
    .equal-height-row .pub-card,
    .equal-height-row .pub-feature-card {
        display: flex;
    }
    .pub-summary,
    .pub-title {
        transition: max-height 0.4s ease;
    }
    .pub-card {
        padding: 0.95rem 0.9rem 1rem;
    }
    .pub-card .pub-title {
        font-size: 0.95rem;
    }
}
.font-arabic {
    font-family:
        IBM Plex Sans Arabic,
        Cairo,
        Tahoma,
        sans-serif !important;
}
.pub-img-skel {
    position: relative;
    background: #242424;
    overflow: hidden;
}
.pub-img-skel:not(.loaded):after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        110deg,
        hsla(0, 0%, 100%, 0),
        hsla(0, 0%, 100%, 0.08) 45%,
        hsla(0, 0%, 100%, 0) 85%
    );
    animation: pub-shimmer 1.35s linear infinite;
}
.pub-img-skel.loaded {
    background: none;
}
.pub-img-skel.error {
    background: #3a2020;
}
@keyframes pub-shimmer {
    0% {
        transform: translateX(-40%);
    }
    to {
        transform: translateX(120%);
    }
}
.pub-empty {
    background: #1c1c1c;
    border: 1px dashed #333;
    padding: 2.6rem 1.5rem;
    text-align: center;
    border-radius: 18px;
    font-size: 0.9rem;
    color: #bdbdbd;
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
    align-items: center;
    justify-content: center;
    min-height: 230px;
}
.pub-empty .pub-reset {
    background: #262626;
    color: #eee;
    font-size: 0.65rem;
    letter-spacing: 0.08em;
    font-weight: 600;
    text-transform: uppercase;
    border: 1px solid #343434;
    padding: 0.55rem 1rem 0.5rem;
    border-radius: 999px;
    cursor: pointer;
    transition:
        background 0.35s,
        box-shadow 0.35s,
        color 0.35s;
}
.pub-empty .pub-reset:hover {
    background: #2e2e2e;
    color: #fff;
    box-shadow:
        0 0 0 1px #d92323,
        0 6px 22px -10px rgba(217, 35, 35, 0.5);
}
.light .pub-empty {
    background: #f7f7f7;
    border-color: #ddd;
    color: #555;
}
.light .pub-empty .pub-reset {
    background: #fff;
    color: #222;
    border-color: #d0d0d0;
}
.light .pub-empty .pub-reset:hover {
    background: #ededed;
    box-shadow:
        0 0 0 1px #d92323,
        0 6px 20px -10px rgba(217, 35, 35, 0.45);
}
.light .pub-search-box input {
    background: linear-gradient(145deg, #fff, #f5f5f5);
    border-color: #cfcfcf;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.07),
        inset 0 0 0 1px rgba(0, 0, 0, 0.05);
}
.light .pub-search-box input:focus {
    border-color: #d92323;
    box-shadow:
        0 0 0 2px rgba(217, 35, 35, 0.35),
        0 4px 18px -6px rgba(217, 35, 35, 0.4);
}
.pub-search-outer {
    width: 100%;
    max-width: 520px;
    position: relative;
    flex: 1 1 340px;
}
.pub-search-box {
    position: relative;
}
.pub-search-box input {
    width: 100%;
    border: none;
    background: hsla(0, 0%, 9%, 0.85);
    border-radius: 18px;
    padding: 0.95rem 3.3rem 0.95rem 2.75rem;
    font-size: 0.9rem;
    color: #f2f2f2;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow:
        0 2px 12px -4px rgba(0, 0, 0, 0.6),
        inset 0 0 0 1px hsla(0, 0%, 100%, 0.06);
    transition:
        box-shadow 0.5s,
        background 0.5s,
        transform 0.5s;
    font-weight: 500;
    letter-spacing: 0.35px;
}
.pub-search-box input::-moz-placeholder {
    color: #9a9a9a;
    font-weight: 400;
    letter-spacing: 0.5px;
}
.pub-search-box input::placeholder {
    color: #9a9a9a;
    font-weight: 400;
    letter-spacing: 0.5px;
}
.pub-search-box .icon {
    left: 1rem;
    font-size: 1rem;
    filter: drop-shadow(0 0 4px rgba(0, 0, 0, 0.4));
}
.pub-search-box .clear-btn,
.pub-search-box .icon {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.pub-search-box .clear-btn {
    right: 0.85rem;
    background: linear-gradient(135deg, #303030, #222);
    color: #e3e3e3;
    border: 1px solid #3b3b3b;
    width: 32px;
    height: 32px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    font-size: 0.8rem;
    cursor: pointer;
    box-shadow: 0 2px 8px -4px rgba(0, 0, 0, 0.55);
    transition:
        background 0.4s,
        color 0.4s,
        box-shadow 0.4s,
        transform 0.35s;
}
.pub-search-box .clear-btn:hover {
    background: linear-gradient(135deg, #3a3a3a, #272727);
    color: #fff;
    box-shadow:
        0 4px 14px -6px rgba(0, 0, 0, 0.7),
        inset 0 0 0 1px #4a4a4a;
}
.pub-search-box .clear-btn:active {
    transform: translateY(-50%) scale(0.92);
}
.pub-search-box .ring-anim {
    position: absolute;
    inset: 0;
    border-radius: 18px;
    pointer-events: none;
    padding: 1px;
    background: linear-gradient(120deg, #d92323, #ff5858, #d92323, #ff5858);
    background-size: 300% 300%;
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    animation: pubSearchBorder 6s linear infinite paused;
    opacity: 0;
    transition: opacity 0.5s;
}
.pub-search-box:focus-within .ring-anim {
    opacity: 1;
    animation-play-state: running;
}
.pub-search-box:focus-within input {
    background: rgba(28, 28, 28, 0.95);
    box-shadow:
        0 6px 30px -12px rgba(217, 35, 35, 0.55),
        0 0 0 1px rgba(217, 35, 35, 0.65),
        0 0 0 4px rgba(217, 35, 35, 0.25);
}
.pub-search-box:focus-within .icon {
    filter: drop-shadow(0 0 6px rgba(217, 35, 35, 0.55));
}
@keyframes pubSearchBorder {
    0% {
        background-position: 0 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    to {
        background-position: 0 50%;
    }
}
.light .pub-search-box input {
    background: linear-gradient(145deg, #fff, #f6f6f6);
    color: #111;
    box-shadow:
        0 2px 10px -4px rgba(0, 0, 0, 0.15),
        inset 0 0 0 1px rgba(0, 0, 0, 0.06);
}
.light .pub-search-box:focus-within input {
    background: #fff;
    box-shadow:
        0 8px 34px -14px rgba(217, 35, 35, 0.35),
        0 0 0 1px rgba(217, 35, 35, 0.6),
        0 0 0 4px rgba(217, 35, 35, 0.22);
}
.light .pub-search-box .clear-btn {
    background: linear-gradient(135deg, #f7f7f7, #ececec);
    color: #333;
    border-color: #d0d0d0;
}
.light .pub-search-box .clear-btn:hover {
    background: linear-gradient(135deg, #fff, #ededed);
    color: #111;
}
@media (max-width: 640px) {
    .pub-search-outer {
        max-width: 100%;
    }
    .pub-search-box input {
        font-size: 0.85rem;
        padding: 0.85rem 3.1rem 0.85rem 2.4rem;
    }
}
[dir='rtl'] body {
    font-family:
        IBM Plex Sans Arabic,
        Cairo,
        Tahoma,
        sans-serif;
}
[dir='rtl'] .space-x-6,
[dir='rtl'] .space-x-8 {
    --tw-space-x-reverse: 1;
}
:root {
    --hero-ease-soft: cubic-bezier(0.22, 0.61, 0.36, 1);
    --hero-ease-snap: cubic-bezier(0.19, 0.9, 0.22, 1);
    --hero-dur-sm: 260ms;
    --hero-dur-md: 520ms;
    --hero-dur-lg: 820ms;
}
.hero-photo {
    position: relative;
    border-radius: 50%;
    isolation: isolate;
    overflow: visible;
    --tilt-rx: 0deg;
    --tilt-ry: 0deg;
    transform: perspective(1200px) rotateX(var(--tilt-rx)) rotateY(var(--tilt-ry)) scale(0.97);
    filter: blur(3px);
    opacity: 0;
    will-change: transform, opacity, filter;
    transition:
        transform var(--hero-dur-sm) var(--hero-ease-soft),
        filter var(--hero-dur-sm) var(--hero-ease-soft);
}
.hero-photo:after,
.hero-photo:before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
}
.hero-photo:before {
    inset: -22%;
    background:
        radial-gradient(circle at 40% 38%, rgba(255, 88, 88, 0.38), rgba(255, 88, 88, 0) 65%),
        radial-gradient(circle at 72% 68%, rgba(255, 150, 70, 0.25), rgba(255, 150, 70, 0) 70%);
    filter: blur(28px) saturate(1.15);
    opacity: 0;
    animation: heroAmbientIn 1.1s 0.3s var(--hero-ease-soft) forwards;
    z-index: -2;
}
.hero-photo:after {
    background:
        linear-gradient(145deg, hsla(0, 0%, 100%, 0.18), hsla(0, 0%, 100%, 0) 62%),
        var(--hero-photo-url, url('../images/website-photo.png')) center/cover no-repeat;
    box-shadow:
        0 0 0 4px #fff,
        inset 0 0 0 1px hsla(0, 0%, 100%, 0.7),
        0 8px 26px -8px rgba(0, 0, 0, 0.65),
        0 0 0 1px rgba(255, 88, 88, 0.22);
    border-radius: 50%;
}
.hero-photo.video-only .hero-flash,
.hero-photo.video-only .hero-ring,
.hero-photo.video-only canvas.hero-particles,
.hero-photo.video-only:after,
.hero-photo.video-only:before {
    display: none !important;
}
.hero-photo-static {
    position: relative;
    overflow: hidden;
    border-radius: 50%;
}
.hero-section-animated {
    position: relative;
    --hero-bg-accent: #d92323;
    --hero-bg-accent-soft: #ff8052;
    --hero-bg-dark: #0e0e0e;
    background:
        radial-gradient(circle at 14% 38%, rgba(217, 35, 35, 0.18), rgba(217, 35, 35, 0) 60%),
        radial-gradient(circle at 86% 72%, rgba(255, 128, 82, 0.14), rgba(255, 128, 82, 0) 65%),
        linear-gradient(160deg, rgba(217, 35, 35, 0.1), rgba(217, 35, 35, 0) 55%);
    animation: heroBgShift 22s ease-in-out infinite;
}
@keyframes heroBgShift {
    0% {
        background-position:
            14% 38%,
            86% 72%,
            0 0;
    }
    50% {
        background-position:
            20% 32%,
            80% 68%,
            40% 50%;
    }
    to {
        background-position:
            14% 38%,
            86% 72%,
            0 0;
    }
}
.hero-section-animated .hero-bg-layer {
    position: absolute;
    inset: -25% -15%;
    z-index: -2;
    background:
        radial-gradient(circle at 18% 32%, rgba(217, 35, 35, 0.45), transparent 60%),
        radial-gradient(circle at 82% 68%, rgba(255, 128, 82, 0.4), transparent 65%),
        radial-gradient(circle at 50% 50%, rgba(217, 35, 35, 0.18), rgba(217, 35, 35, 0) 70%),
        linear-gradient(145deg, rgba(217, 35, 35, 0.15), transparent);
    filter: saturate(140%) brightness(1.05);
    animation: heroBgDrift 26s linear infinite;
    opacity: 0.55;
    pointer-events: none;
}
.hero-section-animated .hero-bg-layer:after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 60% 40%, hsla(0, 0%, 100%, 0.08), transparent 70%),
        radial-gradient(circle at 30% 70%, hsla(0, 0%, 100%, 0.05), transparent 65%);
    mix-blend-mode: overlay;
    animation: heroBgPulse 7.5s ease-in-out infinite;
}
.hero-section-animated .hero-bg-particles {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    -webkit-mask: radial-gradient(circle at center, #000 60%, transparent 95%);
    mask: radial-gradient(circle at center, #000 60%, transparent 95%);
    z-index: -1;
}
.hero-section-animated .hero-bg-particles:after,
.hero-section-animated .hero-bg-particles:before {
    content: '';
    position: absolute;
    top: -10%;
    left: -10%;
    width: 120%;
    height: 120%;
    background-image: radial-gradient(
        circle at center,
        hsla(0, 0%, 100%, 0.55) 0.75px,
        transparent 1.2px
    );
    background-size: 28px 28px;
    opacity: 0.2;
    animation: heroStarsDrift 60s linear infinite;
}
.hero-section-animated .hero-bg-particles:after {
    background-size: 46px 46px;
    opacity: 0.1;
    animation-duration: 95s;
    animation-direction: reverse;
    filter: blur(0.5px);
}
@media (max-width: 768px) {
    .hero-section-animated .hero-bg-layer {
        opacity: 0.42;
    }
    .hero-section-animated .hero-bg-particles {
        display: none;
    }
}
@media (prefers-reduced-motion: reduce) {
    .hero-section-animated .hero-bg-layer,
    .hero-section-animated .hero-bg-layer:after,
    .hero-section-animated .hero-bg-particles:after,
    .hero-section-animated .hero-bg-particles:before {
        animation: none;
    }
}
@keyframes heroBgDrift {
    0% {
        transform: rotate(0deg) scale(1);
    }
    50% {
        transform: rotate(180deg) scale(1.06);
    }
    to {
        transform: rotate(1turn) scale(1);
    }
}
@keyframes heroBgPulse {
    0%,
    to {
        opacity: 0.6;
        filter: blur(0) brightness(1);
    }
    50% {
        opacity: 0.85;
        filter: blur(2px) brightness(1.08);
    }
}
@keyframes heroStarsDrift {
    0% {
        transform: translateZ(0);
    }
    to {
        transform: translate3d(-120px, -80px, 0);
    }
}
.hero-photo-static img {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    transform: translateZ(0);
    will-change: auto;
    backface-visibility: hidden;
}
.hero-photo-static {
    transform: translateZ(0);
    isolation: isolate;
}
.hero-photo-static:after,
.hero-photo-static:before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    pointer-events: none;
    mix-blend-mode: screen;
    opacity: 0.24;
    animation: heroAmbientStatic 11s linear infinite;
    background:
        radial-gradient(circle at 28% 32%, rgba(255, 95, 95, 0.55), rgba(255, 95, 95, 0) 60%),
        radial-gradient(circle at 72% 68%, rgba(255, 180, 120, 0.45), rgba(255, 180, 120, 0) 65%),
        radial-gradient(circle at 50% 50%, hsla(0, 0%, 100%, 0.25), hsla(0, 0%, 100%, 0) 70%);
    filter: blur(8px) saturate(120%);
    transition: opacity 0.6s ease;
}
.hero-photo-static:after {
    animation-direction: reverse;
    animation-duration: 15s;
    opacity: 0.34;
    filter: blur(16px) saturate(155%);
}
.hero-photo-static img {
    animation:
        heroPhotoIn 1.1s ease forwards,
        heroFloat 7s ease-in-out 1.1s infinite;
}
.hero-photo-static.speed-slower:after,
.hero-photo-static.speed-slower:before {
    animation-duration: 18s !important;
}
.hero-photo-static.speed-slower img {
    animation:
        heroPhotoIn 1.2s ease forwards,
        heroFloat 11s ease-in-out 1.2s infinite !important;
}
.hero-photo-static.speed-faster:before {
    animation-duration: 8s !important;
}
.hero-photo-static.speed-faster:after {
    animation-duration: 11s !important;
}
.hero-photo-static.speed-faster img {
    animation:
        heroPhotoIn 0.95s ease forwards,
        heroFloat 5.5s ease-in-out 0.95s infinite !important;
}
.hero-photo-static.glow-strong:before {
    opacity: 0.35 !important;
    filter: blur(10px) saturate(150%) brightness(1.1) !important;
}
.hero-photo-static.glow-strong:after {
    opacity: 0.46 !important;
    filter: blur(20px) saturate(170%) brightness(1.15) !important;
}
.hero-photo-static.glow-soft:before {
    opacity: 0.14 !important;
    filter: blur(6px) saturate(110%) brightness(1) !important;
}
.hero-photo-static.glow-soft:after {
    opacity: 0.18 !important;
    filter: blur(10px) saturate(120%) brightness(1) !important;
}
@media (prefers-reduced-motion: reduce) {
    .hero-photo-static:after,
    .hero-photo-static:before {
        animation: none;
        opacity: 0.12;
    }
    .hero-photo-static img {
        animation: none;
    }
}
@keyframes heroAmbientStatic {
    0% {
        transform: rotate(0deg) scale(1);
    }
    50% {
        transform: rotate(180deg) scale(1.04);
    }
    to {
        transform: rotate(1turn) scale(1);
    }
}
@keyframes heroFloat {
    0% {
        transform: translateY(0) scale(1);
    }
    25% {
        transform: translateY(-6px) scale(1.01);
    }
    50% {
        transform: translateY(0) scale(1);
    }
    75% {
        transform: translateY(5px) scale(1.005);
    }
    to {
        transform: translateY(0) scale(1);
    }
}
.hero-photo .hero-ring {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    pointer-events: none;
    background: transparent;
    border: 1px solid #fff;
    box-shadow: 0 0 0 1px hsla(0, 0%, 100%, 0.9);
    opacity: 0.9;
    transition: opacity 0.45s ease;
}
.hero-photo:hover .hero-ring {
    opacity: 0.18;
}
.light .hero-photo .hero-ring {
    border-color: #fff;
    box-shadow: 0 0 0 1px hsla(0, 0%, 100%, 0.85);
}
.hero-photo.no-ring .hero-ring {
    display: none !important;
}
.light .hero-photo .hero-ring {
    background: conic-gradient(from 0deg, hsla(0, 0%, 100%, 0.9), hsla(0, 0%, 100%, 0.9));
    opacity: 0.6;
    box-shadow:
        0 0 14px -4px rgba(0, 0, 0, 0.25),
        inset 0 0 0 1px rgba(0, 0, 0, 0.08);
}
.light .hero-photo:before {
    background:
        radial-gradient(circle at 40% 38%, hsla(0, 100%, 74%, 0.35), hsla(0, 100%, 74%, 0) 65%),
        radial-gradient(circle at 72% 68%, rgba(255, 190, 120, 0.22), rgba(255, 190, 120, 0) 70%);
}
.light .hero-photo:after {
    box-shadow:
        0 0 0 4px #f2f2f2,
        inset 0 0 0 1px #e0e0e0,
        0 6px 20px -8px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(255, 122, 92, 0.28);
}
.hero-photo canvas.hero-particles {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    z-index: -1;
    mix-blend-mode: plus-lighter;
}
.hero-photo .hero-flash {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    pointer-events: none;
    background: radial-gradient(
        circle at 52% 48%,
        hsla(0, 0%, 100%, 0.5),
        hsla(0, 0%, 100%, 0) 65%
    );
    opacity: 0;
}
.hero-photo.is-visible {
    animation: heroPhotoIn var(--hero-dur-md) var(--hero-ease-snap) forwards;
}
.hero-photo.is-visible:not(.pending-anim) {
    filter: none;
    opacity: 1;
    transform: perspective(1200px) rotateX(0) rotateY(0) scale(1);
}
.hero-photo.mode-3d {
    border-radius: 24px;
    overflow: visible;
    filter: none !important;
    animation: none !important;
    transform: none !important;
}
.hero-photo.mode-3d .hero-flash,
.hero-photo.mode-3d .hero-particles-toggle,
.hero-photo.mode-3d .hero-ring,
.hero-photo.mode-3d canvas.hero-particles,
.hero-photo.mode-3d:after,
.hero-photo.mode-3d:before {
    display: none !important;
}
.hero-photo.mode-3d canvas.hero-3d {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    display: block;
    border-radius: 24px;
    outline: none;
}
.hero-photo .hero-pedestal-shadow {
    position: absolute;
    left: 50%;
    bottom: -14%;
    width: 135%;
    height: 32%;
    transform: translateX(-50%);
    background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.55), transparent 70%);
    filter: blur(6px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.9s ease 0.4s;
}
.hero-photo.mode-3d .hero-pedestal-shadow {
    opacity: 1;
}
.light .hero-photo.mode-3d .hero-pedestal-shadow {
    background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.35), transparent 70%);
}
.hero-particles-toggle {
    position: absolute;
    bottom: -2.25rem;
    right: 0;
    background: #1f1f1f;
    color: #ccc;
    font-size: 0.6rem;
    letter-spacing: 0.6px;
    padding: 0.4rem 0.55rem 0.38rem;
    border: 1px solid #2d2d2d;
    border-radius: 8px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    transition:
        background 0.3s,
        color 0.3s,
        border-color 0.3s,
        box-shadow 0.35s;
}
.hero-particles-toggle:hover {
    background: #262626;
    color: #fff;
}
.hero-particles-toggle[aria-pressed='true'] {
    background: linear-gradient(90deg, #d92323, #ff5858);
    color: #fff;
    border-color: #d92323;
    box-shadow:
        0 0 0 1px #d92323,
        0 0 12px -2px rgba(217, 35, 35, 0.55);
}
.light .hero-particles-toggle {
    background: #f5f5f5;
    color: #555;
    border-color: #d0d0d0;
}
.light .hero-particles-toggle:hover {
    background: #e9e9e9;
    color: #111;
}
.light .hero-particles-toggle[aria-pressed='true'] {
    background: linear-gradient(90deg, #ff7a5c, #f96);
    border-color: #ff7a5c;
    box-shadow:
        0 0 0 1px #ff7a5c,
        0 0 10px -2px rgba(255, 122, 92, 0.5);
}
@keyframes heroPhotoIn {
    0% {
        opacity: 0;
        transform: perspective(1200px) translateY(28px) scale(0.9);
        filter: blur(10px);
    }
    50% {
        filter: blur(0);
    }
    to {
        opacity: 1;
        transform: perspective(1200px) rotateX(0) rotateY(0) scale(1);
        filter: blur(0);
    }
}
@keyframes heroAmbientIn {
    to {
        opacity: 1;
    }
}
@keyframes heroRingSpin {
    to {
        transform: rotate(1turn);
    }
}
@keyframes heroFlash {
    0% {
        opacity: 0.55;
        transform: scale(0.4);
    }
    80% {
        opacity: 0;
    }
    to {
        opacity: 0;
        transform: scale(1.4);
    }
}
#summary-cards {
    position: relative;
}
#summary-cards > div {
    opacity: 0;
    transform: translateY(26px) scale(0.97);
    transition:
        opacity var(--hero-dur-md) var(--hero-ease-soft),
        transform var(--hero-dur-md) var(--hero-ease-soft),
        box-shadow var(--hero-dur-sm) var(--hero-ease-soft);
    will-change: transform, opacity;
    position: relative;
}
#summary-cards.is-visible > div {
    opacity: 1;
    transform: translateY(0) scale(1);
}
#summary-cards.is-visible > div:nth-child(2) {
    transition-delay: 0.07s;
}
#summary-cards.is-visible > div:nth-child(3) {
    transition-delay: 0.14s;
}
#summary-cards .card-hover-effect {
    overflow: hidden;
    perspective: 900px;
}
#summary-cards .summary-card {
    --rx: 0deg;
    --ry: 0deg;
    --card-accent-from: var(--color-accent);
    --card-accent-to: #ff5858;
    --card-accent-radial: rgba(217, 35, 35, 0.18);
    --card-tilt-max: 6deg;
    background:
        linear-gradient(145deg, #fff, #fafafa 70%, #f5f5f5),
        radial-gradient(circle at 20% 18%, rgba(0, 0, 0, 0.04), transparent 70%);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 14px;
    padding: 1.75rem 1.9rem 2rem;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    box-shadow:
        0 2px 6px rgba(0, 0, 0, 0.08),
        0 1px 2px rgba(0, 0, 0, 0.06);
    transform: translateZ(0) rotateX(var(--rx)) rotateY(var(--ry));
    transform-style: preserve-3d;
    transition:
        box-shadow 0.45s var(--hero-ease-soft),
        transform 0.55s cubic-bezier(0.19, 1, 0.22, 1),
        border-color 0.4s var(--hero-ease-soft);
    position: relative;
    overflow: hidden;
    color: #111;
}
#summary-cards .summary-card:before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(
        circle at var(--mx, 50%) var(--my, 50%),
        var(--card-accent-radial),
        transparent 72%
    );
    opacity: 0;
    transition: opacity 0.45s var(--hero-ease-soft);
    pointer-events: none;
}
#summary-cards .summary-card-inner {
    position: relative;
    z-index: 2;
}
#summary-cards .summary-card:focus-visible:before,
#summary-cards .summary-card:focus-within:before,
#summary-cards .summary-card:hover:before {
    opacity: 1;
}
#summary-cards .summary-card:focus-visible,
#summary-cards .summary-card:hover {
    box-shadow:
        0 10px 28px -8px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(0, 0, 0, 0.08);
    border-color: rgba(0, 0, 0, 0.16);
}
#summary-cards .summary-pill {
    display: inline-block;
    font-size: 0.55rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 0.35rem 0.55rem 0.3rem;
    background: linear-gradient(90deg, var(--card-accent-from), var(--card-accent-to));
    color: #fff;
    font-weight: 600;
    border-radius: 6px;
    box-shadow:
        0 0 0 1px hsla(0, 0%, 100%, 0.08),
        0 4px 10px -4px rgba(0, 0, 0, 0.55);
    transform: translateZ(40px);
}
#summary-cards .summary-title {
    font-size: 1.15rem;
    font-weight: 700;
    line-height: 1.25;
    color: #111;
    margin-top: 0.1rem;
    position: relative;
    padding-bottom: 0.55rem;
}
#summary-cards .summary-title:after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    height: 2px;
    width: 42%;
    background: linear-gradient(90deg, var(--card-accent-from), var(--card-accent-to));
    border-radius: 2px;
    transform-origin: left;
    transform: scaleX(0.4);
    opacity: 0.6;
    transition:
        transform 0.6s cubic-bezier(0.19, 1, 0.22, 1),
        opacity 0.5s;
}
#summary-cards .summary-card:focus-visible .summary-title:after,
#summary-cards .summary-card:hover .summary-title:after {
    transform: scaleX(1);
    opacity: 1;
}
#summary-cards .summary-body {
    font-size: 0.93rem;
    line-height: 1.5;
    color: #444;
}
#summary-cards .summary-metric {
    align-self: flex-start;
    margin-top: 0.4rem;
    font-size: 0.65rem;
    letter-spacing: 0.08em;
    font-weight: 600;
    color: var(--card-accent-from);
    background: rgba(217, 35, 35, 0.08);
    border: 1px solid rgba(217, 35, 35, 0.3);
    padding: 0.3rem 0.55rem 0.28rem;
    border-radius: 999px;
    backdrop-filter: blur(4px);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 2px 6px -2px rgba(0, 0, 0, 0.15);
}
#summary-cards .summary-icon {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--card-accent-from) 0, var(--card-accent-to) 90%);
    color: #fff;
    box-shadow:
        0 4px 18px -6px rgba(0, 0, 0, 0.6),
        0 0 0 1px hsla(0, 0%, 100%, 0.07);
    transform: translateZ(30px);
    position: relative;
    overflow: hidden;
}
#summary-cards .summary-icon img,
#summary-cards .summary-icon svg {
    width: 60%;
    height: 60%;
    display: block;
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.35));
}
#summary-cards .summary-icon:after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(
        circle at 30% 25%,
        hsla(0, 0%, 100%, 0.35),
        hsla(0, 0%, 100%, 0) 70%
    );
    opacity: 0.5;
    mix-blend-mode: overlay;
}
#summary-cards .summary-card:focus-visible {
    outline: 0;
    box-shadow:
        0 0 0 2px #ff5858,
        0 0 0 6px rgba(255, 88, 88, 0.35);
}
@media (max-width: 767px) {
    #summary-cards {
        display: flex;
        overflow-x: auto;
        gap: 1rem;
        scroll-snap-type: x mandatory;
        padding-bottom: 0.5rem;
        -webkit-overflow-scrolling: touch;
    }
    #summary-cards .summary-card {
        min-width: 76%;
        flex: 0 0 auto;
        scroll-snap-align: start;
    }
    #summary-cards::-webkit-scrollbar {
        height: 6px;
    }
    #summary-cards::-webkit-scrollbar-track {
        background: #111;
    }
    #summary-cards::-webkit-scrollbar-thumb {
        background: #2a2a2a;
        border-radius: 3px;
    }
}
.light #summary-cards .summary-card {
    background:
        linear-gradient(145deg, #fff, #fafafa 70%, #f5f5f5),
        radial-gradient(circle at 20% 18%, rgba(0, 0, 0, 0.03), transparent 72%);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06);
}
.light #summary-cards .summary-card:hover {
    box-shadow: 0 10px 26px -6px rgba(0, 0, 0, 0.22);
}
.light #summary-cards .summary-metric {
    background: rgba(217, 35, 35, 0.1);
}
@media (prefers-reduced-motion: reduce) {
    #summary-cards .summary-card {
        transform: none !important;
    }
    .hero-photo,
    .hero-photo .hero-flash,
    .hero-photo .hero-ring,
    .hero-photo:before {
        animation: none !important;
        transition: none !important;
        filter: none !important;
    }
    #summary-cards > div,
    .hero-photo {
        opacity: 1 !important;
        transform: none !important;
    }
    #summary-cards > div {
        transition: none !important;
    }
}
.focus-within\:outline-none:focus-within {
    outline: 2px solid transparent;
    outline-offset: 2px;
}
.hover\:scale-105:hover {
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    transform: translate(var(--tw-translate-x), 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));
}
.hover\:border-brand-red\/60:hover {
    border-color: rgba(217, 35, 35, 0.6);
}
.hover\:bg-brand-red:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(217 35 35 / var(--tw-bg-opacity, 1));
}
.hover\:bg-gray-700:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(55 65 81 / var(--tw-bg-opacity, 1));
}
.hover\:bg-gray-800:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(31 41 55 / var(--tw-bg-opacity, 1));
}
.hover\:text-brand-red:hover {
    --tw-text-opacity: 1;
    color: rgb(217 35 35 / var(--tw-text-opacity, 1));
}
.hover\:text-white:hover {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.hover\:underline:hover {
    text-decoration-line: underline;
}
.hover\:opacity-90:hover {
    opacity: 0.9;
}
.focus\:not-sr-only:focus {
    position: static;
    width: auto;
    height: auto;
    padding: 0;
    margin: 0;
    overflow: visible;
    clip: auto;
    white-space: normal;
}
.focus\:absolute:focus {
    position: absolute;
}
.focus\:left-2:focus {
    left: 0.5rem;
}
.focus\:top-2:focus {
    top: 0.5rem;
}
.focus\:outline-none:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
}
.focus-visible\:ring: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(3px + 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);
}
.group:hover .group-hover\:bg-brand-red\/20 {
    background-color: rgba(217, 35, 35, 0.2);
}
.group:hover .group-hover\:text-brand-red {
    --tw-text-opacity: 1;
    color: rgb(217 35 35 / var(--tw-text-opacity, 1));
}
@media (min-width: 640px) {
    .sm\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (min-width: 768px) {
    .md\:col-span-2 {
        grid-column: span 2 / span 2;
    }
    .md\:col-span-3 {
        grid-column: span 3 / span 3;
    }
    .md\:mx-0 {
        margin-left: 0;
        margin-right: 0;
    }
    .md\:my-24 {
        margin-top: 6rem;
        margin-bottom: 6rem;
    }
    .md\:flex {
        display: flex;
    }
    .md\:hidden {
        display: none;
    }
    .md\:h-80 {
        height: 20rem;
    }
    .md\:w-1\/3 {
        width: 33.333333%;
    }
    .md\:w-2\/3 {
        width: 66.666667%;
    }
    .md\:w-80 {
        width: 20rem;
    }
    .md\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .md\:grid-cols-5 {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
    .md\:flex-row {
        flex-direction: row;
    }
    .md\:flex-row-reverse {
        flex-direction: row-reverse;
    }
    .md\:justify-start {
        justify-content: flex-start;
    }
    .md\:justify-center {
        justify-content: center;
    }
    .md\:pl-24 {
        padding-left: 6rem;
    }
    .md\:pr-24 {
        padding-right: 6rem;
    }
    .md\:text-left {
        text-align: left;
    }
    .md\:text-right {
        text-align: right;
    }
    .md\:text-6xl {
        font-size: 3.75rem;
        line-height: 1;
    }
    .md\:text-sm {
        font-size: 0.875rem;
        line-height: 1.25rem;
    }
}
