/* :root {
  --primary-color: #4a90e2;
  --secondary-color: #50e3c2;
  --background-color: #f5f9ff;
  --text-color: #333;
  --gradient-background: linear-gradient(135deg, #00f7ff75 0%, #e726e14e 100%);
  --glass-bg: rgba(255, 255, 255, 0.72);
  --backdrop: blur(12px);
  --container-bg: var(--glass-bg);
  --primary: #156c7e;
  --accent: #19c3a8;
  --primary-button: #007800;
  --primary-button-hover: #009b00;
  --primary-button-focus: #007800;
  --secondry-button: #0e71c8;
  --secondry-button-hover: #1984e1;
  --secondry-button-focus: #1579d1;
  --error: #cc3c3c;
  --success: #1ca67d;
  --input-bg: rgba(242, 247, 251, 0.85);
  --input-border: #ccc;
  --input-border-focus: #2670e7;
  --details-bg: linear-gradient(115deg, #e6f7ff 80%, #f2eaff 100%);
  --shadow-main: 0 8px 40px 0px rgba(38, 112, 231, 0.14), 0 1.5px 14px 0px rgba(38, 112, 231, 0.07);
  --transition-fast: 0.21s cubic-bezier(.4, 1.07, .47, 1.01);
} */

html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
  font-family: 'Inter', 'Poppins', Arial, sans-serif;
  /* background: var(--gradient-background); */
  background-color: var(--background);
  min-height: 100vh;
}

body {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  width: 100vw;
}

.container {
  background: var(--background-color);
  border-radius: 1.9em;
  /* box-shadow: var(--shadow-main); */
  width: 100%;
  max-width: 550px;
  /* padding: clamp(1.6em, 7vw, 2.7em) clamp(1.2em, 9vw, 2.6em); */
  padding: 3rem 2.5rem;
  box-sizing: border-box;
  margin: 24px 20px;
  display: flex;
  flex-direction: column;
  position: relative;
  backdrop-filter: var(--backdrop);
  /* border: 1.5px solid rgba(38, 112, 231, 0.07); */
  animation: floatup 0.9s cubic-bezier(.4, 1.07, .47, 1.01) 1;
  min-height: 400px;
  max-height: 90vh;
  overflow: auto;
  user-select: none;
}

@keyframes floatup {
  0% {
    opacity: 0;
    transform: translateY(30px) scale(.96);
  }

  100% {
    opacity: 1;
    transform: translateY(0px) scale(1);
  }
}

h2 {
  font-size: clamp(1.23em, 3vw, 1.65em);
  font-family: 'Poppins', 'Inter', Arial, sans-serif;
  font-weight: 700;
  margin-bottom: 1em;
  letter-spacing: .06em;
  color: var(--primary-color);
  text-align: center;
  text-shadow: 0 4px 18px #b4e2ff2b;
  animation: fadein 1.2s cubic-bezier(.46, 1.61, .53, .98) 1;
}

@keyframes fadein {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

form {
  display: flex;
  flex-direction: column;
  gap: 0px;
  animation: fadein 1.5s;
}

label {
  font-weight: normal;
  color: var(--primary);
  margin-bottom: .34em;
  font-size: clamp(0.98em, 2vw, 1.04em);
  font-family: 'Poppins', 'Inter', Arial, sans-serif;
  letter-spacing: 0.01em;
  display: block;
}

.form-group {
  display: flex;
  flex-direction: column;
  margin-bottom: 0px;
}

input[type="text"],
input[type="tel"],
input[type="number"],
input[type="email"],
select {
  padding: clamp(0.8em, 3vw, 1em) 1em;
  border: 2px solid var(--input-border);
  border-radius: .72em;
  font-size: clamp(1em, 2vw, 1.12em);
  background: transparent;
  transition: border var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  width: 100%;
  margin-bottom: 2px;
  box-sizing: border-box;
  outline: none;
  box-shadow: 0 1px 7px rgba(38, 112, 231, 0.08);
}

input:focus {
  border-color: var(--input-border-focus);
  /* background: #e3f4ff; */
  /* box-shadow: 0 2.5px 13px rgba(38, 112, 231, 0.14); */
}

input.invalid {
  border-color: var(--error);
  background: #fff2f2;
  box-shadow: 0 2px 11px rgba(204, 60, 60, 0.08);
}

input.valid {
  border-color: var(--success);
  background: #f2fcf7;
}

.error-text,
.success-text {
  font-size: clamp(0.89em, 1.6vw, 1.01em);
  min-height: 18px;
  letter-spacing: 0.01em;
  transition: color var(--transition-fast);
}

.error-text {
  color: var(--error);
  margin-bottom: 6px;
}

.success-text {
  color: var(--success);
  margin-bottom: 6px;
}

.submit-btn {
  margin-top: 10px;
  background: var(--primary-color);
  color: #fff;
  border: none;
  padding: clamp(0.8em, 2vw, 1.05em) 0;
  border-radius: .72em;
  font-size: clamp(1em, 2vw, 1.22em);
  font-weight: 600;
  cursor: pointer;
  font-family: 'Poppins', 'Inter', Arial, sans-serif;
  transition: background var(--transition-fast), box-shadow var(--transition-fast), transform .19s;
  box-shadow: 0 2px 12px 0px #2670e71f;
  margin-bottom: 13px;
  position: relative;
  overflow: hidden;
}

.submit-btn:hover {
  background: var(--secondary-color);
  transform: scale(1.04) translateY(-2.5px);
  box-shadow: 0 7px 18px rgba(38, 112, 231, 0.17);
}

.submit-btn:active {
  background: var(--primary-color);
}

.submit-btn:disabled {
  opacity: 0.6;
  pointer-events: none;
}

/* Loader overlay with blur */
.loader-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 100;
  background: rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(8px);
}

