/* === style.css === */
/* =========================================
   BRUTALIST TERMINAL AESTHETIC
   Typography: JetBrains Mono (Display), Source Code Pro (Body)
   Color: Terminal Green (#00FF41) on Near-Black (#050505)
   ========================================= */

@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;700;800&family=Source+Code+Pro:wght@400;600;700&display=swap');

:root {
    --color-bg: #0a0a0a;
    --color-text: #e0e0e0;
    --color-accent: #ff3333;
    --color-accent-secondary: #ff6b6b;
    --color-text-white: #ffffff;
    --color-text-black: #000000;
    --color-text-gray-300: #d1d5db;
    --color-text-gray-400: #9ca3af;
    --color-text-gray-500: #6b7280;
    --color-text-gray-600: #4b5563;

    --color-border-gray-700: #374151;
    --color-border-gray-800: #1f2937;
    --color-border-gray-900: #111827;

    --color-nav-bg: rgba(10, 10, 10, 0.95);
    --color-nav-text: #d1d5db;
    --color-nav-text-hover: #ff3333;

    --color-card-bg: #111111;

    --color-scrollbar-track: #111;
    --color-scrollbar-thumb: #333;
    --color-scrollbar-thumb-hover: var(--color-accent);
    --color-grid-bg: rgba(255, 51, 51, 0.03);

    --color-glitch-1: #ff0040;
    --color-glitch-2: #ff3333;
    --color-glass-bg: rgba(10, 10, 10, 0.65);
    --color-glass-border: rgba(255, 255, 255, 0.08);

    --color-terminal-bg: #0a0a0a;
    --color-terminal-border: var(--color-accent);
    --color-terminal-shadow: rgba(255, 51, 51, 0.15);
    --color-terminal-header: #1a1a1a;
    --color-terminal-input: #fff;
    --color-terminal-cursor: var(--color-accent);

    --color-command-success: #ff3333;
    --color-command-error: #ff5f56;
    --color-command-info: #00d4ff;
    --color-command-warning: #ffbd2e;

    --team-name: "Red Team";
    --team-icon: "🔴";

    --font-display: 'JetBrains Mono', monospace;
    --font-body: 'Source Code Pro', monospace;
}

/* =========================================
   BLUE TEAM THEME (DEFENSIVE)
   Dark navy for defensive security - keeps brutalist feel
   ========================================= */

.blue-team {
    --color-bg: #0a0f1a;
    --color-text: #e2e8f0;
    --color-accent: #3B82F6;
    --color-accent-secondary: #60a5fa;
    --color-text-white: #f1f5f9;
    --color-text-black: #000000;
    --color-text-gray-300: #cbd5e1;
    --color-text-gray-400: #94a3b8;
    --color-text-gray-500: #64748b;
    --color-text-gray-600: #475569;

    --color-border-gray-700: #334155;
    --color-border-gray-800: #1e293b;
    --color-border-gray-900: #0f172a;

    --color-nav-bg: rgba(10, 15, 26, 0.98);
    --color-nav-text: #e2e8f0;
    --color-nav-text-hover: #3B82F6;

    --color-card-bg: #0f172a;

    --color-scrollbar-track: #0f172a;
    --color-scrollbar-thumb: #334155;
    --color-grid-bg: rgba(59, 130, 246, 0.03);

    --color-glitch-1: #3B82F6;
    --color-glitch-2: #60a5fa;
    --color-glass-bg: rgba(10, 15, 26, 0.65);
    --color-glass-border: rgba(255, 255, 255, 0.08);

    --color-terminal-bg: #0f172a;
    --color-terminal-border: #3B82F6;
    --color-terminal-shadow: rgba(59, 130, 246, 0.15);
    --color-terminal-header: #1e293b;
    --color-terminal-input: #e2e8f0;
    --color-terminal-cursor: #3B82F6;

    --color-command-success: #3B82F6;
    --color-command-error: #ef4444;
    --color-command-info: #06b6d4;
    --color-command-warning: #f59e0b;

    --team-name: "Blue Team";
    --team-icon: "🔵";
}

/* Alias for backward compatibility */
/* Bright Navy Theme (Blue Team) */
.light-theme {
    --color-bg: #f0f4ff;
    --color-text: #1a2332;
    --color-accent: #1e3a8a;
    --color-accent-secondary: #2563eb;
    --color-text-white: #0f172a;
    --color-text-black: #ffffff;
    --color-text-gray-300: #334155;
    --color-text-gray-400: #475569;
    --color-text-gray-500: #64748b;
    --color-text-gray-600: #94a3b8;

    --color-border-gray-700: #cbd5e1;
    --color-border-gray-800: #e0e7ff;
    --color-border-gray-900: #f1f5f9;

    --color-nav-bg: rgba(255, 255, 255, 0.95);
    --color-nav-text: #334155;
    --color-nav-text-hover: #1e3a8a;

    --color-card-bg: #ffffff;

    --color-scrollbar-track: #e0e7ff;
    --color-scrollbar-thumb: #94a3b8;
    --color-scrollbar-thumb-hover: #1e3a8a;
    --color-grid-bg: rgba(30, 58, 138, 0.03);

    --color-terminal-bg: #ffffff;
    --color-terminal-shadow: rgba(30, 58, 138, 0.15);
    --color-terminal-header: #f1f5f9;
    --color-terminal-input: #0f172a;
    --color-terminal-border: #e0e7ff;
    --color-terminal-cursor: #1e3a8a;

    --color-command-success: #047857;
    --color-command-error: #b91c1c;
    --color-command-info: #1d4ed8;
    --color-command-warning: #b45309;
}

/* Blue theme text overrides for better readability */
.light-theme .text-white {
    color: #0f172a !important;
}

.light-theme .text-gray-300 {
    color: #334155 !important;
}

.light-theme .text-gray-400 {
    color: #475569 !important;
}

.light-theme .text-gray-500 {
    color: #64748b !important;
}

/* Blue theme stat numbers fix */
.light-theme .stat-number {
    color: #1e3a8a !important;
}

.light-theme .hero-stat-item span {
    color: #334155 !important;
}

/* Arabic RTL Support */
html[lang="ar"] {
    direction: rtl;
}

html[lang="ar"] body {
    font-family: 'Cairo', var(--font-body), sans-serif;
    text-align: right;
}

html[lang="ar"] .nav-menu {
    flex-direction: row-reverse;
}

html[lang="ar"] .hero-content {
    text-align: right;
}

/* Arabic - Fix flex directions */
html[lang="ar"] .flex {
    direction: rtl;
}

html[lang="ar"] .flip-card-front,
html[lang="ar"] .flip-card-back {
    text-align: right;
}

html[lang="ar"] .flip-card-front .flex {
    flex-direction: row-reverse;
}

html[lang="ar"] .experience-timeline {
    padding-left: 0;
    padding-right: 2rem;
}

html[lang="ar"] .experience-timeline::before {
    left: auto;
    right: 0;
}

html[lang="ar"] .experience-item {
    padding-left: 0;
    padding-right: 2rem;
}

html[lang="ar"] .experience-dot {
    left: auto;
    right: -8px;
}

html[lang="ar"] .hero-stats-row {
    border-left: none;
    border-right: 4px solid var(--color-accent);
    padding-left: 0;
    padding-right: 2rem;
}

html[lang="ar"] .blog-card {
    text-align: right;
}

html[lang="ar"] .terminal-body {
    direction: ltr !important;
    text-align: left !important;
}

/* Mobile responsive - RTL adjustments */
@media (max-width: 768px) {
    html[lang="ar"] .experience-timeline {
        padding-right: 1.5rem;
    }

    html[lang="ar"] .experience-item {
        padding-right: 1.5rem;
    }
}



/* Global Reset & Base */
body {
    background-color: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-body);
    overflow-x: hidden;
    scroll-behavior: smooth;
    position: relative;
}

#noise-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
    /* Modern, fast radial glow instead of expensive SVG noise filter */
    background: radial-gradient(circle at 50% -20%, var(--color-terminal-shadow) 0%, transparent 80%);
}

html[lang="ar"] body {
    font-family: 'Cairo', var(--font-body), sans-serif;
}

::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: var(--color-scrollbar-track);
}

::-webkit-scrollbar-thumb {
    background: var(--color-scrollbar-thumb);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--color-scrollbar-thumb-hover);
}

.grid-bg {
    background-color: var(--color-bg) !important;
    /* Minimal modern grid pattern */
    background-image:
        linear-gradient(var(--color-grid-bg) 1px, transparent 1px),
        linear-gradient(90deg, var(--color-grid-bg) 1px, transparent 1px) !important;
    background-size: 30px 30px !important;
    background-position: center top !important;
}

/* Full-Width Glassmorphism Navbar */
.navbar-glass {
    background: rgba(10, 10, 10, 0.75);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(255, 51, 51, 0.2);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.5);
    transition: all 0.3s ease;
}

/* Glassmorphism utility */
.glassmorphism {
    background: var(--color-glass-bg);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--color-glass-border);
}

.floating-navbar {
    border-radius: 0;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    transition: all 0.3s ease;
}

@media (max-width: 768px) {
    .floating-navbar {
        top: 1rem !important;
        width: 92% !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        border-radius: 12px;
        border: 1px solid var(--color-glass-border) !important;
    }
}

.blue-team .navbar-glass {
    background: rgba(10, 15, 26, 0.75);
    border-bottom-color: rgba(59, 130, 246, 0.2);
}

.light-theme .navbar-glass {
    background: rgba(240, 244, 255, 0.75);
    border-bottom-color: rgba(30, 58, 138, 0.2);
}

/* Glitch Effect */
.glitch-wrapper {
    position: relative;
    display: inline-block;
    line-height: 1.2;
}

.glitch {
    position: relative;
    color: var(--color-text-white);
    display: inline-block;
}

.glitch::before,
.glitch::after {
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.8;
    background: transparent;
    pointer-events: none;
}

.glitch::before {
    left: 2px;
    text-shadow: -1px 0 var(--color-accent);
    clip-path: polygon(0 0, 100% 0, 100% 35%, 0 35%);
    animation: glitch-anim 2.5s infinite linear alternate-reverse;
}

.glitch::after {
    left: -2px;
    text-shadow: 1px 0 var(--color-accent);
    clip-path: polygon(0 65%, 100% 65%, 100% 100%, 0 100%);
    animation: glitch-anim2 2.5s infinite linear alternate-reverse;
}

@keyframes glitch-anim {

    0%,
    100% {
        transform: translate(0);
    }

    20% {
        transform: translate(-2px, 1px);
    }

    40% {
        transform: translate(-2px, -1px);
    }

    60% {
        transform: translate(1px, 1px);
    }

    80% {
        transform: translate(1px, -1px);
    }
}

@keyframes glitch-anim2 {

    0%,
    100% {
        transform: translate(0);
    }

    25% {
        transform: translate(2px, -1px);
    }

    50% {
        transform: translate(-1px, 1px);
    }

    75% {
        transform: translate(1px, 2px);
    }
}

/* Hero Section Name Glitch Effect */
.glitch-name {
    position: relative;
    display: inline-block;
    animation: glitch-subtle 3s infinite;
}

.glitch-name::before,
.glitch-name::after {
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}

