/* File: assets/css/components/forms.css */
/* Forms (system). */

.dag-form{
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
  border:1px solid var(--dag-border);
  border-radius:var(--dag-radius);
  padding:var(--dag-gap);
}

/* Form grid used on car-single */
.dag-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:var(--dag-gap);
}
@media (max-width:720px){
  .dag-grid{grid-template-columns:1fr}
}

.dag-field{display:flex;flex-direction:column;gap:6px}
.dag-field--full{grid-column:1 / -1}

.dag-field label{
  font-size:14px;
  font-weight:700;
  color:var(--dag-text);
}

/* Base control styles (theme-wide) */
:where(input[type='text'],input[type='email'],input[type='tel'],input[type='url'],input[type='number'],input[type='search'],input[type='password'],textarea,select){
  width:100%;
  max-width:100%;
  min-height:44px;
  padding:.66rem .82rem;
  border:1px solid var(--dag-border);
  border-radius:var(--dag-radius-sm);
  background:var(--dag-surface-2);
  color:var(--dag-text);
  transition:border-color var(--dag-transition), box-shadow var(--dag-transition), background var(--dag-transition);
}

:where(textarea){min-height:120px;resize:vertical}
:where(input::placeholder,textarea::placeholder){color:rgba(229,231,235,.62)}

:where(input:focus-visible,textarea:focus-visible,select:focus-visible){
  border-color:rgba(96,165,250,.55);
  box-shadow:var(--dag-ring);
}

:where(select){
  appearance:none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(229,231,235,.72) 50%),
    linear-gradient(135deg, rgba(229,231,235,.72) 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position:
    calc(100% - 18px) calc(1.1em + 2px),
    calc(100% - 13px) calc(1.1em + 2px),
    calc(100% - 2.6em) .6em;
  background-size:5px 5px, 5px 5px, 1px 1.6em;
  background-repeat:no-repeat;
  padding-right:2.6em;
}

/* Checkbox row */
.dag-check{display:flex;align-items:center;gap:10px;color:var(--dag-text)}
.dag-check input[type="checkbox"]{accent-color:var(--dag-primary)}

/* Errors (matches your DOM: .dag-field__error) */
.dag-field__error{
  margin:6px 0 0;
  font-size:12px;
  color:#fecaca;
}
.dag-field__error[hidden]{display:none}

/* Alert bar on car form */
.car-form-alert{
  margin:0 0 12px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(96,165,250,.22);
  background:rgba(96,165,250,.10);
  color:var(--dag-text);
  box-shadow:var(--dag-shadow-xs);
}
.car-form-alert[hidden]{display:none}

/* Hide honeypot */
.dag-form input[name="dag_hp"],
.dag-hp{display:none !important}

/* Phone input group (+1 prefix + tel) (Home) */
.dag-phone-wrap{
  display:flex;
  align-items:stretch;
  gap:0;
  border:1px solid var(--dag-border);
  border-radius:var(--dag-radius-sm);
  overflow:hidden;
  background:var(--dag-surface-2);
  box-shadow:var(--dag-shadow-xs);
}

.dag-phone-prefix{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 12px;
  min-width:46px;
  font-weight:900;
  color:var(--dag-muted);
  background:rgba(255,255,255,.04);
  border-right:1px solid var(--dag-border);
  user-select:none;
}

.dag-phone-wrap input{
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  min-height:44px;
}
.dag-phone-wrap:focus-within{
  border-color:rgba(96,165,250,.55);
  box-shadow:var(--dag-ring);
}

/* Char counters (Home) */
.char-counter{
  display:inline-block;
  margin-top:6px;
  font-size:12px;
  color:var(--dag-muted);
}

/* Home contact layout (rows/fields) */
.home-contact__row{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:var(--dag-gap);
  margin-top:var(--dag-gap);
}
.home-contact__row--full{grid-template-columns:1fr}
.home-contact__row--inline{
  grid-template-columns:1fr;
  margin-top:12px;
}
@media (max-width: 900px){
  .home-contact__row{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
@media (max-width: 640px){
  .home-contact__row{grid-template-columns:1fr}
}

/* Home checkbox row */
.home-contact__checkbox{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:700;
  color:var(--dag-text);
}
.home-contact__checkbox input{accent-color:var(--dag-primary)}

/* Home contact actions */
.home-contact__actions{
  margin-top:14px;
  display:flex;
  justify-content:flex-start;
}