.loader {
  width: 50px;
  height: 50px;
  border: 4px solid #def1f7;
  border-top: 4px solid #2670e7;
  border-radius: 50%;
  animation: spin 0.95s linear infinite;
  background: none;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

.msg {
  text-align: center;
  margin: 10px 0 9px 0;
  color: var(--error);
  font-weight: 500;
  min-height: 22px;
  font-size: clamp(1.03em, 2vw, 1.19em);
  word-break: break-word;
  letter-spacing: 0.01em;
}

.details-panel {
  background: var(--background-color);
  border-radius: 13px;
  /* box-shadow: 0 8px 34px rgba(170, 230, 255, 0.11); */
  margin-top: 0em;
  padding: clamp(1.3em, 3vw, 1.7em) clamp(1em, 2vw, 1.45em);
  display: flex;
  flex-direction: column;
  gap: 13px;
  font-size: clamp(1.02em, 2vw, 1.13em);
  /* border: 1.1px solid #e2ebf3; */
  position: relative;
  opacity: 0.97;
  animation: floatup 1.1s;
}

.details-label {
  font-weight: 600;
  color: var(--primary);
  min-width: 100px;
  padding-right: .4em;
  letter-spacing: 0.04em;
  font-family: 'Poppins', 'Inter', Arial, sans-serif;
  font-size: clamp(0.98em, 1.8vw, 1.09em);
  word-break: break-word;
  text-shadow: 0 2px 8px #93e6f030;
}

.details-value {
  color: #09586f;
  word-break: break-word;
  font-size: clamp(0.96em, 1.8vw, 1em);
  text-shadow: 0 2px 8px #b5eaff26;
}

.logout-btn {
  background: var(--logout-btn);
  color: #fff;
  border: none;
  padding: clamp(0.7em, 2vw, 1em) 0;
  border-radius: .65em;
  font-size: clamp(1em, 2vw, 1.13em);
  font-weight: 600;
  cursor: pointer;
  font-family: 'Poppins', 'Inter', Arial, sans-serif;
  transition: background var(--transition-fast), box-shadow var(--transition-fast);
  box-shadow: 0 2px 9px rgba(38, 112, 231, 0.10);
  margin-top: 10px;
  margin-bottom: 12px;
  width: 100%;
}

.logout-btn:hover {
  background: var(--secondary-color);
  /* box-shadow: 0 5px 14px #2670e72f; */
}

/* Table */
.details-panel table {
  width: 100%;
  border-collapse: collapse;
  font-size: clamp(1em, 2vw, 1.1em);
}

.details-panel tr {
  border-bottom: 1px solid #e2ebf3;
}

.details-panel tr th {
  text-align: left;
  padding: 8px;
  color: var(--secondary);
  font-weight: 600;
  min-width: 130px;
}

.details-panel tr td {
  padding: 8px;
  color: var(--text-color);
}

.details-panel h3 {
  color: var(--primary-color);
}



@media (max-width: 900px) {
  .container {
    /* max-width: 92vw; */
    border-radius: 1em;
    /* padding: 2em 6vw 1.5em 6vw; */
    padding: 3rem 2.5rem;
  }
}

@media (max-width: 700px) {
  .container {
    /* max-width: 99vw; */
    /* padding: 1.1em 4vw 1em 4vw; */
    padding: 3rem 2.5rem;
    border-radius: .77em;
  }

  h2 {
    font-size: clamp(1.09em, 4vw, 1.11em);
  }

  .details-label {
    font-size: clamp(0.87em, 2vw, 0.97em);
    min-width: 76px;
  }

  .details-panel {
    padding: 0.93em 2vw 0.7em 2vw;
  }

  .from-group,
  input[type="text"] {
    margin-bottom: 7px;
  }
}

@media (max-width:400px) {
  .container {
    /* padding: 4px 1vw 2px; */
    padding: 3rem 2.5rem;
  }


  .details-panel {
    padding: 0.5em 1vw 0.3em 1vw;
  }

  label,
  input[type="text"] {
    font-size: clamp(0.87em, 2vw, 0.95em);
  }

  form {
    gap: 0px;
  }
}

@media (max-width: 340px) {
  .details-label {
    min-width: 56px;
  }

  .details-panel {
    font-size: 0.50em;
  }
}