.glitch-name::before {
    animation: glitch-before 3s infinite;
    color: var(--color-accent);
    z-index: -1;
}

.glitch-name::after {
    animation: glitch-after 3s infinite;
    color: var(--color-accent);
    z-index: -2;
}

@keyframes glitch-subtle {

    0%,
    90%,
    100% {
        transform: translate(0);
    }

    92% {
        transform: translate(-1px, 1px);
    }

    94% {
        transform: translate(1px, -1px);
    }
}

@keyframes glitch-before {

    0%,
    90%,
    100% {
        opacity: 0;
        transform: translate(0);
    }

    92% {
        opacity: 0.7;
        transform: translate(-2px, 0);
    }
}

@keyframes glitch-after {

    0%,
    90%,
    100% {
        opacity: 0;
        transform: translate(0);
    }

    94% {
        opacity: 0.7;
        transform: translate(2px, 0);
    }
}

/* Hero Role Typing Animation */
.hero-role {
    color: var(--color-accent);
    font-weight: 600;
    display: inline-block;
    min-width: 200px;
}

.hero-role::after {
    content: '|';
    animation: blink 1s infinite;
    margin-left: 2px;
}

.nav-link {
    position: relative;
    font-family: var(--font-display), monospace;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.nav-link::after {
    content: '';
    position: absolute;
    width: 0;
    height: 1px;
    bottom: -4px;
    left: 0;
    background-color: var(--color-accent);
    transition: width 0.3s;
}

.nav-link:hover::after {
    width: 100%;
}

html[dir="rtl"] .nav-link::after {
    left: auto;
    right: 0;
}

#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--color-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    transition: opacity 0.5s ease;
}

.terminal-loader {
    font-family: var(--font-display), monospace;
    color: var(--color-accent);
    font-size: 16px;
    letter-spacing: 2px;
}

.terminal-loader::after {
    content: '_';
    animation: blink 1s infinite;
}

@keyframes blink {
    50% {
        opacity: 0;
    }
}

/* Scroll Reveal Animation Classes */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.5, 0, 0, 1);
}

.reveal.active {
    opacity: 1;
    transform: translateY(0);
}

/* Staggered Animation Delays */
.reveal.delay-100 {
    transition-delay: 0.1s;
}

.reveal.delay-200 {
    transition-delay: 0.2s;
}

.reveal.delay-300 {
    transition-delay: 0.3s;
}

.reveal.delay-400 {
    transition-delay: 0.4s;
}

.reveal.delay-500 {
    transition-delay: 0.5s;
}

.reveal.delay-600 {
    transition-delay: 0.6s;
}

.reveal.delay-700 {
    transition-delay: 0.7s;
}

.reveal.delay-800 {
    transition-delay: 0.8s;
}

/* Slide-in animations */
@keyframes slideInLeft {
    from {
        opacity: 0;
        transform: translateX(-30px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes slideInRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Scan line effect */
@keyframes scanline {
    0% {
        transform: translateY(-100%);
    }

    100% {
        transform: translateY(100vh);
    }
}

.scanline-effect::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(to bottom, transparent, var(--color-accent), transparent);
    opacity: 0.1;
    animation: scanline 8s linear infinite;
}

.no-select {
    user-select: none;
}

/* =========================================
 T ERMINAL COMPONENT STYLES
 ========================================= */

.terminal-container {
    background: var(--color-terminal-bg);
    border: 1px solid var(--color-terminal-border);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 0 30px var(--color-terminal-shadow);
}

.terminal-header {
    background: var(--color-terminal-header);
    padding: 12px 16px;
    border-bottom: 1px solid var(--color-terminal-border);
    display: flex;
    align-items: center;
    gap: 8px;
}

.terminal-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: inline-block;
}

.dot-close {
    background: #ff5f56;
}

.dot-minimize {
    background: #ffbd2e;
}

.dot-maximize {
    background: #27c93f;
}

.terminal-body {
    padding: 20px;
    height: 400px;
    overflow-y: auto;
    font-family: var(--font-display), monospace;
    font-size: 14px;
    line-height: 1.6;
    /* Force LTR even in Arabic mode */
    direction: ltr !important;
    text-align: left !important;
}

.terminal-output {
    color: var(--color-text);
    margin-bottom: 10px;
}

.terminal-prompt {
    color: var(--color-accent);
    display: inline-block;
}

.terminal-input {
    background: none;
    border: none;
    color: var(--color-terminal-input);
    font-family: var(--font-display), monospace;
    font-size: 14px;
    outline: none;
    width: calc(100% - 200px);
    margin-left: 8px;
    /* Force LTR */
    direction: ltr !important;
    text-align: left !important;
}

.terminal-cursor {
    display: inline-block !important;
    width: 10px;
    height: 1.1em;
    background-color: var(--color-accent);
    vertical-align: text-bottom;
    margin-left: 4px;
    float: none !important;
    animation: blink 1s step-end infinite;
}

.terminal-line {
    margin-bottom: 8px;
}

.command-success {
    color: var(--color-command-success);
}

.command-error {
    color: var(--color-command-error);
}

.command-info {
    color: var(--color-command-info);
}

.command-warning {
    color: var(--color-command-warning);
}

.ascii-art {
    color: var(--color-accent);
    line-height: 1.2;
    font-size: 12px;
}

/* Custom Scrollbar for Terminal */
.terminal-body::-webkit-scrollbar {
    width: 8px;
}

.terminal-body::-webkit-scrollbar-track {
    background: var(--color-terminal-bg);
}

.terminal-body::-webkit-scrollbar-thumb {
    background: var(--color-accent);
    border-radius: 4px;
}

/* Tailwind CSS classes overrides */
.bg-black\/80 {
    background-color: var(--color-nav-bg) !important;
}

.text-gray-300 {
    color: var(--color-text-gray-300) !important;
}

.hover\:text-white:hover {
    color: var(--color-nav-text-hover) !important;
}

.border-gray-800 {
    border-color: var(--color-border-gray-800) !important;
}

.text-white {
    color: var(--color-text-white) !important;
}

.text-accent {
    color: var(--color-accent) !important;
}

.border-accent {
    border-color: var(--color-accent) !important;
}

.hover\:text-accent:hover {
    color: var(--color-accent) !important;
}

.bg-accent {
    background-color: var(--color-accent) !important;
}

.text-black {
    color: var(--color-text-black) !important;
}

.hover\:bg-accent:hover {
    background-color: var(--color-accent) !important;
}

.hover\:text-black:hover {
    color: var(--color-text-black) !important;
}

.text-gray-400 {
    color: var(--color-text-gray-400) !important;
}

.border-l {
    border-left-color: var(--color-border-gray-700) !important;
}

.border-gray-700 {
    border-color: var(--color-border-gray-700) !important;
}

.bg-dark-bg {
    background-color: var(--color-terminal-bg) !important;
}

.bg-card-bg {
    background-color: var(--color-card-bg) !important;
}

.border-y {
    border-top-color: var(--color-border-gray-900) !important;
    border-bottom-color: var(--color-border-gray-900) !important;
}

.border-gray-900 {
    border-color: var(--color-border-gray-900) !important;
}

.text-gray-500 {
    color: var(--color-text-gray-500) !important;
}

.divide-x> :not([hidden])~ :not([hidden]) {
    border-left-color: var(--color-border-gray-800) !important;
}

.rtl .divide-x-reverse> :not([hidden])~ :not([hidden]) {
    border-right-color: var(--color-border-gray-800) !important;
}

.border-b {
    border-bottom-color: var(--color-border-gray-800) !important;
}

.bg-green-900\/10 {
    background-color: rgba(0, 255, 65, 0.1) !important;
}

.light-theme .bg-green-900\/10 {
    background-color: rgba(0, 82, 204, 0.1) !important;
}

.bg-gray-900 {
    background-color: #111827 !important;
}

.light-theme .bg-gray-900 {
    background-color: #e5e7eb !important;
}

.text-gray-600 {
    color: var(--color-text-gray-600) !important;
}

.text-green-900 {
    color: #042f14 !important;
}

.light-theme .text-green-900 {
    color: #cce5ff !important;
}

.hover\:border-accent:hover {
    border-color: var(--color-accent) !important;
}

.hover\:shadow-\[0_0_10px_rgba\(0\,255\,65\,0\.1\)\]:hover {
    box-shadow: 0 0 10px var(--color-terminal-shadow) !important;
}

.hover\:shadow-\[0_0_20px_rgba\(0\,255\,65\,0\.1\)\]:hover {
    box-shadow: 0 0 20px var(--color-terminal-shadow) !important;
}

.hover\:shadow-\[0_0_15px_rgba\(0\,255\,65\,0\.2\)\]:hover {
    box-shadow: 0 0 15px var(--color-terminal-shadow) !important;
}

.hover\:bg-white:hover {
    background-color: var(--color-text-white) !important;
}

/* Flipping Card Effect */
.flip-card {
    background-color: transparent;
    perspective: 1000px;
}

.flip-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    text-align: center;
    transition: transform 0.6s;
    transform-style: preserve-3d;
}

.flip-card:hover .flip-card-inner {
    transform: rotateY(180deg);
}

.flip-card-front,
.flip-card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

/* Glowing Text Effect - Red for Red Team */
.glowing-text {
    color: #ff3333;
    background: linear-gradient(90deg, #ff0000, #ff4d4d, #ff0000);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 0 10px rgba(255, 51, 51, 0.5);
    animation: glow-red 3s linear infinite;
}

@keyframes glow-red {
    0% {
        background-position: 0% 50%;
        text-shadow: 0 0 10px rgba(255, 51, 51, 0.5);
    }

    50% {
        background-position: 100% 50%;
        text-shadow: 0 0 20px rgba(255, 51, 51, 0.8), 0 0 30px rgba(255, 51, 51, 0.4);
    }

    100% {
        background-position: 0% 50%;
        text-shadow: 0 0 10px rgba(255, 51, 51, 0.5);
    }
}

/* Glowing Text Effect - Blue Team */
.blue-team .glowing-text {
    color: #3B82F6;
    background: linear-gradient(90deg, #60a5fa, #3B82F6, #60a5fa);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 0 10px rgba(59, 130, 246, 0.5);
    animation: glow-blue 3s linear infinite;
}

@keyframes glow-blue {
    0% {
        background-position: 0% 50%;
        text-shadow: 0 0 10px rgba(59, 130, 246, 0.5);
    }

    50% {
        background-position: 100% 50%;
        text-shadow: 0 0 20px rgba(59, 130, 246, 0.8), 0 0 30px rgba(59, 130, 246, 0.4);
    }

    100% {
        background-position: 0% 50%;
        text-shadow: 0 0 10px rgba(59, 130, 246, 0.5);
    }
}

/* Blue Team Badge */
.blue-team .min-badge {
    background: rgba(59, 130, 246, 0.08);
}

.blue-team .hero-handle {
    color: var(--color-accent);
    text-shadow: 0 0 30px rgba(59, 130, 246, 0.5);
}

.blue-team .hero-intro {
    background: rgba(59, 130, 246, 0.03) !important;
}

.blue-team .btn-massive:hover {
    box-shadow: 0 0 30px rgba(59, 130, 246, 0.3);
}

.blue-team .btn-secondary:hover {
    box-shadow: 0 0 20px rgba(59, 130, 246, 0.15);
}



.flip-card-front {
    background-color: var(--color-card-bg);
}

.flip-card-back {
    background-color: var(--color-card-bg);
    transform: rotateY(180deg);
    padding: 1.5rem;
}

.animated-gradient {
    background: var(--color-bg);
}

@keyframes gradient {
    0% {
        background-position: 0% 50%;
    }

    50% {
        background-position: 100% 50%;
    }

    100% {
        background-position: 0% 50%;
    }
}

/* Add this to your css/style.css file */
.light-theme .hover\:text-black:hover {
    color: var(--color-text-black) !important;
}

.hover\:text-black:hover {
    color: var(--color-text-black) !important;
}

.light-theme .text-gray-400 {
    color: var(--color-text-gray-400) !important;
}

.light-theme .text-gray-500 {
    color: var(--color-text-gray-500) !important;
}

.light-theme .text-white {
    color: var(--color-text-white) !important;
}

.light-theme .bg-black\/80 {
    background-color: var(--color-nav-bg) !important;
}

.light-theme a.nav-link {
    color: var(--color-nav-text) !important;
}

/* Skills section improvements */
.skills-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--color-text-gray-400);
    font-family: var(--font-display), monospace;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 1rem;
}

