/*! tailwindcss v3.4.10 | MIT License | https://tailwindcss.com */

/* Base reset styles */
*, 
: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: Inter, Segoe UI, Roboto, sans-serif;
  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] {
  display: none;
}

/* Form element styles */
[multiple],
[type=date],
[type=datetime-local],
[type=email],
[type=month],
[type=number],
[type=password],
[type=search],
[type=tel],
[type=text],
[type=time],
[type=url],
[type=week],
input:where(:not([type])),
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff;
  border-color: #6b7280;
  border-radius: 0;
  border-width: 1px;
  font-size: 1rem;
  line-height: 1.5rem;
  padding: .5rem .75rem;
  --tw-shadow: 0 0 #0000;
}

/* Form element focus styles */
[multiple]:focus,
[type=date]:focus,
[type=datetime-local]:focus,
[type=email]:focus,
[type=month]:focus,
[type=number]:focus,
[type=password]:focus,
[type=search]:focus,
[type=tel]:focus,
[type=text]:focus,
[type=time]:focus,
[type=url]:focus,
[type=week]:focus,
input:where(:not([type])):focus,
select:focus,
textarea:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-inset: var(--tw-empty, /*!*/ /*!*/);
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: #2563eb;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  border-color: #2563eb;
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}

/* Form placeholders */
input::-moz-placeholder,
textarea::-moz-placeholder {
  color: #6b7280;
  opacity: 1;
}

input::placeholder,
textarea::placeholder {
  color: #6b7280;
  opacity: 1;
}

/* Webkit date/time inputs */
::-webkit-datetime-edit-fields-wrapper {
  padding: 0;
}

::-webkit-date-and-time-value {
  min-height: 1.5em;
  text-align: inherit;
}

::-webkit-datetime-edit {
  display: inline-flex;
}

::-webkit-datetime-edit,
::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-meridiem-field,
::-webkit-datetime-edit-millisecond-field,
::-webkit-datetime-edit-minute-field,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-second-field,
::-webkit-datetime-edit-year-field {
  padding-bottom: 0;
  padding-top: 0;
}

/* Select dropdown styling */
select {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");
  background-position: right .5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em;
  padding-right: 2.5rem;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}

[multiple],
[size]:where(select:not([size="1"])) {
  background-image: none;
  background-position: 0 0;
  background-repeat: unset;
  background-size: initial;
  padding-right: .75rem;
  -webkit-print-color-adjust: unset;
  print-color-adjust: unset;
}

/* Checkbox and radio styles */
[type=checkbox],
[type=radio] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff;
  background-origin: border-box;
  border-color: #6b7280;
  border-width: 1px;
  color: #2563eb;
  display: inline-block;
  flex-shrink: 0;
  height: 1rem;
  padding: 0;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  vertical-align: middle;
  width: 1rem;
  --tw-shadow: 0 0 #0000;
}

[type=checkbox] {
  border-radius: 0;
}

[type=radio] {
  border-radius: 100%;
}

[type=checkbox]:focus,
[type=radio]:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-inset: var(--tw-empty, /*!*/ /*!*/);
  --tw-ring-offset-width: 2px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: #2563eb;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}

[type=checkbox]:checked,
[type=radio]:checked {
  background-color: currentColor;
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  border-color: transparent;
}

[type=checkbox]:checked {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0'/%3E%3C/svg%3E");
}

@media (forced-colors: active) {
  [type=checkbox]:checked {
    -webkit-appearance: auto;
    -moz-appearance: auto;
    appearance: auto;
  }
}

[type=radio]:checked {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E");
}

@media (forced-colors: active) {
  [type=radio]:checked {
    -webkit-appearance: auto;
    -moz-appearance: auto;
    appearance: auto;
  }
}

[type=checkbox]:checked:focus,
[type=checkbox]:checked:hover,
[type=radio]:checked:focus,
[type=radio]:checked:hover {
  background-color: currentColor;
  border-color: transparent;
}

[type=checkbox]:indeterminate {
  background-color: currentColor;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3E%3C/svg%3E");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  border-color: transparent;
}

@media (forced-colors: active) {
  [type=checkbox]:indeterminate {
    -webkit-appearance: auto;
    -moz-appearance: auto;
    appearance: auto;
  }
}

[type=checkbox]:indeterminate:focus,
[type=checkbox]:indeterminate:hover {
  background-color: currentColor;
  border-color: transparent;
}

[type=file] {
  background: unset;
  border-color: inherit;
  border-radius: 0;
  border-width: 0;
  font-size: unset;
  line-height: inherit;
  padding: 0;
}

[type=file]:focus {
  outline: 1px solid ButtonText;
  outline: 1px auto -webkit-focus-ring-color;
}

/* Custom global styles */
:root {
    /* Slate Color Scale */
    --slate-050: #f8fafc;
    --slate-100: #f1f5f9;
    --slate-200: #e2e8f0;
    --slate-300: #cbd5e1;
    --slate-400: #94a3b8;
    --slate-500: #64748b;
    --slate-600: #475569;
    --slate-700: #334155;
    --slate-800: #1e293b;
    --slate-900: #0f172a;
    --slate-950: #020617;

    /* Cyan Color Scale */
    --cyan-050: #ecfeff;
    --cyan-100: #cffafe;
    --cyan-200: #a5f3fc;
    --cyan-300: #67e8f9;
    --cyan-400: #22d3ee;
    --cyan-500: #06b6d4;
    --cyan-600: #0891b2;
    --cyan-700: #0e7490;
    --cyan-800: #155e75;
    --cyan-900: #164e63;
    --cyan-950: #083344;

    /* Blue Colors */
    --blue-600: #2563eb;
    --blue-700: #1d4ed8;

    /* Semantic Colors */
    --primary: var(--cyan-500);
    --primary-foreground: var(--cyan-900);
    --accent: var(--cyan-600);
}

