:root {
  --page-teal: #4a696c;
  --page-teal-deep: #354a4d;
  --page-teal-light: #5f8589;
  --card-surface: rgba(255, 255, 255, 0.94);
  --field-bg: #eef3f4;
  --field-border: rgba(74, 105, 108, 0.18);
  --field-focus-ring: rgba(122, 168, 172, 0.45);
  --accent-gold: #c9a44a;
}

body {
  font-family: "Tajawal", sans-serif;
}

.material-symbols-outlined {
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

/* Native select arrows removed (clean RTL selects; wins over Tailwind Forms defaults) */
select {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  background-image: none !important;
}

select::-ms-expand {
  display: none;
}

.glass-card {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background-color: var(--card-surface);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 8px 32px rgba(20, 35, 38, 0.12);
}

/* Animated 45° linear gradient (top-left → bottom-right), infinite */
.glass-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(
    45deg,
    rgba(255, 255, 255, 0.5) 0%,
    rgba(201, 164, 74, 0.16) 22%,
    rgba(74, 105, 108, 0.11) 45%,
    rgba(122, 168, 172, 0.14) 68%,
    rgba(236, 242, 243, 0.55) 88%,
    rgba(255, 255, 255, 0.48) 100%
  );
  background-size: 280% 280%;
  background-position: 0% 0%;
  animation: form-gradient-flow 22s ease-in-out infinite alternate;
  will-change: background-position;
}

/* Dotted texture + very slow drift */
.glass-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image: radial-gradient(
    circle at center,
    rgba(74, 105, 108, 0.45) 1px,
    transparent 1.5px
  );
  background-size: 22px 22px;
  opacity: 0.42;
  animation: form-dots-shift 48s linear infinite;
}

.glass-card > * {
  position: relative;
  z-index: 1;
}

@keyframes form-gradient-flow {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: 100% 100%;
  }
}

@keyframes form-dots-shift {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 22px 22px;
  }
}

/* Slight phase offset per form section (same motion, less “synced”) */
form#survey-form > section.glass-card:nth-of-type(1)::before {
  animation-delay: 0s;
}
form#survey-form > section.glass-card:nth-of-type(2)::before {
  animation-delay: -9s;
}
form#survey-form > section.glass-card:nth-of-type(3)::before {
  animation-delay: -17s;
}
form#survey-form > section.glass-card:nth-of-type(2)::after {
  animation-delay: -12s;
}
form#survey-form > section.glass-card:nth-of-type(3)::after {
  animation-delay: -24s;
}

@media (prefers-reduced-motion: reduce) {
  .glass-card::before,
  .glass-card::after {
    animation: none;
  }
  .glass-card::before {
    background-position: 40% 40%;
  }
}

/* Harmonized fields on teal page */
.glass-card input:not([type="file"]):not([type="hidden"]),
.glass-card select,
.glass-card textarea {
  background-color: var(--field-bg) !important;
  border: 1px solid var(--field-border) !important;
  box-shadow: inset 0 1px 2px rgba(74, 105, 108, 0.06);
}

.glass-card input:not([type="file"]):not([type="hidden"]):not([type="checkbox"]):focus,
.glass-card select:focus,
.glass-card textarea:focus {
  outline: none;
  box-shadow:
    inset 0 1px 2px rgba(74, 105, 108, 0.06),
    0 0 0 3px var(--field-focus-ring);
  border-color: rgba(74, 105, 108, 0.35) !important;
}

/* File dropzone aligned with field palette */
.glass-card #site-dropzone {
  background: rgba(238, 243, 244, 0.88) !important;
  border-color: rgba(74, 105, 108, 0.28) !important;
}

.glass-card #site-dropzone:hover {
  background: rgba(255, 255, 255, 0.95) !important;
  border-color: rgba(74, 105, 108, 0.45) !important;
}

.input-glow:focus-within {
  box-shadow: 0 0 0 4px rgba(201, 164, 74, 0.22);
  border-color: var(--accent-gold);
}

.floating-label-container:focus-within label,
.floating-label-container input:not(:placeholder-shown) + label,
.floating-label-container textarea:not(:placeholder-shown) + label {
  transform: translateY(-1.5rem) scale(0.85);
  color: #4a696c;
}

.bg-gold-gradient {
  background: linear-gradient(135deg, #2d4a4e 0%, var(--accent-gold) 100%);
}

.main-gradient-bg {
  background-color: #36514C;
  background-image: linear-gradient(45deg, #36514C 0%, #375953 60%, #36514c57 90%, #36514c33 100%);  /* background-image:
    radial-gradient(
      circle at center,
      #36514C 1px,
      transparent 1.5px
    ),
    linear-gradient(
      145deg,
      #36514C 0%,
      #36514C 42%,
      #36514C 88%,
      #36514C 100%
    ); */
  background-size: 22px 22px, 100% 100%;
  background-position: 0 0, 0 0;
  background-attachment: fixed, fixed;
  background-repeat: repeat, no-repeat;
}

.page-hero-text {
  color: rgba(255, 255, 255, 0.96);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.12);
}

.page-hero-sub {
  color: rgba(255, 255, 255, 0.78);
}

.progress-track {
  background: rgba(255, 255, 255, 0.22);
}

.progress-fill {
  background: linear-gradient(90deg, #e8d49a, var(--accent-gold));
}

/* Gold focus & selection accents for native selects and checkboxes (survey form) */
form#survey-form .glass-card select.survey-select:focus,
form#survey-form .glass-card select:focus {
  outline: none;
  box-shadow:
    inset 0 1px 2px rgba(74, 105, 108, 0.06),
    0 0 0 3px rgba(201, 164, 74, 0.4);
  border-color: rgba(201, 164, 74, 0.55) !important;
}

form#survey-form .glass-card select.survey-select:valid:not(:focus),
form#survey-form .glass-card select:valid:not(:focus) {
  border-color: rgba(201, 164, 74, 0.28) !important;
  box-shadow:
    inset 0 1px 2px rgba(74, 105, 108, 0.06),
    inset 3px 0 0 0 var(--accent-gold);
}

form#survey-form .glass-card select option:checked,
form#survey-form .glass-card select option:hover {
  background-color: var(--accent-gold);
  color: #1a1408;
}

form#survey-form .glass-card input[type="checkbox"].survey-checkbox,
form#survey-form .glass-card input[type="checkbox"] {
  appearance: auto;
  accent-color: var(--accent-gold);
  background-color: #fff !important;
  border: 2px solid rgba(201, 164, 74, 0.55) !important;
  border-radius: 0.25rem;
  min-width: 1.125rem;
  min-height: 1.125rem;
  vertical-align: middle;
  cursor: pointer;
}

form#survey-form .glass-card input[type="checkbox"].survey-checkbox:focus,
form#survey-form .glass-card input[type="checkbox"].survey-checkbox:focus-visible,
form#survey-form .glass-card input[type="checkbox"]:focus,
form#survey-form .glass-card input[type="checkbox"]:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(201, 164, 74, 0.45) !important;
}

form#survey-form .glass-card input[type="checkbox"].survey-checkbox:checked,
form#survey-form .glass-card input[type="checkbox"]:checked {
  border-color: var(--accent-gold) !important;
}

form#survey-form .viol-row:has(input[type="checkbox"]:checked) {
  background: rgba(201, 164, 74, 0.14);
  border-radius: 0.75rem;
  padding: 0.5rem 0.5rem 0.5rem 0.25rem;
  margin-inline: -0.25rem;
  border: 1px solid rgba(201, 164, 74, 0.22);
}