.skills-header::before {
    content: '>>';
    display: inline-block;
    color: var(--color-accent);
    font-weight: 700;
}

.skill {
    margin-bottom: 0.85rem;
}

.skill .w-full {
    background-color: var(--color-border-gray-800) !important;
    height: 10px;
    border-radius: 999px;
}

.skill .w-full .bg-accent {
    height: 100% !important;
    border-radius: inherit;
    box-shadow: 0 4px 12px rgba(0, 255, 65, 0.07);
    transition: width 0.9s cubic-bezier(0.2, 0.9, 0.2, 1);
    background: linear-gradient(90deg, var(--color-accent), rgba(0, 255, 65, 0.6)) !important;
}

.skill .flex {
    gap: 0.5rem;
    align-items: center;
}

@media (max-width: 768px) {
    .skills-header::before {
        width: 32px;
        height: 5px;
    }

    .skill .w-full {
        height: 8px;
    }
}

.light-theme a.nav-link:hover {
    color: var(--color-nav-text-hover) !important;
}

.light-theme .border-b {
    border-color: var(--color-border-gray-800) !important;
}

.light-theme .border-gray-800 {
    border-color: var(--color-border-gray-800) !important;
}

.light-theme .text-accent {
    color: var(--color-accent) !important;
}

.light-theme .bg-accent {
    background-color: var(--color-accent) !important;
}

.light-theme .text-black {
    color: var(--color-text-white) !important;
}

.light-theme .border-accent {
    border-color: var(--color-accent) !important;
}

.light-theme .hover\:bg-accent:hover {
    background-color: var(--color-accent) !important;
}

.light-theme .hover\:text-accent:hover {
    color: var(--color-accent) !important;
}

.light-theme .bg-card-bg {
    background-color: var(--color-card-bg) !important;
}

.light-theme .border-y {
    border-top-color: var(--color-border-gray-900) !important;
    border-bottom-color: var(--color-border-gray-900) !important;
}

.light-theme .border-gray-900 {
    border-color: var(--color-border-gray-900) !important;
}

.light-theme .divide-x> :not([hidden])~ :not([hidden]) {
    border-left-color: var(--color-border-gray-800) !important;
}

.light-theme .rtl .divide-x-reverse> :not([hidden])~ :not([hidden]) {
    border-right-color: var(--color-border-gray-800) !important;
}

.light-theme .text-gray-600 {
    color: var(--color-text-gray-600) !important;
}

/* Making sure that the icon in the theme-toggle button has the correct color in both themes */
#theme-toggle i {
    color: var(--color-text-gray-400);
}

#theme-toggle:hover i {
    color: var(--color-accent);
}

#lang-btn {
    border-color: var(--color-accent);
    color: var(--color-accent);
}

#lang-btn:hover {
    background-color: var(--color-accent);
    color: var(--color-text-black);
}

/* Mobile Menu Fixes */
#mobile-menu {
    top: 48px;
    /* Just below mobile navbar */
    left: 0;
    right: 0;
    transition: all 0.3s ease-in-out;
    background: #0a0a0a;
    min-height: auto;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    display: none;
    z-index: 41;
    border-radius: 0 0 1.5rem 1.5rem !important;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    background: rgba(10, 10, 10, 0.85);
    border: 1px solid var(--color-glass-border);
}

#mobile-menu.matrix-open {
    display: flex !important;
    animation: slideDown 0.3s ease-out;
}

#mobile-menu:not(.hidden) {
    display: block;
    animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

#mobile-menu a {
    display: block;
    padding: 1rem 0;
    color: #ffffff !important;
    font-family: var(--font-display), monospace;
    font-size: 1rem;
    transition: color 0.2s ease;
    border-bottom: 1px solid rgba(55, 65, 81, 0.5);
}

#mobile-menu a:last-child {
    border-bottom: none;
}

#mobile-menu a:hover {
    color: var(--color-accent) !important;
}

/* Mobile menu theme toggle and language button */
#mobile-menu .mobile-controls {
    display: flex;
    gap: 1rem;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(55, 65, 81, 0.5);
    flex-wrap: wrap;
}

#mobile-menu .mobile-controls button,
#mobile-menu .mobile-controls a {
    flex: 1;
    min-width: 80px;
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    text-align: center;
    border: 1px solid var(--color-accent) !important;
    color: var(--color-accent) !important;
    background: transparent;
    border-radius: 0.25rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

#mobile-menu .mobile-controls button:hover,
#mobile-menu .mobile-controls a:hover {
    background: var(--color-accent);
    color: #000000 !important;
}

/* Mobile menu social icons */
#mobile-menu .flex.justify-center {
    border-top: 1px solid rgba(55, 65, 81, 0.5);
}

#mobile-menu .flex.justify-center a {
    border-bottom: none !important;
    padding: 0.5rem;
    color: #9ca3af !important;
}

#mobile-menu .flex.justify-center a:hover {
    color: var(--color-accent) !important;
}

/* Mobile responsive glitch effect - reduce intensity on small screens */
@media (max-width: 768px) {

    .glitch::before,
    .glitch::after {
        opacity: 0.5;
    }

    .glitch::before {
        left: 1px;
    }

    .glitch::after {
        left: -1px;
    }

    /* Ensure buttons maintain consistent styling in all languages */
    .bg-accent {
        background-color: var(--color-accent) !important;
        color: var(--color-text-black) !important;
    }
}

/* Ensure consistent button styling regardless of language */
html[lang="ar"] .bg-accent {
    background-color: var(--color-accent) !important;
    color: var(--color-text-black) !important;
}

html[lang="ar"] .bg-gray-800 {
    background-color: #1f2937 !important;
}

/* Fix for text overlap in hero section */
.glitch-wrapper {
    isolation: isolate;
}

/* Improved typing text visibility */
#typing-text {
    min-height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* =========================================
   BRUTALIST HERO SECTION
   ========================================= */

.hero-minimal {
    min-height: 100vh;
    padding-top: 100px;
    padding-bottom: 80px;
    position: relative;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.hero-grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 4rem;
    align-items: center;
}

@media (max-width: 1024px) {
    .hero-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
        text-align: center;
        display: flex;
        flex-direction: column-reverse;
        align-items: center;
    }

    .hero-grid .text-left {
        text-align: center;
        width: 100%;
    }
}

/* Brutalist Terminal Window for Hero */
.hero-terminal {
    background: var(--color-terminal-bg);
    border: 1px solid var(--color-accent);
    border-radius: 8px;
    overflow: hidden;
    box-shadow:
        0 0 0 1px var(--color-accent),
        0 0 40px var(--color-terminal-shadow),
        inset 0 0 60px rgba(0, 255, 65, 0.02);
    position: relative;
}

.hero-terminal::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
}

.hero-terminal-header {
    background: var(--color-terminal-header);
    padding: 12px 16px;
    border-bottom: 1px solid var(--color-border-gray-800);
    display: flex;
    align-items: center;
    gap: 8px;
}

.hero-terminal-dots {
    display: flex;
    gap: 6px;
}

.hero-terminal-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
}

.hero-terminal-dot.red {
    background: #ff5f56;
}

.hero-terminal-dot.yellow {
    background: #ffbd2e;
}

.hero-terminal-dot.green {
    background: #27c93f;
}

.hero-terminal-title {
    color: var(--color-text-gray-500);
    font-family: var(--font-body);
    font-size: 0.75rem;
    margin-left: auto;
    margin-right: auto;
}

.hero-terminal-body {
    padding: 24px;
}

/* Brutalist Badge */
.min-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 51, 51, 0.08);
    border: 1px solid var(--color-accent);
    padding: 6px 14px;
    font-family: var(--font-body);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-accent);
    margin-bottom: 1.5rem;
}

.min-dot {
    width: 6px;
    height: 6px;
    background: var(--color-accent);
    border-radius: 50%;
    animation: pulse-dot 2s infinite;
}

@keyframes pulse-dot {

    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.5;
        transform: scale(0.8);
    }
}

/* Brutalist Headline */
.hero-headline {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -2px;
    margin-bottom: 1rem;
    text-transform: uppercase;
}

/* Brutalist Handle Display */
.hero-handle {
    font-family: var(--font-display);
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 800;
    color: var(--color-accent);
    text-shadow: 0 0 30px rgba(255, 51, 51, 0.5);
    letter-spacing: -1px;
    display: block;
    margin-bottom: 0.5rem;
}

.hero-sub {
    font-size: 1.1rem;
    color: var(--color-text-gray-400);
    margin-bottom: 1.5rem;
    line-height: 1.7;
}

.hero-role {
    color: var(--color-accent);
    font-weight: 600;
    display: inline-block;
    min-width: 200px;
}

.hero-role::after {
    content: '|';
    animation: blink 1s infinite;
    margin-left: 4px;
    color: var(--color-accent);
}

/* Brutalist Mission Box */
.hero-intro {
    font-family: var(--font-body);
    background: rgba(255, 51, 51, 0.03) !important;
    border: 1px solid var(--color-border-gray-800);
    border-left: 3px solid var(--color-accent) !important;
    padding: 16px 20px !important;
    margin-bottom: 2rem;
    position: relative;
}

.hero-intro::before {
    content: '//';
    position: absolute;
    top: -10px;
    left: 12px;
    background: var(--color-bg);
    padding: 0 8px;
    font-family: var(--font-display);
    font-size: 0.7rem;
    color: var(--color-accent);
    letter-spacing: 2px;
}

/* Brutalist CTA Buttons */
.btn-massive {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 1rem 2.5rem;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-text-black);
    background: var(--color-accent);
    border: 2px solid var(--color-accent);
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

.btn-massive::before {
    content: '>';
    margin-right: 10px;
    font-weight: 800;
    transition: transform 0.3s;
}

.btn-massive:hover {
    background: transparent;
    color: var(--color-accent);
    box-shadow: 0 0 30px rgba(255, 51, 51, 0.3);
}

.btn-massive:hover::before {
    transform: translateX(4px);
}

.btn-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.875rem 2rem;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--color-text-gray-300);
    background: transparent;
    border: 1px solid var(--color-border-gray-700);
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-secondary:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
    box-shadow: 0 0 20px rgba(255, 51, 51, 0.15);
}