body, html {
  background: var(--slate-950);
  color: var(--slate-300);
  font-family: Inter, Segoe UI, Roboto, sans-serif;
  line-height: 1.6;
  margin: 0;
  padding: 0;
}

/* Button Styles */
.btn-primary-custom {
    padding: 0;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-size: 0.875rem;
    font-weight: 400;    color: var(--slate-900);
    background: linear-gradient(135deg, var(--cyan-400) 0%, var(--cyan-500) 100%);
    border: none;
    border-radius: 0.5rem;
    transition: all 0.2s ease;
    cursor: pointer;
}

.btn-primary-custom:hover {
    background: linear-gradient(135deg, var(--cyan-600) 0%, var(--cyan-700) 100%);
    transform: translateY(-1px);
    box-shadow: 0 10px 25px -5px color-mix(in srgb, var(--cyan-400) 40%, transparent);
}

.btn-primary-custom.btn-lg {
    padding: .5rem 2rem;
    font-size: .95rem;
}

.btn-outline-custom {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 400;
    background: transparent;
    border: 1.5px solid var(--slate-700);
    border-radius: 0.5rem;
    text-decoration: none;
    transition: all 0.2s ease;
    cursor: pointer;
}

.btn-outline-custom:hover {
    background: color-mix(in srgb, var(--slate-800) 50%, transparent);
    border-color: var(--cyan-400);
    color: var(--cyan-400);
}

.btn-outline-custom.btn-lg {
    padding: .5rem 2rem;
    font-size: .95rem;
}

.btn-outline-custom.btn-sm {
    padding: 0.5rem 1rem;
    font-size: 0.75rem;
}

/* Text Gradient Utilities */
.text-accent-gradient {
    background: linear-gradient(135deg, var(--cyan-400) 0%, var(--cyan-500) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.text-gradient {
    background: linear-gradient(135deg, var(--cyan-400) 0%, var(--cyan-500) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Glow Effect */
.glow-effect {
    box-shadow: 0 0 0.5rem rgba(34, 211, 238, 0.35), 0 0 1.5rem rgba(168, 85, 247, 0.25);
}

/* Additional Button Styles for ProjectNavigation */
.btn-cyan-primary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    background-color: var(--cyan-500);
    color: var(--slate-950);
    border: none;
    border-radius: 0.5rem;
    text-decoration: none;
    transition: all 0.2s ease;
    cursor: pointer;
}

.btn-cyan-primary:hover {
    background-color: var(--cyan-600);
    transform: translateY(-1px);
}

.btn-cyan-primary.btn-lg {
    padding: 0.75rem 2rem;
    font-size: 1rem;
}

.btn-gradient-primary {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    background: linear-gradient(135deg, var(--cyan-500) 0%, var(--blue-600) 100%);
    color: white;
    border: none;
    border-radius: 0.5rem;
    text-decoration: none;
    transition: all 0.2s ease;
    cursor: pointer;
}

.btn-gradient-primary:hover {
    background: linear-gradient(135deg, var(--cyan-600) 0%, var(--blue-700) 100%);
    transform: translateY(-1px);
}

.btn-gradient-primary.btn-lg {
    padding: 0.75rem 2rem;
    font-size: 1rem;
}

/* Hover states for background colors */
.hover\:bg-slate-800:hover {
    background-color: var(--slate-800);
}

.hover\:bg-cyan-600:hover {
    background-color: var(--cyan-600);
}

/* Background color utilities */
.bg-cyan-600 {
    background-color: var(--cyan-600);
}

.bg-blue-700 {
    background-color: var(--blue-700);
}

/* Tailwind CSS Variables */
*, 
: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: ;
}

/* Container responsive styles */
.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;
  }
}

/* MainLayout Component Styles */
.app-root {
  min-height: 100vh;
  /* Keep base color but add subtle layered radial gradients so every page shows the same soft glow used on Home */
  background:
    radial-gradient(800px 400px at 10% 10%, rgba(34,211,238,0.06) 0%, transparent 30%),
    radial-gradient(700px 350px at 90% 80%, rgba(168,85,247,0.04) 0%, transparent 30%),
    var(--slate-950);
  background-repeat: no-repeat;
  background-attachment: fixed;
  color: #fff;
  display: flex;
  flex-direction: column;
}

/* Site Navigation */
.site-nav {
    position: sticky;
    position: -webkit-sticky;
    top: 0;
    z-index: 50;
    background: rgba(2, 6, 23, 0.9); /* slate-950/90 */
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--slate-800);
}

