@charset "UTF-8";
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  /* Backgrounds */
  --bg-dark: #111111;
  --bg-darker: #0a0a0a;
  --card-bg: #1a1a1a;
  --card-border: #2a2a2a;
  --card-hover: #222222;
  /* White scale */
  --white: #ffffff;
  --white-90: rgba(255,255,255,0.9);
  --white-70: rgba(255,255,255,0.7);
  --white-40: rgba(255,255,255,0.4);
  --white-20: rgba(255,255,255,0.2);
  --white-10: rgba(255,255,255,0.1);
  --white-06: rgba(255,255,255,0.06);
  /* Primary — Red */
  --red: #d42e2e;
  --red-hover: #e04040;
  --red-10: rgba(212,46,46,0.1);
  --red-15: rgba(212,46,46,0.15);
  --red-glow: rgba(212,46,46,0.15);
  --red-dark: #111111;
  /* Legacy aliases (some pages still reference --lime) */
  --lime: var(--red);
  --lime-hover: var(--red-hover);
  --lime-dark: var(--white);
  --lime-10: var(--red-10);
  --lime-15: var(--red-15);
  /* Accents */
  --cyan: #44d9ee;
  --cyan-10: rgba(68,217,238,0.1);
  --orange: #ee9a44;
  --orange-10: rgba(238,154,68,0.1);
  --yellow: #f5a623;
  --green: #34c759;
  /* Status */
  --success: #44ee6c;
  --success-15: rgba(68,238,108,0.15);
  --warning: #eec844;
  --warning-15: rgba(238,200,68,0.15);
  --error: #ff4d4d;
  --info: #60a5fa;
  /* Typography */
  --font-display: 'Barlow Condensed', sans-serif;
  --font-body: 'DM Sans', sans-serif;
  /* Misc */
  --radius: 4px;
}

.button-container {
  text-align: center;
}
.button-container A {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
}

.register-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 8px;
  width: 100%;
  max-width: 500px;
  padding: 3rem 2.5rem;
}
.register-card .card-header {
  margin-bottom: 2rem;
}
.register-card .card-header h1 {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--white);
  margin-bottom: 0.5rem;
  line-height: 1;
}
.register-card .card-header p {
  color: var(--white-70);
  font-size: 0.9rem;
  line-height: 1.5;
}
.register-card .form-row {
  display: flex;
  gap: 1rem;
}
.register-card .form-row .form-group {
  flex: 1;
}
.register-card .form-group {
  margin-bottom: 1.15rem;
}
.register-card .form-group label {
  display: block;
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
  color: var(--white-70);
}
.register-card .form-group input, .register-card .form-group select {
  width: 100%;
  height: 3rem;
  border: 1px solid var(--card-border);
  border-radius: var(--radius);
  padding: 0 1rem;
  font-family: var(--font-body);
  font-size: 0.9rem;
  background: var(--white-06);
  color: var(--white);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.register-card .form-group input::placeholder, .register-card .form-group select::placeholder {
  color: var(--white-40);
}
.register-card .form-group input:focus, .register-card .form-group select:focus {
  outline: none;
  border-color: var(--lime);
  box-shadow: 0 0 0 2px rgba(212, 46, 46, 0.15);
}
.register-card .form-group select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.4)' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  padding-right: 2rem;
}
.register-card .form-group select option {
  background: var(--card-bg);
  color: var(--white);
}
.register-card .form-group .hint {
  font-size: 0.78rem;
  color: var(--white-40);
  margin-top: 0.35rem;
}
.register-card .checkbox-group {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
  font-size: 0.85rem;
  color: var(--white-70);
}
.register-card .checkbox-group input[type=checkbox] {
  width: 1rem;
  height: 1rem;
  margin-top: 0.15rem;
  accent-color: var(--lime);
  flex-shrink: 0;
}
.register-card .checkbox-group a {
  color: var(--lime);
  text-decoration: none;
  font-weight: 500;
}
.register-card .checkbox-group a:hover {
  text-decoration: underline;
}
.register-card .divider {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1.75rem 0;
  color: var(--white-40);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.register-card .divider::before, .register-card .divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--card-border);
}
.register-card .social-buttons {
  display: flex;
  gap: 0.75rem;
}
.register-card .social-buttons button {
  flex: 1;
  height: 3rem;
  border: 1px solid var(--card-border);
  border-radius: var(--radius);
  background: var(--white-06);
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--white);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  transition: background 0.2s, border-color 0.2s;
}
.register-card .social-buttons button:hover {
  background: var(--white-10);
  border-color: var(--white-40);
}
.register-card .social-buttons button svg {
  width: 18px;
  height: 18px;
}
.register-card .card-footer {
  text-align: center;
  margin-top: 2rem;
  font-size: 0.9rem;
  color: var(--white-70);
}
.register-card .card-footer a {
  color: var(--lime);
  font-weight: 600;
  text-decoration: none;
}
.register-card .card-footer a:hover {
  text-decoration: underline;
}

@media (max-width: 640px) {
  .top-bar {
    display: none;
  }
  .site-header {
    padding: 0 1rem;
  }
  .site-header nav {
    display: none;
  }
  .register-card {
    padding: 2rem 1.5rem;
  }
  .register-card .form-row {
    flex-direction: column;
    gap: 0;
  }
}

/*# sourceMappingURL=registrazione.css.map */
