﻿/* ========== FORM SYSTEM (REUSABLE) ========== */
:root{--form-bg:var(--surface, #fff);--form-border:color-mix(in srgb, var(--primary-700) 35%, #fff);--form-text:var(--text-primary, #111);--form-muted:color-mix(in srgb, var(--form-text) 65%, #fff);--form-radius:14px;--form-gap:clamp(.75rem,2vw,1.25rem);--form-pad:clamp(1rem,2.5vw,1.5rem);--form-shadow:0 10px 25px rgba(0,0,0,.08);--form-ring:0 0 0 3px color-mix(in srgb, var(--primary-700) 28%, transparent);}

.myFORM{width:100%;max-width:72rem;margin:0 auto;color:var(--form-text);}
.myFORM *{box-sizing:border-box;}
.myFORM.noJS{visibility:hidden;} /* keep your behavior if you still toggle this elsewhere */

.form-card{background:var(--form-bg);border:1px solid var(--form-border);border-radius:var(--form-radius);box-shadow:var(--form-shadow);padding:var(--form-pad);}
.form-section{padding:var(--form-pad);border-radius:calc(var(--form-radius) - 4px);background:color-mix(in srgb, var(--form-bg) 92%, var(--primary-700) 8%);}
.form-section + .form-section{margin-top:var(--form-gap);}
.form-title{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.6rem;margin:0 0 2rem 0;font-size:clamp(1.2rem,2vw,1.5rem);font-weight:800;}
.form-subtitle{margin:0 0 1rem 0;color:var(--form-muted);line-height:1.5;}

.form-grid{display:grid;grid-template-columns:1fr;gap:var(--form-gap);}
@media(min-width:820px){.form-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(min-width:1100px){.form-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr));}}
.field{display:grid;gap:.35rem;min-width:0;}
.field.full{grid-column:1/-1;}