.nav-row {
    height: 3.5rem; /* 56px - more compact like reference */
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.brand {
    font-weight: 700;
    font-size: 1.125rem;
    text-decoration: none;
    background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.nav-links {
    display: none;
    gap: 2rem;
}

.nav-link {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .375rem .75rem;
    border-radius: .375rem;
    color: var(--slate-300);
    text-decoration: none;
    font-size: 0.875rem;
    transition: background-color .2s ease, color .2s ease, box-shadow .2s ease;
}

.nav-link:hover {
    color: var(--cyan-400);
    background: rgba(30, 41, 59, 0.5); /* slate-800/50 */
}

.nav-link.active {
    color: var(--cyan-400);
    background: rgba(6, 182, 212, 0.2); /* cyan-500/20 */
}

.icon {
    width: 1rem; /* 16px */
    height: 1rem;
    display: inline-block;
}

.mobile-menu-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    color: #e2e8f0;
    background: transparent;
    border: none;
    border-radius: .5rem;
}

.mobile-menu-button:hover {
    background: rgba(30, 41, 59, 0.5);
}

.mobile-menu-button svg { 
    width: 20px; 
    height: 20px; 
}

.mobile-nav {
    display: block;
    background: var(--slate-900);
    border-top: 1px solid var(--slate-800);
}

.mobile-nav-inner {
    padding: .5rem .5rem 1rem;
}

.mobile-nav-link {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .5rem .75rem;
    border-radius: .5rem;
    color: var(--slate-300);
    text-decoration: none;
    transition: background-color .2s ease, color .2s ease;
}

.mobile-nav-link:hover, 
.mobile-nav-link.active {
    color: var(--cyan-400);
    background: rgba(30, 41, 59, 0.5);
}

.mobile-nav .icon { 
    width: 1.25rem; 
    height: 1.25rem; 
}

/* Content */
.main-content {
    flex: 1 1 auto;
}

/* Footer */
.site-footer {
    background: var(--slate-950);
    border-top: 1px solid var(--slate-800);
    padding: 2rem 0;
    margin-top: 5rem;
    color: #64748b;
}

.site-footer p {
    color: #64748b;
    margin: 0;
}

/* MainLayout Responsive */
@media (min-width: 768px) {
    .nav-links.desktop { 
        display: flex; 
    }
    .mobile-menu-button { 
        display: none; 
    }
    .mobile-nav { 
        display: none; 
    }
}

/* Blazor Error UI */
#blazor-error-ui {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}


.w-1 { width: 0.25rem !important; }
.h-1 { height: 0.25rem !important; }
.w-2 { width: 0.5rem !important; }
.h-2 { height: 0.5rem !important; }
.w-3 { width: 0.75rem !important; }
.h-3 { height: 0.75rem !important; }
.w-4 { width: 1rem !important; }
.h-4 { height: 1rem !important; }
.w-5 { width: 1.25rem !important; }
.h-5 { height: 1.25rem !important; }
.w-6 { width: 1.5rem !important; }
.h-6 { height: 1.5rem !important; }
.w-7 { width: 1.75rem !important; }
.h-7 { height: 1.75rem !important; }
.w-8 { width: 2rem !important; }
.h-8 { height: 2rem !important; }
.w-9 { width: 2.25rem !important; }
.h-9 { height: 2.25rem !important; }
.w-10 { width: 2.5rem !important; }
.h-10 { height: 2.5rem !important; }
.w-11 { width: 2.75rem !important; }
.h-11 { height: 2.75rem !important; }
.w-12 { width: 3rem !important; }
.h-12 { height: 3rem !important; }
.w-24 { width: 6rem !important; }
.h-24 { height: 6rem !important; }
.ml-2 { margin-left: 0.5rem !important; }
.p-1 { padding: 0.25rem !important; }
.p-2 { padding: 0.5rem !important; }
.p-3 { padding: 0.75rem !important; }
.p-4 { padding: 1rem !important; }
.p-5 { padding: 1.25rem !important; }
.p-6 { padding: 1.5rem !important; }
.p-7 { padding: 1.75rem !important; }
.p-8 { padding: 2rem !important; }
.p-9 { padding: 2.25rem !important; }
.p-10 { padding: 2.5rem !important; }
.p-11 { padding: 2.75rem !important; }
.p-12 { padding: 3rem !important; }

.bg-green-400 { background-color: #4ade80 !important; }
.bg-gradient-to-br { background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)) !important; }
.from-cyan-500\/10 { --tw-gradient-from: rgba(6, 182, 212, 0.1) !important; --tw-gradient-to: rgba(6, 182, 212, 0) !important; --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important; }
.via-transparent { --tw-gradient-to: rgba(15, 23, 42, 0) !important; --tw-gradient-stops: var(--tw-gradient-from), transparent, var(--tw-gradient-to) !important; }
.to-slate-900\/50 { --tw-gradient-to: rgba(15, 23, 42, 0.5) !important; }

/* Border opacity utilities */
/* Border Slate Colors */
.border-slate-050 { border-color: var(--slate-050) !important; }
.border-slate-100 { border-color: var(--slate-100) !important; }
.border-slate-200 { border-color: var(--slate-200) !important; }
.border-slate-300 { border-color: var(--slate-300) !important; }
.border-slate-400 { border-color: var(--slate-400) !important; }
.border-slate-500 { border-color: var(--slate-500) !important; }
.border-slate-600 { border-color: var(--slate-600) !important; }
.border-slate-700 { border-color: var(--slate-700) !important; }
.border-slate-800 { border-color: var(--slate-800) !important; }
.border-slate-900 { border-color: var(--slate-900) !important; }
.border-slate-950 { border-color: var(--slate-950) !important; }

/* Border Cyan Colors */
.border-cyan-050 { border-color: var(--cyan-050) !important; }
.border-cyan-100 { border-color: var(--cyan-100) !important; }
.border-cyan-200 { border-color: var(--cyan-200) !important; }
.border-cyan-300 { border-color: var(--cyan-300) !important; }
.border-cyan-400 { border-color: var(--cyan-400) !important; }
.border-cyan-500 { border-color: var(--cyan-500) !important; }
.border-cyan-600 { border-color: var(--cyan-600) !important; }
.border-cyan-700 { border-color: var(--cyan-700) !important; }
.border-cyan-800 { border-color: var(--cyan-800) !important; }
.border-cyan-900 { border-color: var(--cyan-900) !important; }
.border-cyan-950 { border-color: var(--cyan-950) !important; }