/* Hero Profile Image - Circular Hover Glow */
.hero-image-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    padding: 2rem;
}

.profile-clean {
    width: 280px;
    height: 280px;
    object-fit: cover;
    border-radius: 50%;
    border: 3px solid transparent;
    filter: grayscale(100%) contrast(1.1);
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    z-index: 2;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
    animation: float 6s ease-in-out infinite;
}

.profile-clean:hover {
    filter: grayscale(0%) contrast(1);
    box-shadow: 0 0 40px var(--color-accent);
    transform: translateY(-10px) scale(1.05);
    border-color: var(--color-accent);
}

@keyframes float {
    0% {
        transform: translateY(0px);
    }

    50% {
        transform: translateY(-15px);
    }

    100% {
        transform: translateY(0px);
    }
}

@media (max-width: 1024px) {
    .profile-clean {
        width: 220px;
        height: 220px;
    }
}

@media (max-width: 768px) {
    .profile-clean {
        width: 180px;
        height: 180px;
    }
}

/* Brutalist Section Headers */
.section-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.section-marker {
    font-family: var(--font-display);
    font-size: 0.7rem;
    color: var(--color-accent);
    letter-spacing: 3px;
}

.section-title {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-text-white);
    letter-spacing: -1px;
}

.section-line {
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, var(--color-border-gray-800), transparent);
}

/* =========================================
   CYBERSECURITY HEX BADGES
   ========================================= */

.cyber-badges-container {
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 0 !important;
    width: 100% !important;
    max-width: 420px !important;
    margin: 0 auto !important;
    align-items: start !important;
    padding: 2rem 1rem !important;
}

.cyber-badge-wrapper {
    position: relative !important;
    aspect-ratio: 1 / 1.1547 !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: transform 0.3s ease !important;
}

.cyber-badge-wrapper:nth-child(1) { grid-column: 1 / span 2 !important; margin-top: 0 !important; }
.cyber-badge-wrapper:nth-child(2) { grid-column: 3 / span 2 !important; margin-top: 0 !important; }
.cyber-badge-wrapper:nth-child(3) { grid-column: 5 / span 2 !important; margin-top: 0 !important; }

.cyber-badge-wrapper:nth-child(4) { grid-column: 2 / span 2 !important; margin-top: -28.8% !important; }
.cyber-badge-wrapper:nth-child(5) { grid-column: 4 / span 2 !important; margin-top: -28.8% !important; }

.cyber-badge-wrapper:nth-child(6) { grid-column: 3 / span 2 !important; margin-top: -28.8% !important; }

.cyber-badge {
    position: absolute !important;
    inset: 2px !important;
    background: var(--color-border-gray-800) !important;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%) !important;
    transition: all 0.3s ease !important;
}
.cyber-badge-inner {
    position: absolute !important;
    inset: 1px !important;
    background: var(--color-card-bg) !important;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    z-index: 2 !important;
    padding: 5px !important;
}

.skill-bar-container, .badge-glow { display: none !important; }

.cyber-badge-wrapper:hover {
    transform: translateY(-5px) scale(1.05) !important;
    z-index: 10 !important;
}
.cyber-badge-wrapper:hover .cyber-badge {
    background: var(--color-accent) !important;
}

.cyber-badge {
    position: absolute !important;
    inset: 2px !important;
    background: var(--color-border-gray-800) !important;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%) !important;
    transition: all 0.3s ease !important;
}

.cyber-badge-inner {
    position: absolute !important;
    inset: 1px !important;
    background: var(--color-card-bg) !important;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    z-index: 2 !important;
}

.skill-bar-container, .badge-glow {
    display: none !important;
}

.cyber-badge-wrapper:hover {
    transform: translateY(-5px) scale(1.05) !important;
    z-index: 10 !important;
}
.cyber-badge-wrapper:hover .cyber-badge {
    background: var(--color-accent) !important;
}

.badge-icon {
    font-size: 2.5rem;
    color: var(--color-text-gray-400);
    margin-bottom: 0.75rem;
    transition: all 0.3s ease;
    display: flex;
    justify-content: center;
    align-items: center;
}

.cyber-badge-wrapper:hover .badge-icon {
    color: var(--color-accent);
    transform: scale(1.1);
    filter: drop-shadow(0 0 8px var(--color-accent));
}

.badge-title {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--color-text-white);
    margin-bottom: 0.25rem;
    text-align: center;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    font-family: var(--font-display), monospace;
}

.badge-level {
    font-size: 0.85rem;
    color: var(--color-accent);
    font-family: 'Fira Code', monospace;
    font-weight: 600;
}


/* =========================================
   TOOLS ARSENAL TAG CLOUD
   ========================================= */
/* =========================================
   CATEGORIZED TERMINAL HUD V2 (TOOLS ARSENAL)
   ========================================= */
.tools-hud-container {
    width: 100%;
    max-width: 800px;
    margin: 4rem auto 0 auto;
    background: var(--color-terminal-bg);
    border: 1px solid var(--color-border-gray-800);
    border-left: 3px solid var(--color-accent);
    padding: 2.5rem 1.5rem 2rem 1.5rem;
    font-family: var(--font-display), monospace;
    position: relative;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
    overflow: hidden;
    z-index: 10;
}

.tools-hud-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: repeating-linear-gradient(
        0deg,
        transparent,
        transparent 2px,
        rgba(0, 0, 0, 0.03) 2px,
        rgba(0, 0, 0, 0.03) 4px
    );
    pointer-events: none;
    z-index: 1;
}

.tools-hud-container::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(ellipse at center, transparent 0%, rgba(0, 0, 0, 0.1) 100%);
    pointer-events: none;
    z-index: 2;
}

.hud-corner {
    position: absolute;
    width: 12px;
    height: 12px;
    border-color: var(--color-accent);
    border-style: solid;
    opacity: 0.8;
    z-index: 3;
}

.hud-corner-tl { top: 8px; left: 8px; border-width: 2px 0 0 2px; }
.hud-corner-tr { top: 8px; right: 8px; border-width: 2px 2px 0 0; }
.hud-corner-bl { bottom: 8px; left: 8px; border-width: 0 0 2px 2px; }
.hud-corner-br { bottom: 8px; right: 8px; border-width: 0 2px 2px 0; }

.hud-meta-bar {
    position: absolute;
    top: -12px;
    left: 15px;
    right: 15px;
    display: flex;
    justify-content: space-between;
    background: var(--color-bg);
    padding: 4px 12px;
    font-size: 0.65rem;
    color: var(--color-text-gray-500);
    letter-spacing: 1px;
    z-index: 10;
}

.hud-meta-bar span {
    margin-right: 15px;
}

.hud-meta-module { color: var(--color-accent) !important; font-weight: 700; }
.hud-meta-status { color: #22c55e !important; }
.hud-meta-version { color: var(--color-text-gray-400) !important; }

.hud-header {
    position: relative;
    top: -8px;
    left: 15px;
    background: var(--color-bg);
    padding: 0 10px;
    font-size: 0.75rem;
    color: var(--color-accent);
    font-weight: 800;
    letter-spacing: 2px;
    z-index: 10;
}

.hud-category {
    display: flex;
    flex-direction: column;
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px dashed var(--color-border-gray-800);
    position: relative;
    z-index: 5;
}

.hud-category:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

@media (min-width: 768px) {
    .hud-category {
        flex-direction: row;
        align-items: flex-start;
    }
}

.hud-label-row {
    display: flex;
    align-items: center;
    min-width: 180px;
    margin-bottom: 0.5rem;
    gap: 8px;
}

@media (min-width: 768px) {
    .hud-label-row {
        margin-bottom: 0;
    }
}

.hud-label {
    color: var(--color-accent);
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 1px;
}

.hud-label::before {
    content: '~/bin/';
    opacity: 0.6;
    margin-right: 2px;
}

.hud-timestamp {
    font-size: 0.65rem;
    color: var(--color-text-gray-600);
    font-family: var(--font-mono);
    letter-spacing: 0.5px;
}

@media (max-width: 640px) {
    .hud-timestamp {
        display: none;
    }
}

.hud-tools {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 12px;
    color: var(--color-text-gray-400);
    font-size: 0.85rem;
    position: relative;
    z-index: 5;
}

.hud-tool-item {
    position: relative;
    transition: all 0.2s ease;
    cursor: crosshair;
    padding: 2px 6px;
    border-radius: 2px;
    background: transparent;
}

.hud-tool-item:hover {
    color: var(--color-text-white);
    text-shadow: 0 0 10px var(--color-accent), 0 0 20px var(--color-accent);
    background: rgba(255, 255, 255, 0.05);
    border-radius: 2px;
}

.hud-tool-item:not(:last-child)::after {
    content: ',';
    color: var(--color-text-gray-600);
    margin-left: 1px;
}

@keyframes hud-flicker {
    0%, 100% { opacity: 1; }
    50% { opacity: 1; }
}

.tools-hud-container {
    animation: hud-flicker 8s infinite;
}

.tools-hud-container:hover {
    animation: none;
}


/* =========================================
   GITHUB CONTRIBUTION GRAPH
   ========================================= */

.github-section {
    background: var(--color-card-bg);
    border: 1px solid var(--color-border-gray-800);
    border-radius: 1rem;
    padding: 2rem;
}

.github-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
}

.github-header h3 {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.25rem;
    color: var(--color-text-white);
}

.github-header i {
    color: var(--color-accent);
}

.github-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

@media (max-width: 640px) {
    .github-stats {
        grid-template-columns: repeat(2, 1fr);
    }
}

.github-stat {
    text-align: center;
    padding: 1rem;
    background: var(--color-bg);
    border-radius: 0.5rem;
}

.github-stat-value {
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--color-accent);
    font-family: var(--font-display), monospace;
}

.github-stat-label {
    font-size: 0.75rem;
    color: var(--color-text-gray-400);
    text-transform: uppercase;
}

.github-calendar {
    display: grid;
    grid-template-columns: repeat(52, 1fr);
    gap: 3px;
}

.github-week {
    display: flex;
    flex-direction: column;
    gap: 3px;
}


.github-day {
    width: 10px;
    height: 10px;
    border-radius: 2px;
    background: var(--color-border-gray-800);
    opacity: 0.6;
    /* Translucent effect */
    transition: opacity 0.3s;
}

.github-day:hover {
    opacity: 1;
}

.github-day.level-1 {
    background: rgba(255, 51, 51, 0.4);
}

.github-day.level-2 {
    background: rgba(255, 51, 51, 0.6);
}

.github-day.level-3 {
    background: rgba(255, 51, 51, 0.8);
}

.github-day.level-4 {
    background: var(--color-accent);
    opacity: 0.9;
}

.blue-team .github-day.level-1 {
    background: rgba(30, 58, 138, 0.3);
}

.blue-team .github-day.level-2 {
    background: rgba(30, 58, 138, 0.5);
}

.blue-team .github-day.level-3 {
    background: rgba(30, 58, 138, 0.7);
}

.blue-team .github-day.level-4 {
    background: var(--color-accent);
}

/* Blue Team Cyber Badge Styling */
.blue-team .cyber-badge-wrapper:hover .badge-glow {
    box-shadow: 0 10px 40px rgba(30, 58, 138, 0.2);
}