.label{font-size:.95rem;font-weight:700;line-height:1.2;}
.hint{font-size:.88rem;color:var(--form-muted);line-height:1.4;}
.req{color:color-mix(in srgb, #d00 70%, var(--form-text));font-weight:800;margin-left:.25rem;}

.control{appearance:none;-webkit-appearance:none;width:100%;min-width:0;padding:.65rem .8rem;border:1px solid var(--form-border);border-radius:12px;background:#fff;color:var(--form-text);line-height:1.2;transition:border-color .15s ease, box-shadow .15s ease, transform .05s ease;}
.control:focus{outline:0;border-color:color-mix(in srgb, var(--primary-700) 70%, #fff);box-shadow:var(--form-ring);}
.control::placeholder{color:color-mix(in srgb, var(--form-muted) 75%, #fff);}



textarea.control{min-height:7.5rem;resize:vertical;}

.checkbox{display:flex;gap:.65rem;align-items:flex-start;line-height:1.35;}
.checkbox input{width:20px;height:20px;margin-top:.1rem;accent-color:var(--primary-700);}
.checkbox .label{font-weight:800;margin:0;}
.checkbox .hint{margin:.1rem 0 0 0;}

.form-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:flex-start;margin-top:var(--form-gap);}
.form-actions .cta_button{max-width:180px;margin:0 auto;}
.form-actions .secondary{border:1px solid var(--form-border);background:transparent;color:var(--primary-700);}
.form-actions .secondary:hover{background:color-mix(in srgb, var(--primary-700) 8%, #fff);}

.alert{padding:.85rem 1rem;line-height:1.5;}
.alert strong{color:#b00000;}

.invalid-feedback{display:none;font-size:.88rem;color:#b00000;line-height:1.25;}
.field.is-invalid .invalid-feedback{display:block;}
.field.is-invalid .control{border-color:color-mix(in srgb, #d00 55%, #fff);box-shadow:0 0 0 3px color-mix(in srgb, #d00 18%, transparent);}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* Optional: tighten your existing “half” legacy so old forms don’t look broken */
.half{width:100%;float:none;display:block;margin:0;}
.clear{display:block;clear:both;}

.form-grid{align-items:start;}
.field{align-self:start;}

.sms-optin{margin-top:.75rem;width:100%;}
.sms-label{display:grid;grid-template-columns:20px 1fr;gap:.6rem;align-items:start;justify-items:start;font-weight:700;color:var(--primary-700);}
.sms-label input{width:20px;height:20px;margin:0;accent-color:var(--primary-700);}
.sms-title{display:block;text-align:left;line-height:1.25;}
.sms-copy{margin:.35rem 0 0 1.65rem;font-size:.95rem;line-height:1.5;color:#333;}


/* Keep your placeholder fade behavior if you still want it */
::-webkit-input-placeholder{opacity:1;transition:opacity .35s;}
::-moz-placeholder{opacity:1;transition:opacity .35s;}
:-ms-input-placeholder{opacity:1;transition:opacity .35s;}
::placeholder{opacity:1;transition:opacity .35s;}
*:focus::-webkit-input-placeholder{opacity:0;}
*:focus::-moz-placeholder{opacity:0;}
*:focus:-ms-input-placeholder{opacity:0;}
*:focus::placeholder{opacity:0;}

/* Datepicker positioning + stacking */
.field{position:relative;}
.form-section,.form-card{overflow:visible;} /* important if anything was clipping */
.datepicker-dropdown{z-index:999999;}

/* Optional: keep popup from stretching weird */
.datepicker{width:auto;max-width:calc(100vw - 2rem);}

.inline-row{display:grid;grid-template-columns:minmax(0,1fr) 9rem;gap:.75rem;align-items:start;}
@media(max-width:520px){.inline-row{grid-template-columns:1fr;}}

/* keep the select arrow working inside inline rows */
.inline-select{margin:0;gap:0;}


/* VIN help button */
.vin-help{
  all:unset;                 /* remove native button styling */
  display:inline-flex;
  align-items:center;
  justify-content:left;
  cursor:pointer;
  margin-left:0;
  line-height:1;
}

.vin-help i{
  font-size:1.7rem;
  color:var(--primary-700);
}

.vin-help:hover i{
  color:color-mix(in srgb, var(--primary-700) 75%, #000);
}

.vin-help:focus-visible{
  outline:2px solid var(--primary-700);
  outline-offset:2px;
  border-radius:50%;
}

/* caption under VIN */
.vin-caption{margin:.35rem 0 0 0;font-size:.9rem;line-height:1.35;}

.vin-help-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  align-items:start;
}

.vin-help-layout img{
  width:100%;
  height:auto;
  display:block;
}

.special_contact{overflow:hidden;transition:height .28s ease;}
.special_contact.hidden{display:none;}

.field select.invalid{border-color:var(--danger);box-shadow:0 0 0 3px color-mix(in srgb, var(--danger) 20%, transparent);}
.field.is-invalid select{border-color:var(--danger);box-shadow:0 0 0 3px color-mix(in srgb, var(--danger) 20%, transparent);}



/* Mobile: stack nicely */
@media (max-width: 640px){
  .vin-help-layout{
    grid-template-columns:1fr;
  }
}

#vinHelp{
  overflow:hidden;
  height:0;
  transition:height .35s ease;
}

/* Optional: spacing when open */
#vinHelp.is-open{
  margin-top:1rem;
}


/* layout when visible */
.referral-group{display:grid;gap:var(--form-gap);}

/* ALWAYS wins for the same element */
.referral-group.hidden{display:none !important;}


#dpCTRL button {
    background:var(--primary-700);
    font-size: 1em;
    padding: 0 0.2em;
    border-radius: 0;
    min-width: 50px;
    cursor: pointer;
    color: var(--text-on-primary);
    font-weight: 700;
}
.datepicker-picker span{color:var(--primary-700)}

.datepicker-cell:not(.disabled):hover {
    background-color:var(--primary-100);
    cursor: pointer;
}


/* SELECT ARROW (single system - wrapper) */
.field.is-select:after{content:none;}
.control-wrap{position:relative;}
.control-wrap:after {
    content: "";
    position: absolute;
    right: 1.05rem;
    top: 50%;
    transform: translateY(-100%);
    width: 1rem;
    height: .5rem;
    background: var(--primary-700);
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    pointer-events: none;
    opacity: .9;
}
select.control{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:none;padding-right:3rem;}


/* base: point RIGHT */
.control-wrap:after{transform:translateY(-100%) rotate(-90deg);transform-origin:center;transition:transform .18s ease;}

/* when user clicks/tabs into the select: rotate DOWN */
.field.is-select:focus-within .control-wrap:after{transform:translateY(-100%) rotate(0deg);}

p#recaptcha {
    font-size: var(--fs-compact);
    text-align: center;
    line-height: 1.5;
    margin-block: 2rem;
}