/* Hover Border Cyan Colors */
.hover\:border-cyan-050:hover { border-color: var(--cyan-050) !important; }
.hover\:border-cyan-100:hover { border-color: var(--cyan-100) !important; }
.hover\:border-cyan-200:hover { border-color: var(--cyan-200) !important; }
.hover\:border-cyan-300:hover { border-color: var(--cyan-300) !important; }
.hover\:border-cyan-400:hover { border-color: var(--cyan-400) !important; }
.hover\:border-cyan-500:hover { border-color: var(--cyan-500) !important; }
.hover\:border-cyan-600:hover { border-color: var(--cyan-600) !important; }
.hover\:border-cyan-700:hover { border-color: var(--cyan-700) !important; }
.hover\:border-cyan-800:hover { border-color: var(--cyan-800) !important; }
.hover\:border-cyan-900:hover { border-color: var(--cyan-900) !important; }
.hover\:border-cyan-950:hover { border-color: var(--cyan-950) !important; }

.border-cyan-500\/20 { border-color: rgba(6, 182, 212, 0.2) !important; }

.animate-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite !important;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* Additional mobile responsiveness */
@media (max-width: 640px) {
  .text-6xl { font-size: 3rem !important; line-height: 1.1 !important; }
  .py-24 { padding-top: 4rem !important; padding-bottom: 4rem !important; }
  .mb-20 { margin-bottom: 3rem !important; }
  .px-4 { padding-left: 1rem !important; padding-right: 1rem !important; }
  .p-8 { padding: 1.5rem !important; }
  .gap-8 { gap: 1.5rem !important; }
}


#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}

/* Tailwind Utility Classes */

/* Position */
.static { position: static; }
.absolute { position: absolute; }
.relative { position: relative; }

/* Positioning */
.inset-0 { inset: 0; }
.right-3 { right: .75rem; }
.top-3 { top: .75rem; }

/* Margin */
.mx-auto { margin-left: auto; margin-right: auto; }
.mb-1 { margin-bottom: .25rem; }
.mb-2 { margin-bottom: .5rem; }
.mb-3 { margin-bottom: .75rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-5 { margin-bottom: 1.25rem; }
.mb-6 { margin-bottom: 1.5rem; }
.mb-7 { margin-bottom: 1.75rem; }
.mb-8 { margin-bottom: 2rem; }
.mb-9 { margin-bottom: 2.25rem; }
.mb-10 { margin-bottom: 2.5rem; }
.mb-11 { margin-bottom: 2.75rem; }
.mb-12 { margin-bottom: 3rem; }
.mb-16 { margin-bottom: 4rem; }


.ml-1 { margin-left: .25rem; }
.ml-2 { margin-left: .5rem; }
.ml-3 { margin-left: .75rem; }
.ml-4 { margin-left: 1rem; }
.ml-5 { margin-left: 1.25rem; }
.ml-6 { margin-left: 1.5rem; }
.ml-7 { margin-left: 1.75rem; }
.ml-8 { margin-left: 2rem; }
.ml-9 { margin-left: 2.25rem; }
.ml-10 { margin-left: 2.5rem; }
.ml-11 { margin-left: 2.75rem; }
.ml-12 { margin-left: 3rem; }

.mr-1 { margin-right: .25rem; }
.mr-2 { margin-right: .5rem; }
.mr-3 { margin-right: .75rem; }
.mr-4 { margin-right: 1rem; }
.mr-5 { margin-right: 1.25rem; }
.mr-6 { margin-right: 1.5rem; }
.mr-7 { margin-right: 1.75rem; }
.mr-8 { margin-right: 2rem; }
.mr-9 { margin-right: 2.25rem; }
.mr-10 { margin-right: 2.5rem; }
.mr-11 { margin-right: 2.75rem; }
.mr-12 { margin-right: 3rem; }

.mt-0 { margin-top: 0rem; }
.mt-1 { margin-top: .25rem; }
.mt-2 { margin-top: .5rem; }
.mt-3 { margin-top: .75rem; }
.mt-4 { margin-top: 1rem; }
.mt-5 { margin-top: 1.25rem; }
.mt-6 { margin-top: 1.5rem; }
.mt-7 { margin-top: 1.75rem; }
.mt-8 { margin-top: 2rem; }
.mt-9 { margin-top: 2.25rem; }
.mt-10 { margin-top: 2.5rem; }
.mt-11 { margin-top: 2.75rem; }
.mt-12 { margin-top: 3rem; }
.mt-auto { margin-top: auto; }

/* Line Clamp */
.line-clamp-3 {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
}

/* Display */
.block { display: block; }
.inline { display: inline; }
.flex { display: flex; }
.inline-flex { display: inline-flex; }
.table { display: table; }
.grid { display: grid; }

/* Aspect Ratio */
.aspect-video { aspect-ratio: 16/9; }

/* Height */
.h-12 { height: 3rem; }
.h-2 { height: .5rem; }
.h-3 { height: .75rem; }
.h-4 { height: 1rem; }
.h-5 { height: 1.25rem; }
.h-6 { height: 1.5rem; }
.h-9 { height: 2.25rem; }
.h-96 { height: 24rem; }
.h-full { height: 100%; }
.min-h-screen { min-height: 100vh; }

/* Width */
.w-12 { width: 3rem; }
.w-2 { width: .5rem; }
.w-3 { width: .75rem; }
.w-4 { width: 1rem; }
.w-5 { width: 1.25rem; }
.w-64 { width: 16rem; }
.w-96 { width: 24rem; }
.w-full { width: 100%; }

/* Max Width */
.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }
.max-w-4xl { max-width: 56rem; }
.max-w-5xl { max-width: 64rem; }
.max-w-7xl { max-width: 80rem; }