/* GitHub Calendar Container */
.github-calendar-container {
    overflow-x: auto;
    padding: 1rem 0;
}

.github-calendar-container img {
    min-width: 700px;
}

.blue-team .github-calendar-container img {
    filter: brightness(1.1) contrast(1.05);
}

/* Theme Toggle Button Styling */
#theme-toggle {
    border-color: var(--color-accent) !important;
    color: var(--color-accent) !important;
}

#theme-toggle:hover {
    background-color: var(--color-accent) !important;
    color: var(--color-text-black) !important;
}

/* Stats animation enhancement */
.stat-number {
    font-family: var(--font-display);
    font-weight: 700;
    transition: color 0.3s ease;
}

.stat-number:hover {
    color: var(--color-accent);
    text-shadow: 0 0 20px rgba(0, 255, 65, 0.5);
}

/* =========================================
   BLOG CARDS SECTION
   ========================================= */

.blog-card {
    background: var(--color-card-bg);
    border: 1px solid var(--color-border-gray-800);
    border-radius: 1rem;
    padding: 1.5rem;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.blog-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-accent), var(--color-accent-secondary));
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.blog-card:hover {
    border-color: var(--color-accent);
    transform: translateY(-5px);
    box-shadow: 0 10px 40px rgba(0, 255, 65, 0.15);
}

.blog-card:hover::before {
    transform: scaleX(1);
}

.blog-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.blog-tag {
    background: var(--color-bg);
    color: var(--color-accent);
    padding: 0.25rem 0.75rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.blog-date {
    color: var(--color-text-gray-400);
    font-size: 0.75rem;
    font-family: var(--font-display), monospace;
}

.blog-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text-white);
    margin-bottom: 0.75rem;
    line-height: 1.4;
    transition: color 0.3s;
}

.blog-card:hover .blog-title {
    color: var(--color-accent);
}

.blog-excerpt {
    color: var(--color-text-gray-400);
    font-size: 0.875rem;
    line-height: 1.6;
    margin-bottom: 1.5rem;
    flex-grow: 1;
}

.blog-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border-gray-800);
}

.blog-read-time {
    color: var(--color-text-gray-500);
    font-size: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.blog-link {
    color: var(--color-accent);
    font-size: 0.875rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    transition: gap 0.3s;
}

.blog-link:hover {
    gap: 0.75rem;
}

/* =========================================
   CONTACT FORM SECTION
   ========================================= */

.contact-form {
    background: var(--color-card-bg);
    border: 1px solid var(--color-border-gray-800);
    border-radius: 1rem;
    padding: 2rem;
}

.form-group {
    margin-bottom: 1.5rem;
}

.form-label {
    display: block;
    color: var(--color-text-white);
    font-weight: 600;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
}

.form-input {
    width: 100%;
    background: var(--color-bg);
    border: 1px solid var(--color-border-gray-800);
    border-radius: 0.5rem;
    padding: 0.75rem 1rem;
    color: var(--color-text-white);
    font-family: var(--font-display), monospace;
    font-size: 0.875rem;
    transition: all 0.3s;
}

.form-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(0, 255, 65, 0.1);
}

.form-input::placeholder {
    color: var(--color-text-gray-500);
}

textarea.form-input {
    resize: vertical;
    min-height: 120px;
}

.btn-submit {
    width: 100%;
    background: var(--color-accent);
    color: var(--color-text-black);
    font-weight: 700;
    padding: 1rem;
    border-radius: 0.5rem;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    transition: all 0.3s;
    font-size: 1rem;
}

.btn-submit:hover {
    background: var(--color-accent-secondary);
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(0, 255, 65, 0.3);
}

.btn-submit:active {
    transform: translateY(0);
}

.contact-info-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--color-bg);
    border: 1px solid var(--color-border-gray-800);
    border-radius: 0.75rem;
    transition: all 0.3s;
    width: 100%;
    box-sizing: border-box;
}

.contact-info-card:hover {
    border-color: var(--color-accent);
    transform: translateX(5px);
    box-shadow: 0 5px 20px rgba(0, 255, 65, 0.1);
}

.contact-icon {
    width: 50px;
    height: 50px;
    min-width: 50px;
    background: var(--color-accent);
    color: var(--color-text-black);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    transition: all 0.3s;
}

.contact-info-card:hover .contact-icon {
    transform: scale(1.1) rotate(5deg);
}

/* Contact section mobile fixes */
@media (max-width: 768px) {
    .contact-info-card {
        padding: 1rem;
    }

    .contact-icon {
        width: 44px;
        height: 44px;
        min-width: 44px;
        font-size: 1.1rem;
    }

    .contact-info-card h4 {
        font-size: 0.95rem;
    }

    .contact-info-card p {
        font-size: 0.75rem;
        word-break: break-all;
    }
}

/* Blue Team Overrides */
.light-theme .blog-card:hover {
    box-shadow: 0 10px 40px rgba(30, 58, 138, 0.2);
}

.light-theme .form-input:focus {
    box-shadow: 0 0 0 3px rgba(30, 58, 138, 0.1);
}

.light-theme .btn-submit:hover {
    box-shadow: 0 10px 30px rgba(30, 58, 138, 0.3);
}

.light-theme .contact-info-card:hover {
    box-shadow: 0 5px 20px rgba(30, 58, 138, 0.1);
}

/* Experience Timeline Styles */
.experience-timeline {
    position: relative;
    max-width: 800px;
    margin: 0 auto;
}

.experience-timeline::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 2px;
    background: linear-gradient(to bottom, var(--color-accent), transparent);
}

.experience-item {
    position: relative;
    padding-left: 40px;
    margin-bottom: 40px;
}

.experience-dot {
    position: absolute;
    left: -6px;
    top: 5px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--color-accent);
    border: 3px solid var(--color-bg);
    box-shadow: 0 0 10px var(--color-accent);
}

.experience-content {
    background: var(--color-card-bg);
    border: 1px solid var(--color-border-gray-800);
    border-radius: 8px;
    padding: 24px;
    transition: all 0.3s ease;
}

.experience-content:hover {
    border-color: var(--color-accent);
    transform: translateX(5px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.experience-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 8px;
}

.experience-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text-white);
}

.experience-date {
    font-size: 0.875rem;
    color: var(--color-accent);
    font-family: var(--font-display), monospace;
}

.experience-company {
    color: var(--color-text-gray-400);
    font-size: 0.95rem;
    margin-bottom: 16px;
}

.experience-list {
    list-style: none;
    padding: 0;
    margin: 0 0 16px 0;
}

.experience-list li {
    position: relative;
    padding-left: 20px;
    margin-bottom: 8px;
    color: var(--color-text-gray-300);
    font-size: 0.9rem;
}

.experience-list li::before {
    content: '▸';
    position: absolute;
    left: 0;
    color: var(--color-accent);
}

.experience-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.experience-tags span {
    padding: 4px 12px;
    background: rgba(0, 255, 65, 0.1);
    border: 1px solid rgba(0, 255, 65, 0.3);
    border-radius: 20px;
    font-size: 0.75rem;
    color: var(--color-accent);
}

.light-theme .experience-tags span {
    background: rgba(30, 58, 138, 0.1);
    border-color: rgba(30, 58, 138, 0.3);
}

/* Mobile responsive */
@media (max-width: 768px) {
    .experience-timeline::before {
        left: 5px;
    }

    .experience-item {
        padding-left: 30px;
    }

    .experience-dot {
        left: -1px;
    }

    .experience-header {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* Navbar Logo - Force sizing and crisp rendering */
#nav-logo {
    width: 40px !important;
    height: 40px !important;
    max-width: 40px !important;
    max-height: 40px !important;
    object-fit: contain !important;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

/* Flip Card adjustments for 140px height */
.flip-card {
    min-height: 140px;
}

.flip-card-inner {
    min-height: 140px;
}

.flip-card-front,
.flip-card-back {
    min-height: 140px;
}

/* Light theme adjustments for certification logos */
.light-theme .flip-card-front img,
.light-theme .flip-card-back img {
    filter: none;
}

/* Secondary Button (Outline) */
.btn-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 2rem;
    font-family: var(--font-display), monospace;
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--color-white);
    background: transparent;
    border: 1px solid var(--color-border);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    text-transform: uppercase;
    letter-spacing: 1px;
    height: 56px;
    /* Match massive button height */
    text-decoration: none;
}

.btn-secondary:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
    box-shadow: 0 0 15px rgba(0, 255, 65, 0.2);
    transform: translateY(-2px);
    text-decoration: none;
}

/* Glowing Text Effect - Red (Aggressive) */
.glowing-text {
    /* Fallback color */
    color: #ef4444;
    /* Red Gradient */
    background: linear-gradient(90deg, #ff0000, #ff4d4d, #ff0000);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 0 10px rgba(255, 0, 0, 0.5);
    animation: glow-red 3s linear infinite;
    font-weight: bold;
    /* Make it pop */
}

@keyframes glow-red {
    0% {
        background-position: 0% 50%;
        text-shadow: 0 0 10px rgba(255, 0, 0, 0.5);
    }

    50% {
        background-position: 100% 50%;
        text-shadow: 0 0 20px rgba(255, 0, 0, 0.8), 0 0 30px rgba(255, 0, 0, 0.4);
    }

    100% {
        background-position: 0% 50%;
        text-shadow: 0 0 10px rgba(255, 0, 0, 0.5);
    }
}

/* Glowing Text Effect - Blue (Optimistic/Cool) */
.blue-team .glowing-text {
    color: #3b82f6;
    background: linear-gradient(90deg, #60a5fa, #3b82f6, #2563eb);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 0 10px rgba(59, 130, 246, 0.5);
    animation: glow-blue 3s linear infinite;
}

@keyframes glow-blue {
    0% {
        background-position: 0% 50%;
        text-shadow: 0 0 10px rgba(59, 130, 246, 0.5);
    }

    50% {
        background-position: 100% 50%;
        text-shadow: 0 0 20px rgba(59, 130, 246, 0.8), 0 0 30px rgba(59, 130, 246, 0.4);
    }

    100% {
        background-position: 0% 50%;
        text-shadow: 0 0 10px rgba(59, 130, 246, 0.5);
    }
}

/* =========================================
   COMPREHENSIVE MOBILE RESPONSIVE STYLES
   ========================================= */

/* Navbar Logo adjustments for different screen sizes */
@media (max-width: 1023px) {
    #nav-logo {
        width: 40px !important;
        height: 40px !important;
        max-width: 40px !important;
        max-height: 40px !important;
    }

    #navbar .container {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

/* Brutalist Navbar Enhancement */
/* Only apply to nav elements WITHOUT .floating-navbar */
nav.fixed:not(.floating-navbar) {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
    background: var(--color-nav-bg);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--color-border-gray-800);
}

nav.fixed::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
    opacity: 0.3;
}

