/* ═══════════════════════════════════════════════════════════
   CHAMPCHASE — CONTACT PAGE STYLES    Only loaded on contact.html. Uses shared.css tokens only.
   ═══════════════════════════════════════════════════════════ */

/* Section title + subtitle (mirrors beta.css pattern) */
.stitle{font-size:clamp(16px,3.5vw,26px);text-align:center;margin-bottom:8px;letter-spacing:2px}
.ssub{text-align:center;color:rgba(255,255,255,.65);font-size:15px;margin-bottom:36px}

/* ═══ HERO LANE CHIPS ═══ */
.lane-chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.lane-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg3);border:1px solid var(--dg);border-radius:20px;font-family:var(--dp);font-size:13px;letter-spacing:2px;color:var(--w2)}
.lane-chip-dot{width:8px;height:8px;border-radius:50%;background:var(--g);display:inline-block}
.lane-chip-dot.gold{background:var(--gold);box-shadow:0 0 8px var(--gold-g)}
.lane-chip-dot.cherry{background:var(--cherry-l);box-shadow:0 0 8px var(--cherry-g)}

/* ═══ FORM WRAP ═══ */
.contact-wrap{max-width:640px;margin:0 auto;position:relative;z-index:2}

/* ═══ TABS ═══ */
.contact-tabs{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;margin-bottom:20px;border-bottom:1px solid var(--dg);padding-bottom:0}
.contact-tab{background:none;border:none;color:var(--g);font-family:var(--dp);font-size:14px;letter-spacing:2px;padding:12px 16px;cursor:pointer;transition:color .2s var(--ease);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}
.contact-tab:hover{color:var(--w)}
.contact-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.contact-tab:focus-visible{outline:2px solid var(--gold);outline-offset:-2px}

/* ═══ ERROR SUMMARY ═══ */
.contact-error-summary{background:rgba(185,28,28,.08);border:1px solid var(--cherry);border-left:3px solid var(--cherry-l);color:var(--w);padding:12px 16px;border-radius:3px;margin-bottom:16px;font-size:13px;line-height:1.5}
.contact-error-summary strong{color:var(--cherry-l);display:block;margin-bottom:4px;letter-spacing:1px;font-size:11px;font-family:var(--px)}
.contact-error-summary ul{list-style:none;padding:0;margin:6px 0 0}
.contact-error-summary li{padding:2px 0}
.contact-error-summary a{color:var(--gold);text-decoration:underline}

/* ═══ FIELDS ═══ */
.contact-form{display:flex;flex-direction:column;gap:14px}

.field-group{display:flex;flex-direction:column;gap:6px}
.field-group[hidden]{display:none !important}

.field-label{font-family:var(--dp);font-size:14px;letter-spacing:2px;color:var(--w);display:flex;align-items:baseline;gap:10px;justify-content:space-between;flex-wrap:wrap}
.field-label-text{display:none}
.field-label-text[data-label-for]{display:none}
.field-req{font-family:var(--bd);font-size:11px;letter-spacing:1px;color:var(--cherry-l);text-transform:uppercase;font-weight:700}
.field-req.field-req-opt{color:var(--g);font-weight:400;text-transform:none;letter-spacing:normal;font-style:italic}
.field-req[hidden]{display:none !important}

/* ═══ INPUTS ═══ */
.contact-input{background:var(--bg3);border:1px solid var(--dg);color:var(--w);padding:12px 16px;border-radius:3px;font-family:var(--bd);font-size:15px;transition:border-color .2s var(--ease),box-shadow .2s;width:100%}
.contact-input:focus{border-color:var(--cherry);box-shadow:0 0 12px var(--cherry-g);outline:none}
.contact-input:focus-visible{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold),0 0 12px var(--gold-g);outline:none}
.contact-input::placeholder{color:var(--g)}
.contact-input[aria-invalid="true"]{border-color:var(--cherry-l);box-shadow:0 0 0 2px rgba(185,28,28,.2)}

.contact-textarea{resize:vertical;min-height:120px;line-height:1.5;font-family:var(--bd)}

.contact-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239CA3AF' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}

/* ═══ FIELD ERROR TEXT ═══ */
.field-err{font-size:12px;color:var(--cherry-l);line-height:1.4;min-height:0;transition:min-height .15s ease}
.field-err:not(:empty){min-height:16px;padding:2px 0}

/* ═══ CHECKBOX ═══ */
.field-group-check{margin-top:4px}
/* align-items center + max-width cleans up the previously awkward
   flex-start wrap. Text now reads as one tidy line on desktop, wraps cleanly
   beside the centered checkbox on narrow mobile. */
.contact-check-label{display:flex;gap:10px;align-items:center;cursor:pointer;color:var(--w2);font-size:13px;line-height:1.5;max-width:480px}
.contact-check{accent-color:var(--cherry);cursor:pointer;flex-shrink:0;width:16px;height:16px}

/* ═══ HONEYPOT ═══ */
.honeypot{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* ═══ SUBMIT ═══ */
.contact-actions{margin-top:8px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.contact-submit{min-width:200px}
.contact-submit:disabled{opacity:.45;cursor:not-allowed;animation:none}
.contact-submit:disabled:hover{transform:none;box-shadow:none;background:var(--cherry)}
.contact-submit-note{font-size:11px;color:var(--g);margin:0;letter-spacing:1px;font-family:var(--dp);transition:color .2s}
.contact-submit-note.ready{color:var(--gold)}

/* ═══ CONFIRMATION PANEL ═══ */
.contact-confirm{background:var(--bg2);border:1px solid var(--gold-d);border-left:4px solid var(--gold);padding:32px 28px;border-radius:4px;max-width:640px;margin:0 auto;box-shadow:0 0 40px var(--gold-g);text-align:center;animation:confirmIn .5s var(--bounce)}
@keyframes confirmIn{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.contact-confirm-body{font-size:15px;color:var(--w2);line-height:1.6;max-width:500px;margin:0 auto}

/* ═══ MOBILE ═══ */
@media(max-width:640px){
  .contact-tabs{overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:0;gap:0}
  .contact-tabs::-webkit-scrollbar{display:none}
  .contact-tab{padding:12px 14px;font-size:13px;flex-shrink:0}
  .contact-confirm{padding:24px 20px}
}

@media(max-width:480px){
  .field-label{font-size:13px}
  .contact-input{font-size:15px;padding:11px 14px}
  .lane-chip{font-size:11px;padding:6px 10px}
  .lane-chip-dot{width:6px;height:6px}
}