/* Flex */
.flex-1 { flex: 1 1 0%; }

/* Animations */
@keyframes pulse {
  50% { opacity: .5; }
}
.animate-pulse { animation: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; }

/* Flexbox */
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }

/* Gap */
.gap-2 { gap: .5rem; }
.gap-3 { gap: .75rem; }
.gap-4 { gap: 1rem; }
.gap-6 { gap: 1.5rem; }
.gap-8 { gap: 2rem; }

/* Overflow */
.overflow-hidden { overflow: hidden; }
.overflow-x-auto { overflow-x: auto; }

/* Whitespace */
.whitespace-nowrap { white-space: nowrap; }

/* Border Radius */
.rounded { border-radius: .25rem; }
.rounded-2xl { border-radius: 1rem; }
.rounded-full { border-radius: 9999px; }
.rounded-md { border-radius: .375rem; }
.rounded-lg { border-radius: .5rem; }
.rounded-xl { border-radius: .75rem; }

/* Borders */
.border { border-width: 1px; }
.border-slate-600 { 
  --tw-border-opacity: 1; 
  border-color: rgb(71 85 105 / var(--tw-border-opacity)); 
}
.border-slate-700\/30 { border-color: rgba(51, 65, 85, .3); }
.border-slate-700\/50 { border-color: rgba(51, 65, 85, .5); }
.border-slate-700\/60 { border-color: rgba(51, 65, 85, .6); }

/* Backgrounds */
.bg-green-400 { 
  --tw-bg-opacity: 1; 
  background-color: rgb(74 222 128 / var(--tw-bg-opacity)); 
}
.bg-slate-700 { 
  --tw-bg-opacity: 1; 
  background-color: rgb(51 65 85 / var(--tw-bg-opacity)); 
}
.bg-slate-800 { 
  --tw-bg-opacity: 1; 
  background-color: rgb(30 41 59 / var(--tw-bg-opacity)); 
}
.bg-slate-800\/20 { background-color: rgba(30, 41, 59, .2); }
.bg-slate-800\/30 { background-color: rgba(30, 41, 59, .3); }
.bg-slate-800\/40 { background-color: rgba(30, 41, 59, .4); }
.bg-slate-800\/50 { background-color: rgba(30, 41, 59, .5); }
.bg-slate-900\/30 { background-color: rgba(15, 23, 42, .3); }
.bg-slate-900\/50 { background-color: rgba(15, 23, 42, .5); }

/* Background Images */
.bg-gradient-to-br { background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)); }
.bg-gradient-to-r { background-image: linear-gradient(to right, var(--tw-gradient-stops)); }