/* Mobile Portrait (up to 480px) */
@media (max-width: 480px) {
    #navbar .container {
        padding: 0.5rem 0.75rem;
    }

    #nav-logo {
        width: 32px !important;
        height: 32px !important;
        max-width: 32px !important;
        max-height: 32px !important;
    }

    #navbar a span {
        font-size: 0.9rem;
    }

    .hero-headline {
        font-size: 1.75rem !important;
        line-height: 1.2;
    }

    .hero-sub {
        font-size: 0.95rem;
    }

    .btn-massive {
        padding: 12px 24px;
        font-size: 0.875rem;
    }

    .btn-secondary {
        padding: 10px 20px;
        font-size: 0.75rem;
        height: auto;
    }

    /* Contact section mobile fixes */
    #contact .grid {
        gap: 1.5rem;
    }

    .contact-form {
        padding: 1.25rem;
    }

    .contact-info-card {
        padding: 0.875rem;
    }

    .contact-icon {
        width: 40px;
        height: 40px;
        min-width: 40px;
        font-size: 1rem;
    }

    /* Terminal adjustments */
    .terminal-body {
        height: 300px;
        font-size: 12px;
    }

    .terminal-input {
        font-size: 12px;
        width: calc(100% - 150px);
    }

    /* Blog cards */
    .blog-title {
        font-size: 1rem;
    }

    .blog-excerpt {
        font-size: 0.8rem;
    }

    /* Skills section */
    .skill-card {
        padding: 1rem;
    }

    .skill-progress-ring {
        width: 60px;
        height: 60px;
    }

    .skill-title {
        font-size: 0.875rem;
    }

    .skill-desc {
        font-size: 0.7rem;
    }

    /* Stats section */
    .stat-number {
        font-size: 1.75rem !important;
    }

    /* Experience section */
    .experience-title {
        font-size: 1rem;
    }

    .experience-list li {
        font-size: 0.8rem;
    }
}

/* Mobile Landscape (height constraint) */
@media (max-height: 500px) and (orientation: landscape) {
    #mobile-menu {
        min-height: auto;
        max-height: calc(100vh - 64px);
        overflow-y: auto;
    }

    #mobile-menu a {
        padding: 0.5rem 0;
        font-size: 0.9rem;
    }

    #mobile-menu .mobile-controls {
        margin-top: 0.75rem;
        padding-top: 0.75rem;
    }

    .hero-minimal {
        min-height: auto;
        padding-top: 80px;
        padding-bottom: 40px;
    }
}

/* Tablet adjustments (768px - 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
    .hero-headline {
        font-size: 2.5rem;
    }

    .hero-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .profile-clean {
        max-width: 280px;
        margin: 0 auto;
    }

    /* Contact section grid */
    #contact .grid {
        grid-template-columns: 1fr !important;
    }
}

/* Fix for very small screens */
@media (max-width: 320px) {
    .hero-headline {
        font-size: 1.5rem !important;
    }

    .min-badge {
        font-size: 0.7rem;
        padding: 4px 10px;
    }

    .btn-massive,
    .btn-secondary {
        width: 100%;
        text-align: center;
        margin-bottom: 0.5rem;
    }

    .flex-col.sm\\:flex-row {
        flex-direction: column !important;
    }

    .contact-info-card h4 {
        font-size: 0.85rem;
    }

    .contact-info-card p {
        font-size: 0.7rem;
    }
}

/* Ensure full-width on mobile for grids */
@media (max-width: 768px) {

    .grid.md\\:grid-cols-2,
    .grid.md\\:grid-cols-4 {
        grid-template-columns: 1fr !important;
    }

    /* Fix stats grid to 2 columns on mobile */
    .grid.grid-cols-2.md\\:grid-cols-4 {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    /* Fix dividers on stats */
    .divide-x> :not([hidden])~ :not([hidden]) {
        border-left-width: 0 !important;
    }

    /* Add top border instead for second row */
    .grid.grid-cols-2> :nth-child(n+3) {
        border-top: 1px solid var(--color-border-gray-800);
        padding-top: 1rem;
        margin-top: 0.5rem;
    }

    /* Hero stats row mobile */
    .hero-stats-row {
        flex-wrap: wrap;
        gap: 1.5rem;
    }

    #blog .flex-wrap a {
        width: 100%;
        text-align: center;
    }

    /* Projects horizontal scroll on mobile */
    #projects-grid {
        display: flex !important;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        gap: 1.25rem;
        padding-bottom: 1.5rem;
        padding-left: 0.5rem;
        padding-right: 0.5rem;
        scrollbar-width: none;
        /* Firefox */
    }

    #projects-grid::-webkit-scrollbar {
        display: none;
        /* Chrome/Safari */
    }

    #projects-grid>.project-item {
        flex: 0 0 85%;
        scroll-snap-align: start;
        min-width: 280px;
    }
}

/* ==========================================================================
   Project Modals (Native <dialog>)
   ========================================================================== */
.cyber-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-width: 600px;
    background: rgba(10, 15, 20, 0.85);
    border: 1px solid var(--color-border-gray-800);
    border-radius: 8px;
    padding: 2rem;
    color: var(--color-text-main);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 0 30px rgba(0, 255, 65, 0.15);
    z-index: 1000;
}

.cyber-modal::backdrop {
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
}

.cyber-modal .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--color-border-gray-800);
    padding-bottom: 1rem;
}

.cyber-modal .modal-close {
    background: transparent;
    border: none;
    color: var(--color-text-muted);
    font-size: 2rem;
    line-height: 1;
    cursor: pointer;
    transition: color 0.3s ease;
}

.cyber-modal .modal-close:hover {
    color: var(--color-accent);
}

.cyber-modal .btn-massive {
    padding: 1rem;
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 2px;
}

/* =========================================
   CYBER DATACARDS (WITH LOGOS & SCANNER)
   ========================================= */
/* Force sleek horizontal layout */
.cyber-datacard {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    padding: 0.6rem 1rem !important;
    margin-bottom: 0.8rem !important;
    min-height: 70px;
    position: relative;
    overflow: hidden;
}

/* Dynamic Badge via data attribute */
.cyber-datacard::before {
    content: attr(data-badge) !important;
    position: absolute;
    top: 0;
    right: 0;
    border-bottom-left-radius: 6px;
    font-size: 0.6rem !important;
    padding: 3px 8px !important;
    font-family: var(--font-display), monospace;
    font-weight: 800;
    letter-spacing: 1px;
    z-index: 3;
}

/* Specific Badge Colors */
.badge-verified::before {
    background: rgba(0, 255, 204, 0.1);
    color: #00ffcc;
}
.badge-request::before {
    background: rgba(255, 170, 0, 0.1);
    color: #ffaa00;
}

/* Wrapper that supports 1 or 2 logos */
.datacard-icon-wrapper {
    width: auto !important;
    min-width: 45px;
    height: 45px !important;
    margin-right: 1rem !important;
    padding: 4px !important;
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    flex-shrink: 0 !important;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    z-index: 2;
}

.datacard-icon {
    max-width: 40px;
    max-height: 100%;
    object-fit: contain;
    filter: grayscale(40%);
    transition: all 0.3s ease;
}

/* Compact Typography */
.datacard-info {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: left;
    z-index: 2;
}

.datacard-info h3 {
    font-size: 0.95rem !important;
    margin-bottom: 0.1rem !important;
    color: var(--color-text-white);
    font-family: var(--font-display), monospace;
}

.datacard-info p {
    font-size: 0.8rem !important;
    margin: 0 !important;
    color: var(--color-text-gray-400);
}

/* Scanner Effect */
.cyber-datacard::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 50%;
    height: 100%;
    background: linear-gradient(to right, transparent, rgba(255, 0, 60, 0.1), transparent);
    transform: skewX(-20deg);
    z-index: 1;
}

.cyber-datacard:hover {
    border-left-color: var(--color-accent);
    transform: translateX(5px);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.6);
    background: rgba(20, 20, 20, 0.9);
}

.cyber-datacard:hover::after {
    animation: cyber-scan 1.2s infinite;
}

@keyframes cyber-scan {
    0% { left: -100%; }
    100% { left: 200%; }
}

.cyber-datacard:hover .datacard-icon {
    filter: grayscale(0%) drop-shadow(0 0 8px rgba(255, 255, 255, 0.2));
    transform: scale(1.05);
}

/* Anchor tag as datacard */
a.cyber-datacard {
    text-decoration: none;
    color: inherit;
    display: block;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .cyber-datacard {
        padding: 0.6rem !important;
        min-height: 65px !important;
    }
    .datacard-icon-wrapper {
        min-width: 40px !important;
        height: 40px !important;
        margin-right: 0.8rem !important;
    }
    .datacard-info h3 {
        font-size: 0.8rem !important;
    }
    .datacard-info p {
        font-size: 0.65rem !important;
    }
    .cyber-datacard::before {
        font-size: 0.5rem !important;
        padding: 2px 5px !important;
        top: 0 !important;
        right: 0 !important;
    }
}

/* =========================================
   CYBER BUTTONS
   ========================================= */
.cyber-btn {
    display: inline-block;
    padding: 0.8rem 1.5rem;
    font-family: var(--font-display), monospace;
    font-size: 0.9rem;
    font-weight: bold;
    letter-spacing: 1px;
    text-transform: uppercase;
    transition: all 0.3s ease;
    cursor: pointer;
    position: relative;
    text-decoration: none;
}

.cyber-btn.primary {
    background: transparent;
    color: var(--color-accent);
    border: 1px solid var(--color-accent);
    box-shadow: 0 0 10px rgba(255, 0, 60, 0.2), inset 0 0 10px rgba(255, 0, 60, 0.1);
}

.cyber-btn.primary:hover {
    background: var(--color-accent);
    color: #000;
    box-shadow: 0 0 20px var(--color-accent);
}

.cyber-btn.secondary {
    background: transparent;
    color: var(--color-text-gray-400);
    border: 1px solid var(--color-border-gray-800);
}

.cyber-btn.secondary:hover {
    color: #fff;
    border-color: #fff;
    background: rgba(255, 255, 255, 0.05);
}

/* =========================================
   MOBILE ACCORDION - ENCRYPTED LOGS
   ========================================= */
/* DESKTOP: Always open, no toggle button */
@media (min-width: 769px) {
    .exp-toggle { display: none; }
    .exp-content { display: block !important; }
    .exp-header { cursor: default; }
}

/* MOBILE: Collapsed by default, show toggle button */
@media (max-width: 768px) {
    .exp-header {
        cursor: pointer;
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        gap: 10px;
    }
    .exp-content {
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.4s ease-out, opacity 0.4s ease-out;
        opacity: 0;
    }
    .experience-card.is-open .exp-content {
        max-height: 1000px;
        opacity: 1;
        margin-top: 1rem;
    }
    .experience-card.is-open .exp-toggle {
        transform: rotate(180deg);
        color: #00ffcc;
    }
}

/* =========================================
   MOBILE HORIZONTAL SCROLL - WRITEUPS
   ========================================= */
@media (max-width: 768px) {
    .writeups-container {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        scroll-snap-type: x mandatory !important;
        gap: 1.5rem !important;
        padding-bottom: 1.5rem !important;
        -ms-overflow-style: none;
        scrollbar-width: none;
    }
    .writeups-container::-webkit-scrollbar {
        display: none;
    }
    .writeups-container > div, .writeup-card, .blog-card {
        flex: 0 0 85% !important;
        max-width: 85% !important;
        scroll-snap-align: center !important;
        min-width: 280px;
    }
}

/* === minimal.css === */
/* =========================================
   HERO / MINIMAL SPLIT THEME
   Clean, Direct, High Impact
   ========================================= */