/* Gradient Color Stops */
.from-cyan-500\/10 {
  --tw-gradient-from: rgba(6, 182, 212, .1) var(--tw-gradient-from-position);
  --tw-gradient-to: rgba(6, 182, 212, 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.from-slate-900 {
  --tw-gradient-from: #0f172a var(--tw-gradient-from-position);
  --tw-gradient-to: rgba(15, 23, 42, 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.via-slate-800 {
  --tw-gradient-to: rgba(30, 41, 59, 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), #1e293b var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.via-transparent {
  --tw-gradient-to: transparent var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), transparent var(--tw-gradient-via-position), var(--tw-gradient-to);
}
.to-purple-500\/10 { --tw-gradient-to: rgba(168, 85, 247, .1) var(--tw-gradient-to-position); }
.to-slate-900 { --tw-gradient-to: #0f172a var(--tw-gradient-to-position); }
.to-slate-900\/50 { --tw-gradient-to: rgba(15, 23, 42, .5) var(--tw-gradient-to-position); }

/* Object Fit */
.object-cover { 
  -o-object-fit: cover; 
  object-fit: cover; 
}

/* Padding */
.p-12 { padding: 3rem; }
.p-8 { padding: 2rem; }
.px-2 { padding-left: .5rem; padding-right: .5rem; }
.px-3 { padding-left: .75rem; padding-right: .75rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.py-1\.5 { padding-bottom: .375rem; padding-top: .375rem; }
.py-16 { padding-bottom: 4rem; padding-top: 4rem; }
.py-2 { padding-bottom: .5rem; padding-top: .5rem; }
.py-20 { padding-bottom: 5rem; padding-top: 5rem; }
.py-24 { padding-bottom: 6rem; padding-top: 6rem; }
.py-5 { padding-bottom: 1.25rem; padding-top: 1.25rem; }
.pb-20 { padding-bottom: 5rem; }
.ps-3 { padding-inline-start: .75rem; }
.pl-8 { padding-left: 2rem; }

/* Text Alignment */
.text-center { text-align: center; }

/* Font Sizes */
.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-6xl { font-size: 3.75rem; line-height: 1; }
.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 Weights */
.font-bold { font-weight: 700; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }

/* Line Heights */
.leading-none { line-height: 1; }
.leading-relaxed { line-height: 1.625; }

/* Text Colors */
.text-cyan-400 { 
  --tw-text-opacity: 1; 
  color: rgb(34 211 238 / var(--tw-text-opacity)); 
}
.text-slate-300 { 
  --tw-text-opacity: 1; 
  color: rgb(203 213 225 / var(--tw-text-opacity)); 
}
.text-slate-400 { 
  --tw-text-opacity: 1; 
  color: rgb(148 163 184 / var(--tw-text-opacity)); 
}
.text-slate-500 { 
  --tw-text-opacity: 1; 
  color: rgb(100 116 139 / var(--tw-text-opacity)); 
}
.text-slate-950 { 
  --tw-text-opacity: 1; 
  color: rgb(2 6 23 / var(--tw-text-opacity)); 
}
.text-white { 
  --tw-text-opacity: 1; 
  color: rgb(255 255 255 / var(--tw-text-opacity)); 
}

/* Shadows */
.shadow-\[0_0_0_1px_rgba\(148\2c 163\2c 184\2c 0\.12\)\] {
  --tw-shadow: 0 0 0 1px rgba(148, 163, 184, .12);
  --tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);
}

.shadow-\[0_0_0_1px_rgba\(148\2c 163\2c 184\2c 0\.12\)\],
.shadow-xl {
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-xl {
  --tw-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);
  --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
}

/* Filters */
.blur-xl { --tw-blur: blur(24px); }

.blur-xl,
.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.backdrop-blur-sm {
  --tw-backdrop-blur: blur(4px);
  -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);
}

/* Transitions */
.transition-all {
  transition-duration: .15s;
  transition-property: all;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
}

.transition-colors {
  transition-duration: .15s;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  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);
}

.duration-300 { transition-duration: .3s; }

/* Accessibility */
.visually-hidden {
  height: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  clip: rect(0, 0, 0, 0) !important;
  border: 0 !important;
  white-space: nowrap !important;
}

/* Hover States */
.hover\:border-cyan-500\/30:hover { border-color: rgba(6, 182, 212, .3); }
.hover\:border-cyan-500\/40:hover { border-color: rgba(6, 182, 212, .4); }
.hover\:bg-slate-700:hover { 
  --tw-bg-opacity: 1; 
  background-color: rgb(51 65 85 / var(--tw-bg-opacity)); 
}
.hover\:shadow-2xl:hover {
  --tw-shadow: 0 25px 50px -12px rgba(0, 0, 0, .25);
  --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}
.bg-cyan-400 {
  background-color: var(--cyan-400);
}
.bg-cyan-500 { 
  background-color: var(--cyan-500);
}

/* Focus States */
.focus-visible\:outline-none:focus-visible {
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.focus-visible\:ring-2:focus-visible {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus-visible\:ring-offset-2:focus-visible { --tw-ring-offset-width: 2px; }

/* Disabled States */
.disabled\:pointer-events-none:disabled { pointer-events: none; }
.disabled\:opacity-50:disabled { opacity: .5; }

/* Group Hover States */
.group:hover .group-hover\:scale-105 {
  --tw-scale-x: 1.05;
  --tw-scale-y: 1.05;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.group:hover .group-hover\:text-cyan-400 { 
  --tw-text-opacity: 1; 
  color: rgb(34 211 238 / var(--tw-text-opacity)); 
}

/* Responsive Styles */
@media (min-width: 640px) {
  .sm\:flex-row { flex-direction: row; }
  .sm\:px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
}

@media (min-width: 768px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\:gap-6 { gap: 1.5rem; }
  .md\:px-3 { padding-left: .75rem; padding-right: .75rem; }
  .md\:py-3 { padding-bottom: .75rem; padding-top: .75rem; }
  .md\:text-2xl { font-size: 1.5rem; line-height: 2rem; }
  .md\:text-4xl { font-size: 2.25rem; line-height: 2.5rem; }
  .md\:text-5xl { font-size: 3rem; line-height: 1; }
  .md\:text-6xl { font-size: 3.75rem; line-height: 1; }
  .md\:text-8xl { font-size: 6rem; line-height: 1; }
}

  /* Added utilities to match tailwind-like classes used in components */
  .text-5xl { font-size: 3rem; line-height: 1; }
  .leading-tight { line-height: 1.25; }

  @media (min-width: 768px) {
    /* md:text-7xl approximates a larger heading on md screens */
    .md\:text-7xl { font-size: 4.5rem; line-height: 1; }
  }


@media (min-width: 1024px) {
  .lg\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .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\:col-span-2 { grid-column: span 2 / span 2; }
  .lg\:col-start-1 { grid-column-start: 1; }
  .lg\:grid-flow-col-dense { grid-auto-flow: column dense; }
  .lg\:px-8 { padding-left: 2rem; padding-right: 2rem; }
  .lg\:pr-16 { padding-right: 4rem; }
  .lg\:pl-16 { padding-left: 4rem; }
}


/* YELLOW */
.text-yellow-400 { color: #facc15 !important; }
.text-amber-400 { color: #fbbf24 !important; }

/* Additional colors for ProjectDesignShowcase */
.bg-green-500 { background-color: #10b981; }
.bg-blue-600 { background-color: #2563eb; }
.border-slate-600 { border-color: #475569; }
.border-cyan-500\/20 { border-color: rgba(6, 182, 212, 0.2) !important; }

/* Additional colors for SkillsSection */
.bg-pink-500 { background-color: #ec4899; }
.bg-purple-500 { background-color: #a855f7; }
.bg-blue-500 { background-color: #3b82f6; }
.bg-orange-500 { background-color: #f97316; }
.bg-gray-500 { background-color: #6b7280; }

/* SkillsSection animations and effects */
.skills-progress-bar {
  transition: width 1.5s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes pulse-glow {
  0%, 100% { box-shadow: 0 0 5px rgba(34, 211, 238, 0.3); }
  50% { box-shadow: 0 0 15px rgba(34, 211, 238, 0.6); }
}

.skills-section .bg-slate-800\/50:hover {
  transform: translateY(-2px);
  transition: transform 0.3s ease;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
}

/* Gradient classes for ProjectDesignShowcase */
.from-cyan-500 {
  --tw-gradient-from: #06b6d4;
  --tw-gradient-to: rgba(6, 182, 212, 0);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.to-blue-600 {
  --tw-gradient-to: #2563eb;
}

.from-cyan-500\/10 {
  --tw-gradient-from: rgba(6, 182, 212, 0.1);
  --tw-gradient-to: rgba(6, 182, 212, 0);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.to-purple-500\/10 {
  --tw-gradient-to: rgba(168, 85, 247, 0.1);
}

/* Aspect ratio utility */
.aspect-video {
  aspect-ratio: 16 / 9;
}

/* Tab button styling for ProjectDesignShowcase */
.tab-button {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1rem;
  color: #cbd5e1; /* text-slate-300 */
  transition: all 0.2s ease;
  background: transparent;
  border: none;
  cursor: pointer;
  font-weight: 400;
}

.tab-button:hover {
  color: #ffffff;
  background-color: rgba(51, 65, 85, 0.5); /* bg-slate-700/50 */
}

.tab-button.active {
  background-color: var(--cyan-500);
  color: #020617; /* text-slate-950 */
  font-weight: 500;
}

.tab-button:focus {
  outline: none;
  box-shadow: 0 0 0 2px rgba(6, 182, 212, 0.2);
}

/* SVG Specific Styles */
.\[\&_svg\]\:pointer-events-none svg { pointer-events: none; }
.\[\&_svg\]\:size-4 svg { height: 1rem; width: 1rem; }
.\[\&_svg\]\:shrink-0 svg { flex-shrink: 0; }

/* Small utility classes not generated by Tailwind in this build */
.space-y-1 > * + * { margin-top: 0.25rem; }
.space-y-2 > * + * { margin-top: 0.5rem; }
.space-y-3 > * + * { margin-top: 0.75rem; }
.space-y-4 > * + * { margin-top: 1rem; }
.space-y-5 > * + * { margin-top: 1.25rem; }
.space-y-6 > * + * { margin-top: 1.5rem; }
.space-y-7 > * + * { margin-top: 1.75rem; }
.space-y-8 > * + * { margin-top: 2rem; }
.space-y-9 > * + * { margin-top: 2.25rem; }
.space-y-10 > * + * { margin-top: 2.5rem; }
.space-y-11 > * + * { margin-top: 2.75rem; }
.space-y-12 > * + * { margin-top: 3rem; }

/* Added utilities required by ProjectUserJourney component */
.left-1\/2 { left: 50% !important; }
.top-1\/2 { top: 50% !important; }
.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)); }
.\-translate-x-1\/2 { --tw-translate-x: -50%; }
.\-translate-y-1\/2 { --tw-translate-y: -50%; }
.hidden { display: none !important; }

/* Responsive block for large screens (lg breakpoint = 1024px) */
@media (min-width: 1024px) {
  .lg\:block { display: block !important; }
}

.border-4 { border-width: 4px !important; }

/* Provide a to-purple-500 gradient color token if missing */
.to-purple-500 { --tw-gradient-to: #a855f7; }

/* Additional utilities used by ProjectUserJourney */
.top-0 { top: 0 !important; }
.bottom-0 { bottom: 0 !important; }
.w-0\.5 { width: 0.125rem !important; }
.bg-gradient-to-b { background-image: linear-gradient(to bottom, var(--tw-gradient-stops)); }

/* Missing utility classes for ProjectUserJourney component */
.space-y-16 > * + * { margin-top: 4rem; }
.items-start { align-items: flex-start; }
.bg-slate-800\/30 { background-color: rgba(30, 41, 59, 0.3); }
.border-b { border-bottom-width: 1px; }
.mt-2 { margin-top: 0.5rem; }
.mt-16 { margin-top: 4rem; }
.w-16 { width: 4rem; }
.h-16 { height: 4rem; }
.duration-500 { transition-duration: 500ms; }
.bg-red-400 { background-color: #f87171; }
.text-red-400 { color: #f87171; }

/* Additional gradient classes for ProjectTechStack component */
.from-slate-800 { --tw-gradient-from: #1e293b var(--tw-gradient-from-position); --tw-gradient-to: rgba(30, 41, 59, 0) var(--tw-gradient-to-position); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }
.from-slate-800\/50 { --tw-gradient-from: rgba(30, 41, 59, 0.5) var(--tw-gradient-from-position); --tw-gradient-to: rgba(30, 41, 59, 0) var(--tw-gradient-to-position); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }
.to-slate-700 { --tw-gradient-to: #334155 var(--tw-gradient-to-position); }
.to-slate-700\/50 { --tw-gradient-to: rgba(51, 65, 85, 0.5) var(--tw-gradient-to-position); }

/* Tech Stack Component Colors */
.from-blue-500 { --tw-gradient-from: #3b82f6; --tw-gradient-to: rgba(59, 130, 246, 0); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }
.to-cyan-500 { --tw-gradient-to: #06b6d4; }
.from-green-500 { --tw-gradient-from: #10b981; --tw-gradient-to: rgba(16, 185, 129, 0); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }
.to-emerald-500 { --tw-gradient-to: #10b981; }
.from-purple-500 { --tw-gradient-from: #8b5cf6; --tw-gradient-to: rgba(139, 92, 246, 0); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }
.to-pink-500 { --tw-gradient-to: #ec4899; }

.category_web_app {
  background-color: rgba(34,197,94,0.75) !important;
  color: #ffffff;
  border-color: rgba(14, 84, 39, 0.55) !important;
}

.category_video_game {
  background-color: rgba(141, 91, 189, 0.75) !important;
  color: #ffffff;
  border-color: rgba(48, 22, 72, 0.55) !important;
}

.category_ui_ux {
  background-color: rgba(236,72,153,0.75) !important; 
  color: #ffffff;
  border-color: rgba(236,72,153,0.55) !important;
}

.category_mobile_app {
  background-color: rgba(40, 92, 176, 0.75) !important;
  color: #ffffff;
  border-color: rgba(26, 56, 105, 0.55) !important; 
}

/* Category color utilities (used by ProjectHero category badges)
  Provides a lightweight set of classes matching the patterns used in
  the component: bg-<color>-500/20, text-<color>-400 and
  border-<color>-500/50 for green, purple, pink and blue. */

/* GREEN */
.bg-green-500\/20 { background-color: rgba(34,197,94,0.2) !important; }
.text-green-400 { color: #4ade80 !important; }
.border-green-500\/50 { border-color: rgba(34,197,94,0.5) !important; }

/* PURPLE */
.bg-purple-500\/20 { background-color: rgba(168,85,247,0.2) !important; }
.text-purple-400 { color: #c084fc !important; }
.border-purple-500\/50 { border-color: rgba(168,85,247,0.5) !important; }

/* PINK */
.bg-pink-500\/20 { background-color: rgba(236,72,153,0.2) !important; }
.text-pink-400 { color: #f472b6 !important; }
.border-pink-500\/50 { border-color: rgba(236,72,153,0.5) !important; }

/* BLUE */
.bg-blue-500\/20 { background-color: rgba(59,130,246,0.2) !important; }
.text-blue-400 { color: #60a5fa !important; }
.border-blue-500\/50 { border-color: rgba(59,130,246,0.5) !important; }

.bg-slate-700\/50 { background-color: rgba(51, 65, 85, 0.5); }
.hover\:bg-slate-700:hover { background-color: #334155; }
.rounded-2xl { border-radius: 1rem; }
.justify-between { justify-content: space-between; }

/* Small utilities required by ProjectProcess component */
.left-8 { left: 2rem !important; }
.top-8 { top: 2rem !important; }
.bottom-8 { bottom: 2rem !important; }
.flex-shrink-0 { flex-shrink: 0; }
.z-10 { z-index: 10; }
.w-1\.5 { width: 0.375rem !important; }
.h-1\.5 { height: 0.375rem !important; }

/* Responsive (md) utilities */
@media (min-width: 768px) {
  .md\:block { display: block !important; }
  .md\:gap-8 { gap: 2rem; }
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:flex-row { flex-direction: row; }
  .md\:items-center { align-items: center; }
  .md\:justify-between { justify-content: space-between; }
  .md\:items-start { align-items: flex-start; }
  .md\:mt-0 { margin-top: 0; }
  .md\:ml-4 { margin-left: 1rem; }
}

/* Additional ProjectGallery utility classes */
.aspect-square { aspect-ratio: 1 / 1; }
.cursor-pointer { cursor: pointer; }
.group:hover .group-hover\:scale-110 { transform: scale(1.1); }
.transition-transform { transition-property: transform; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms; }
.duration-300 { transition-duration: 300ms; }
.hover\:border-cyan-500\/50:hover { border-color: rgba(6, 182, 212, 0.5); }

/* Additional gradient classes for ProjectProcess component */
.from-yellow-500 { --tw-gradient-from: #eab308; --tw-gradient-to: rgba(234, 179, 8, 0); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }
.to-orange-500 { --tw-gradient-to: #f97316; }
.from-pink-500 { --tw-gradient-from: #ec4899; --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }

/* Grid classes for ProjectBehindScenes component */
.grid { display: grid; }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }

/* Medium screen breakpoint (768px and up) */
@media (min-width: 768px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* Large screen breakpoint (1024px and up) */
@media (min-width: 1024px) {
  .lg\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .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\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
  
  /* Grid flow and column positioning for alternating layout */
  .lg\:grid-flow-col-dense { grid-auto-flow: column dense; }
  .lg\:col-span-2 { grid-column: span 2 / span 2; }
  .lg\:col-span-3 { grid-column: span 3 / span 3; }
  .lg\:col-start-1 { grid-column-start: 1; }
  .lg\:col-start-4 { grid-column-start: 4; }
}

/* Spacing utilities */
.space-y-12 > :not([hidden]) ~ :not([hidden]) { --tw-space-y-reverse: 0; margin-top: calc(3rem * calc(1 - var(--tw-space-y-reverse))); margin-bottom: calc(3rem * var(--tw-space-y-reverse)); }

/* Additional gradient classes for ProjectResults */
.from-slate-800\/50 {
  --tw-gradient-from: rgba(30, 41, 59, 0.5) var(--tw-gradient-from-position);
  --tw-gradient-to: rgba(30, 41, 59, 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.to-slate-700\/50 {
  --tw-gradient-to: rgba(51, 65, 85, 0.5) var(--tw-gradient-to-position);
}

/* Additional utility classes for About and Contact pages */
.w-32 { width: 8rem; }
.h-32 { height: 8rem; }
.w-fit { width: -moz-fit-content; width: fit-content; }
.from-cyan-400 { --tw-gradient-from: #22d3ee; --tw-gradient-to: rgba(34, 211, 238, 0); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }
.from-cyan-500\/10 { --tw-gradient-from: rgba(6, 182, 212, 0.1); --tw-gradient-to: rgba(6, 182, 212, 0); --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to); }
.to-blue-600\/10 { --tw-gradient-to: rgba(37, 99, 235, 0.1); }
.bg-slate-800\/50 { background-color: rgba(30, 41, 59, 0.5); }
.border-slate-600 { border-color: #475569; }
.border-cyan-500\/20 { border-color: rgba(6, 182, 212, 0.2); }
.text-green-400 { color: #4ade80; }
.disabled\:opacity-50:disabled { opacity: 0.5; }
.resize-none { resize: none; }