/* Hero Container - Split Layout */
.hero-minimal {
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    padding-top: 80px;
    /* Accounts for fixed header */
    background: transparent;
}

.hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

/* Typography - Massive & Bold */
.hero-headline {
    font-size: 4.5rem;
    line-height: 1.1;
    font-weight: 800;
    margin-bottom: 1.5rem;
    letter-spacing: -0.02em;
}

.hero-headline .highlight {
    color: var(--color-accent);
}

.hero-sub {
    font-size: 1.25rem;
    color: var(--color-text-gray-400);
    margin-bottom: 2rem;
    line-height: 1.6;
    max-width: 90%;
}

/* Minimal Badge */
.min-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 16px;
    background: rgba(var(--color-accent), 0.1);
    /* fallback if variable acts up */
    background: color-mix(in srgb, var(--color-accent), transparent 90%);
    border: 1px solid var(--color-accent);
    border-radius: 4px;
    color: var(--color-accent);
    font-family: 'Fira Code', monospace;
    font-size: 0.85rem;
    margin-bottom: 2rem;
    font-weight: 600;
}

.min-dot {
    width: 8px;
    height: 8px;
    background: var(--color-accent);
    border-radius: 50%;
    animation: pulse 2s infinite;
}

/* Integrated Stats Row */
.hero-stats-row {
    display: flex;
    gap: 3rem;
    margin-bottom: 2.5rem;
    border-left: 4px solid var(--color-accent);
    padding-left: 2rem;
}

.hero-stat-item strong {
    display: block;
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-text-white);
    line-height: 1;
    margin-bottom: 0.25rem;
}

.hero-stat-item span {
    font-size: 0.85rem;
    color: var(--color-text-gray-500);
    text-transform: uppercase;
    letter-spacing: 1px;
    font-family: 'Fira Code', monospace;
}

.light-theme .hero-stat-item strong {
    color: var(--color-text-black);
}

/* Massive CTA */
.btn-massive {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 18px 48px;
    background: var(--color-accent);
    color: #000;
    font-size: 1.1rem;
    font-weight: 800;
    border-radius: 0;
    /* Boxy look */
    transition: transform 0.2s, box-shadow 0.2s;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: none;
}

.btn-massive:hover {
    transform: translateY(-4px);
    box-shadow: 12px 12px 0 rgba(255, 255, 255, 0.1);
}

.light-theme .btn-massive:hover {
    box-shadow: 12px 12px 0 rgba(0, 0, 0, 0.1);
}

/* Right Column - Profile Image */
.hero-image-wrapper {
    position: relative;
    z-index: 10;
}

/* Background Abstract Shape */
.bg-shape {
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    width: 40%;
    background: rgba(17, 17, 17, 0.5);
    z-index: 0;
    clip-path: polygon(20% 0, 100% 0, 100% 100%, 0% 100%);
}

/* Responsive Adjustments */
@media (max-width: 1024px) {
    .hero-headline {
        font-size: 3.5rem;
    }

    .hero-grid {
        gap: 2rem;
    }
}

@media (max-width: 768px) {
    .hero-grid {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .hero-stats-row {
        justify-content: center;
        border-left: none;
        border-top: 4px solid var(--color-accent);
        padding-left: 0;
        padding-top: 1.5rem;
    }

    .bg-shape {
        width: 100%;
        height: 30%;
        top: auto;
        bottom: 0;
        clip-path: none;
    }

    .hero-headline {
        font-size: 2.5rem;
    }


}

/* =========================================
   CSUME V3 PROJECT SECTION PORT
   Exact replication of the grid and hover effects
   ========================================= */

.d2c_project_wrapper {
    padding: 80px 0;
}

.d2c_img_wrapper {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: 4px;
}

/* Image Dimensions matching aspect ratios */
.d2c_large_img {
    height: 700px;
}

.d2c_small_img {
    height: 338px;
}

@media (max-width: 991px) {

    .d2c_large_img,
    .d2c_small_img {
        height: 400px;
    }
}

/* Image Fit */
.d2c_img_wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Overlay - Initially Visible (Darken) */
.d2c_overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(13, 17, 26, 0.80) 0%, rgba(13, 17, 26, 0.20) 100%);
    opacity: 1;
    transition: 0.4s all;
}

/* The Card Content - Initially Hidden */
.d2c_card_reveal {
    width: 100%;
    height: 100%;
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: 0.4s all;
    /* Card Styles from csume */
    padding: 1px;
    background: linear-gradient(180deg, rgba(94, 106, 210, 0.5) 0%, rgba(19, 23, 34, 0) 90%);
}

.d2c_card_child {
    height: 100%;
    padding: 10px;
    background: radial-gradient(100% 100% at 50% 0%, rgba(120, 119, 198, 0.17) 0%, rgba(13, 17, 26, 0) 100%), #131722;
}

.d2c_card_child_two {
    height: 100%;
    padding: 1px;
    background: radial-gradient(100% 100% at 50% 0%, rgba(120, 119, 198, 0.17) 0%, rgba(13, 17, 26, 0) 100%), #131722;
}

.d2c_card_child_three {
    height: 100%;
    padding: 25px;
    background: radial-gradient(100% 100% at 50% 0%, rgba(120, 119, 198, 0.17) 0%, rgba(13, 17, 26, 0) 100%), #131722;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* Hover Effects */
.d2c_img_wrapper:hover .d2c_overlay {
    opacity: 0;
}

.d2c_img_wrapper:hover .d2c_card_reveal {
    opacity: 1;
}

/* Typography map to csume */
.d2c_project_title {
    color: #fff;
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 16px;
    text-transform: capitalize;
}

.d2c_project_desc {
    color: #EAFBF2;
    font-size: 16px;
    font-weight: 400;
    margin-bottom: 26px;
    line-height: 1.5;
}

.d2c_sub_title {
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 10px;
}

.d2c_list_item {
    color: #EAFBF2;
    padding: 5px 0;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.d2c_list_icon {
    color: #fff;
    font-size: 10px;
}

/* =========================================
   HERO ENHANCEMENTS: TARGETING UI & GLITCH
   ========================================= */

.target-ui-container {
    position: relative;
    display: inline-block;
    padding: 2.5rem;
}

.target-ring {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    border: 1px dashed var(--color-text-gray-600);
    pointer-events: none;
    opacity: 0.4;
}

.target-ring-1 {
    animation: rotate-ring 25s linear infinite;
    border-top-color: var(--color-accent);
}

.target-ring-2 {
    margin: 1.5rem;
    animation: rotate-ring-reverse 18s linear infinite;
    border-bottom-color: var(--color-accent);
    border-style: dotted;
}

.target-crosshair::before,
.target-crosshair::after {
    content: '';
    position: absolute;
    background: var(--color-accent);
    opacity: 0.3;
    pointer-events: none;
}

.target-crosshair::before {
    top: 50%;
    left: 0;
    right: 0;
    height: 1px;
    transform: translateY(-50%);
}

.target-crosshair::after {
    left: 50%;
    top: 0;
    bottom: 0;
    width: 1px;
    transform: translateX(-50%);
}

.profile-clean.profile-glitch {
    position: relative;
    border-radius: 50%;
    /* Ensuring it matches rings */
    z-index: 2;
    transition: filter 0.3s;
    background: var(--color-bg);
}

.target-ui-container:hover .profile-clean.profile-glitch {
    animation: img-glitch 0.3s cubic-bezier(.25, .46, .45, .94) both infinite;
    filter: drop-shadow(0 0 15px var(--color-accent));
}

@keyframes rotate-ring {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

@keyframes rotate-ring-reverse {
    0% {
        transform: rotate(360deg);
    }

    100% {
        transform: rotate(0deg);
    }
}

@keyframes img-glitch {
    0% {
        transform: translate(0)
    }

    20% {
        transform: translate(-2px, 2px)
    }

    40% {
        transform: translate(-2px, -2px)
    }

    60% {
        transform: translate(2px, 2px)
    }

    80% {
        transform: translate(2px, -2px)
    }

    100% {
        transform: translate(0)
    }
}

/* =========================================
   PROJECT FILTERS & SKILLS BARS
   ========================================= */

.filter-btn {
    background: transparent;
    border: 1px solid var(--color-border-gray-800);
    color: var(--color-text-gray-400);
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-family: var(--font-display);
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.3s ease;
}

.filter-btn:hover {
    border-color: var(--color-text-gray-600);
    color: var(--color-text-white);
}

.filter-btn.active {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #000;
    font-weight: bold;
}

.light-theme .filter-btn.active {
    color: #fff;
}

/* Skills Bars */
.skill-bar-container {
    width: 100%;
    height: 6px;
    background: var(--color-border-gray-900);
    border-radius: 3px;
    margin-top: 1rem;
    overflow: hidden;
    position: relative;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.5);
}

.skill-progress {
    height: 100%;
    width: 0;
    /* Starts at 0 for animation */
    background: var(--color-accent);
    border-radius: 3px;
    transition: width 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
}

/* Add a subtle glow/shine to the progress bar */
.skill-progress::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
    animation: shine 2s linear infinite;
}

@keyframes shine {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(100%);
    }
}

.cyber-frame-glass {
    position: relative;
    padding: 1rem;
    border-radius: 12px;
    background: rgba(10, 10, 10, 0.4);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    z-index: 2;
}

.light-theme .cyber-frame-glass,
.blue-team .cyber-frame-glass {
    background: rgba(255, 255, 255, 0.05);
}

.cyber-frame-glass:before {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 10%;
    right: 10%;
    height: 3px;
    background: var(--color-accent);
    border-radius: 3px 3px 0 0;
    opacity: 0;
    transition: opacity 0.3s, transform 0.3s;
    transform: translateY(5px);
}

.cyber-frame-glass:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4), 0 0 20px var(--color-terminal-shadow);
    border-color: rgba(var(--color-accent), 0.3);
}

.cyber-frame-glass:hover:before {
    opacity: 1;
    transform: translateY(0);
}

.cyber-frame-glass .profile-clean {
    border-radius: 8px;
    /* Slightly less than the frame */
    display: block;
    width: 100%;
    height: auto;
}

/* =========================================
   FLOATING NAVBAR & HERO SIDEBARS
   ========================================= */

.floating-navbar {
    border-radius: 40px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), 0 0 15px rgba(var(--color-terminal-shadow), 0.2);
    transition: all 0.3s ease;
}

.floating-navbar::after {
    content: '';
    position: absolute;
    bottom: 0px;
    left: 10%;
    right: 10%;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
    opacity: 0.6;
}

@keyframes pulse-glow {

    0%,
    100% {
        opacity: 0.4;
        box-shadow: 0 0 5px var(--color-accent);
    }

    50% {
        opacity: 1;
        box-shadow: 0 0 15px var(--color-accent);
    }
}

/* Left Sidebar: Socials */
.vertical-social-bar {
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
    z-index: 10;
    opacity: 0.7;
    transition: opacity 0.3s, transform 0.3s;
    background: rgba(10, 10, 10, 0.45);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 20px;
    padding: 10px 5px;
}

.vertical-social-bar:hover {
    opacity: 1;
}

.social-line {
    width: 1px;
    height: 60px;
    background: linear-gradient(to bottom, transparent, var(--color-accent), transparent);
}

.vertical-social-bar a {
    color: var(--color-text-gray-400);
    font-size: 1.25rem;
    transition: all 0.3s;
}

.vertical-social-bar a:hover {
    color: var(--color-accent);
    transform: scale(1.2) translateX(3px);
}

/* Right Sidebar: Threat Feed */
.vertical-threat-feed {
    position: absolute;
    right: 20px;
    top: 30%;
    height: 400px;
    width: 250px;
    overflow: hidden;
    z-index: 10;
    opacity: 0.2;
    direction: ltr;
    /* Always LTR for logs */
    pointer-events: none;
    mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);
    -webkit-mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);
    background: rgba(10, 10, 10, 0.45);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 8px;
}

.threat-marquee {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-family: var(--font-mono);
    font-size: 0.65rem;
    color: var(--color-accent);
    animation: scroll-feed 20s linear infinite;
    will-change: transform;
}

.threat-marquee span {
    white-space: nowrap;
    text-align: right;
}

@keyframes scroll-feed {
    0% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(-50%);
    }

    /* Scrolls exactly half to loop */
}

/* =========================================
   PHASE 3: SITE POLISH & ENHANCEMENTS
   ========================================= */

/* Micro-Progress Scrollbar */
#scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--color-accent);
    z-index: 9999;
    transform-origin: left;
    transform: scaleX(0);
    will-change: transform;
    box-shadow: 0 0 10px var(--color-accent);
}

/* Smart Scroll Hide Navbar */
.nav-hidden {
    transform: translate(-50%, -150%) !important;
}

/* Scroll-Spy Active Link */
.nav-link.active-link {
    color: var(--color-accent) !important;
    font-weight: bold;
    text-shadow: 0 0 10px rgba(0, 255, 65, 0.4);
}

/* Cyber-Matrix Mobile Menu Overlay */
#mobile-menu {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s ease;
    background: rgba(0, 0, 0, 0.95);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
}

#mobile-menu.matrix-open {
    opacity: 1;
    pointer-events: auto;
}

/* Staggered Glitch Slide-in Links */
#mobile-menu .menu-item {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

#mobile-menu.matrix-open .menu-item:nth-child(1) {
    transition-delay: 0.1s;
    opacity: 1;
    transform: translateY(0);
}

#mobile-menu.matrix-open .menu-item:nth-child(2) {
    transition-delay: 0.2s;
    opacity: 1;
    transform: translateY(0);
}

#mobile-menu.matrix-open .menu-item:nth-child(3) {
    transition-delay: 0.3s;
    opacity: 1;
    transform: translateY(0);
}

#mobile-menu.matrix-open .menu-item:nth-child(4) {
    transition-delay: 0.4s;
    opacity: 1;
    transform: translateY(0);
}

#mobile-menu.matrix-open .menu-item:nth-child(5) {
    transition-delay: 0.5s;
    opacity: 1;
    transform: translateY(0);
}

#mobile-menu.matrix-open .menu-item:nth-child(6) {
    transition-delay: 0.6s;
    opacity: 1;
    transform: translateY(0);
}

#mobile-menu.matrix-open .menu-controls {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

#mobile-menu.matrix-open .menu-controls {
    transition-delay: 0.7s;
    opacity: 1;
    transform: translateY(0);
}

/* Arabic (RTL) Special Polish */
html[lang="ar"] body {
    line-height: 1.8;
    letter-spacing: 0.3px;
}

html[lang="ar"] .vertical-social-bar {
    left: auto;
    right: 20px;
}

html[lang="ar"] .vertical-threat-feed {
    right: auto;
    left: 20px;
    direction: ltr;
    /* Ensure logs always display LTR */
}

/* Fix terminal input outlines jumping around */
.terminal-input:focus {
    outline: none !important;
    box-shadow: none !important;
    border: none !important;
}

.terminal-input {
    caret-color: var(--color-accent);
}

/* Hardware accelerated translation on project cards instead of VanillaTilt */
.project-item {
    will-change: transform;
}

/* Ambient Spotlight */
.ambient-spotlight {
    position: absolute;
    top: 0;
    left: 0;
    width: 800px;
    height: 800px;
    background: radial-gradient(circle, var(--color-terminal-shadow) 0%, transparent 60%);
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
    transform: translate(-50%, -50%);
    will-change: transform;
    opacity: 0;
    transition: opacity 0.5s ease;
}

.ambient-spotlight.active {
    opacity: 1;
}

/* === output.css === */
*,: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,.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,.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.19 | MIT License | https://tailwindcss.com*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}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-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{color:inherit;font-family:inherit;font-feature-settings:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height: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{color:#9ca3af;opacity:1}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.-bottom-6{bottom:-1.5rem}.-left-6{left:-1.5rem}.left-0{left:0}.top-0{top:0}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.order-first{order:-9999}.order-last{order:9999}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-bottom:.5rem;margin-top:.5rem}.-mt-32{margin-top:-8rem}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-3{margin-left:.75rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-2{height:.5rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-\[18px\]{height:18px}.h-full{height:100%}.h-px{height:1px}.w-2{width:.5rem}.w-20{width:5rem}.w-48{width:12rem}.w-64{width:16rem}.w-8{width:2rem}.w-\[8px\]{width:8px}.w-full{width:100%}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.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))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-row{flex-direction:row}.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}.justify-around{justify-content:space-around}.gap-10{gap:2.5rem}.gap-12{gap:3rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1.5rem*var(--tw-space-x-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-gray-700{--tw-border-opacity:1;border-color:rgb(55 65 81/var(--tw-border-opacity,1))}.border-gray-700\/50{border-color:rgba(55,65,81,.5)}.border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity,1))}.border-gray-800\/50{border-color:rgba(31,41,55,.5)}.border-gray-900{--tw-border-opacity:1;border-color:rgb(17 24 39/var(--tw-border-opacity,1))}.border-white\/10{border-color:hsla(0,0%,100%,.1)}.bg-\[\#0a0a0a\]\/60{background-color:hsla(0,0%,4%,.6)}.bg-\[\#111\]{--tw-bg-opacity:1;background-color:rgb(17 17 17/var(--tw-bg-opacity,1))}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-gray-800\/20{background-color:rgba(31,41,55,.2)}.bg-gray-900{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity,1))}.bg-gray-900\/40{background-color:rgba(17,24,39,.4)}.bg-\[linear-gradient\(transparent_50\%\2c rgba\(0\2c 0\2c 0\2c 0\.2\)_50\%\)\]{background-image:linear-gradient(transparent 50%,rgba(0,0,0,.2) 0)}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-gray-700{--tw-gradient-from:#374151 var(--tw-gradient-from-position);--tw-gradient-to:rgba(55,65,81,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}.bg-\[length\:100\%_4px\]{background-size:100% 4px}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-10{padding-bottom:2.5rem;padding-top:2.5rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-20{padding-bottom:5rem;padding-top:5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.pb-16{padding-bottom:4rem}.pb-2{padding-bottom:.5rem}.pl-4{padding-left:1rem}.pt-12{padding-top:3rem}.pt-24{padding-top:6rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.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-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-relaxed{line-height:1.625}.tracking-\[0\.2em\]{letter-spacing:.2em}.tracking-tight{letter-spacing:-.025em}.tracking-tighter{letter-spacing:-.05em}.tracking-wide{letter-spacing:.025em}.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-blue-400{--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity,1))}.text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/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-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-green-400{--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity,1))}.text-green-900{--tw-text-opacity:1;color:rgb(20 83 45/var(--tw-text-opacity,1))}.text-purple-400{--tw-text-opacity:1;color:rgb(192 132 252/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))}.text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity,1))}.opacity-20{opacity:.2}.shadow-2xl{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.shadow-2xl,.shadow-\[0_4px_30px_rgba\(0\2c 0\2c 0\2c 0\.5\)\]{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-\[0_4px_30px_rgba\(0\2c 0\2c 0\2c 0\.5\)\]{--tw-shadow:0 4px 30px rgba(0,0,0,.5);--tw-shadow-colored:0 4px 30px var(--tw-shadow-color)}.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);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.grayscale{--tw-grayscale:grayscale(100%)}.filter,.grayscale{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-blur-lg,.backdrop-blur-md{-webkit-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);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)}.backdrop-blur-md{--tw-backdrop-blur:blur(12px)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px)}.backdrop-blur-sm,.backdrop-blur-xl{-webkit-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);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)}.backdrop-blur-xl{--tw-backdrop-blur:blur(24px)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.delay-100{transition-delay:.1s}.delay-200{transition-delay:.2s}.delay-300{transition-delay:.3s}.delay-500{transition-delay:.5s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.hover\:-translate-y-2:hover{--tw-translate-y:-0.5rem}.hover\:-translate-y-2:hover,.hover\:scale-105:hover{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\:scale-105:hover{--tw-scale-x:1.05;--tw-scale-y:1.05}.hover\:scale-110:hover{--tw-scale-x:1.1;--tw-scale-y:1.1;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\:bg-gray-700\/50:hover{background-color:rgba(55,65,81,.5)}.hover\:bg-opacity-90:hover{--tw-bg-opacity:0.9}.hover\:text-black:hover{--tw-text-opacity:1;color:rgb(0 0 0/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\:shadow-\[0_0_20px_rgba\(0\2c 255\2c 65\2c 0\.1\)\]:hover{--tw-shadow:0 0 20px rgba(0,255,65,.1);--tw-shadow-colored:0 0 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:grayscale-0:hover{--tw-grayscale:grayscale(0);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)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.group:hover .group-hover\:rotate-12{--tw-rotate:12deg;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))}.group:hover .group-hover\:text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}@media (min-width:640px){.sm\:h-7{height:1.75rem}.sm\:w-auto{width:auto}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-base{font-size:1rem;line-height:1.5rem}}@media (min-width:768px){.md\:order-first{order:-9999}.md\:order-last{order:9999}.md\:mt-0{margin-top:0}.md\:mt-8{margin-top:2rem}.md\:hidden{display:none}.md\:h-80{height:20rem}.md\:w-1\/2{width:50%}.md\:w-80{width:20rem}.md\:max-w-md{max-width:28rem}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:items-start{align-items:flex-start}.md\:justify-start{justify-content:flex-start}.md\:gap-16{gap:4rem}.md\:py-32{padding-bottom:8rem;padding-top:8rem}.md\:pb-24{padding-bottom:6rem}.md\:pt-0{padding-top:0}.md\:pt-12{padding-top:3rem}.md\:pt-16{padding-top:4rem}.md\:pt-32{padding-top:8rem}.md\:text-left{text-align:left}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:h-12{height:3rem}.lg\:w-12{width:3rem}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:gap-3{gap:.75rem}.lg\:gap-6{gap:1.5rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:text-2xl{font-size:1.5rem;line-height:2rem}}@media (min-width:1280px){.xl\:block{display:block}.xl\:flex{display:flex}}.rtl\:border-l-0:where([dir=rtl],[dir=rtl] *){border-left-width:0}.rtl\:border-r:where([dir=rtl],[dir=rtl] *){border-right-width:1px}.rtl\:pl-0:where([dir=rtl],[dir=rtl] *){padding-left:0}.rtl\:pr-4:where([dir=rtl],[dir=rtl] *){padding-right:1rem}

