/* =========================================================
   HIRE FROM ELLEN
   File: /assets/css/hire-from-ellen.css
   ========================================================= */

:root{
  --hire-radius: 22px;
  --hire-border: rgba(15,23,42,.10);
  --hire-muted: #64748b;
}

/* Header merge spacing (your site uses --site-header-offset) */
.hire.page-hero{
  background:#fff;
  color:#0f172a;
  padding-top: calc(var(--site-header-offset, 110px) + 34px);
  padding-bottom: 22px;
}

.hire.page-section{
  background:#fff;
  padding: 22px 0 70px;
}

/* breadcrumb (matches your existing pattern) */
.breadcrumb{
  font-size: 13px;
  color: var(--hire-muted);
  font-weight: 700;
  display:flex;
  align-items:center;
  gap: 8px;
  margin: 6px 0 18px;
}
.breadcrumb a{ color: var(--hire-muted); text-decoration:none; }
.breadcrumb a:hover{ color:#0f172a; }
.crumb-sep{ opacity:.6; }

.hire-hero{ max-width: 900px; }
.hire-kicker{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  color:#111827;
  opacity:.92;
  margin:0 0 10px;
}
.hire-kickerIco{
  width: 28px;
  height: 28px;
  border-radius: 12px;
  border: 1px solid rgba(250,57,74,.22);
  background: rgba(250,57,74,.10);
  display:grid;
  place-items:center;
}

.hire-title{
  margin:0 0 10px;
  font-size: 36px;
  line-height: 1.12;
  letter-spacing: -0.02em;
}
.hire-lead{
  margin:0;
  font-size: 14px;
  line-height: 1.75;
  color:#4b5563;
  max-width: 75ch;
}

.hire-wrap{
  display:grid;
  grid-template-columns: 1fr 340px;
  gap: 18px;
  align-items:start;
}

.hire-card{
  border: 1px solid var(--hire-border);
  border-radius: var(--hire-radius);
  background:#fff;
  box-shadow: 0 16px 46px rgba(15,23,42,.08);
  padding: 16px;
}

.hire-alert{
  border-radius: 16px;
  padding: 12px 14px;
  font-weight: 800;
  font-size: 13px;
  margin-bottom: 12px;
}
.hire-alert--success{
  border: 1px solid rgba(34,197,94,.25);
  background: rgba(34,197,94,.07);
  color: #166534;
}
.hire-alert--error{
  border: 1px solid rgba(153,27,27,.25);
  background: rgba(153,27,27,.06);
  color: #991b1b;
}

.hire-sectionHead{
  margin-bottom: 10px;
}
.hire-sectionHead h2{
  margin:0 0 4px;
  font-size: 16px;
  font-weight: 900;
}
.hire-sectionHead p{
  margin:0;
  font-size: 13px;
  color: var(--hire-muted);
  line-height: 1.6;
}

.hire-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.hire-field label{
  display:block;
  font-size: 12px;
  font-weight: 900;
  color:#0f172a;
  margin-bottom: 6px;
}
.hire-field input,
.hire-field select,
.hire-field textarea{
  width:100%;
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 14px;
  padding: 11px 12px;
  font-size: 14px;
  outline: none;
  background:#fff;
  color:#0f172a;
}
.hire-field textarea{ resize: vertical; min-height: 110px; }

.hire-field input:focus,
.hire-field select:focus,
.hire-field textarea:focus{
  border-color: rgba(250,57,74,.28);
  box-shadow: 0 0 0 4px rgba(250,57,74,.10);
}

.hire-field--wide{
  grid-column: 1 / -1;
}

.hire-divider{
  height: 1px;
  background: rgba(15,23,42,.10);
  margin: 14px 0;
}

.hire-radioRow{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.hire-radio{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(2,6,23,.02);
  padding: 10px 12px;
  border-radius: 999px;
  cursor: pointer;
  user-select: none;
}
.hire-radio input{ width:auto; }

.hire-check{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  margin-top: 12px;
  font-size: 13px;
  color:#0f172a;
  line-height: 1.5;
}
.hire-check input{ margin-top: 3px; }

.hire-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.hire-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 13px;
  text-decoration:none;
  border: 1px solid transparent;
  cursor: pointer;
}

.hire-btn--primary{
  background: linear-gradient(135deg, #ff445e, #ff6a2a);
  color: #fff;
  box-shadow: 0 16px 38px rgba(250,57,74,.22);
}
.hire-btn--primary:hover{ filter: brightness(.98); }

.hire-btn--ghost{
  background: #ffffff;
  border-color: rgba(15,23,42,.14);
  color: #111827;
}
.hire-btn--ghost:hover{ background: #f9fafb; }

.hire-footnote{
  margin: 10px 0 0;
  font-size: 12px;
  color: var(--hire-muted);
  line-height: 1.6;
}

/* Sidebar */
.hire-sideCard{
  border: 1px solid var(--hire-border);
  border-radius: var(--hire-radius);
  background:#fff;
  box-shadow: 0 16px 46px rgba(15,23,42,.08);
  overflow:hidden;
  position: sticky;
  top: calc(var(--site-header-offset, 110px) + 18px);
}
.hire-sideHead{
  padding: 14px;
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.hire-sideHead b{
  display:block;
  font-size: 14px;
  font-weight: 900;
}
.hire-sideHead span{
  display:block;
  margin-top: 2px;
  font-size: 12px;
  font-weight: 700;
  color: var(--hire-muted);
}
.hire-sideBody{ padding: 14px; }

.hire-point{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(2,6,23,.02);
  margin-bottom: 10px;
}
.hire-ico{ width: 28px; display:inline-flex; justify-content:center; }
.hire-point b{
  display:block;
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 4px;
}
.hire-point p{
  margin:0;
  font-size: 13px;
  line-height: 1.6;
  color:#4b5563;
}

.hire-sideCta{
  margin-top: 10px;
  display:inline-flex;
  width: 100%;
  justify-content:center;
  align-items:center;
  gap: 10px;
  height: 44px;
  border-radius: 999px;
  background: rgba(250,57,74,.10);
  border: 1px solid rgba(250,57,74,.25);
  color: #111827;
  font-weight: 900;
  text-decoration:none;
}
.hire-sideCta:hover{ filter: brightness(.98); }

/* Responsive */
@media (max-width: 980px){
  .hire-wrap{ grid-template-columns: 1fr; }
  .hire-sideCard{ position: static; }
}
@media (max-width: 640px){
  .hire-title{ font-size: 28px; }
  .hire-grid{ grid-template-columns: 1fr; }
  .hire-actions .hire-btn{ width: 100%; }
}



/* =========================================================
   Hire – Inline Alerts (Success / Error)
   ========================================================= */

.hire-alert{
  padding:14px 18px;
  border-radius:14px;
  font-size:14px;
  font-weight:600;
  margin-bottom:18px;
  border:1px solid transparent;
}

.hire-alert--success{
  background: rgba(34,197,94,.08);
  border-color: rgba(34,197,94,.25);
  color:#166534;
}

.hire-alert--error{
  background: rgba(239,68,68,.08);
  border-color: rgba(239,68,68,.25);
  color:#991b1b;
}

/* Inline messages below button */
.hire-inlineSuccess,
.hire-inlineError{
  margin-top:14px;
  padding:12px 16px;
  border-radius:12px;
  font-size:14px;
  font-weight:600;
  line-height:1.5;
  animation: hireFadeIn .35s ease;
}

.hire-inlineSuccess{
  background: linear-gradient(
    135deg,
    rgba(34,197,94,.08),
    rgba(16,185,129,.05)
  );
  border:1px solid rgba(34,197,94,.25);
  color:#166534;
}

.hire-inlineError{
  background: linear-gradient(
    135deg,
    rgba(239,68,68,.08),
    rgba(220,38,38,.05)
  );
  border:1px solid rgba(239,68,68,.25);
  color:#991b1b;
}

/* Smooth appearance */
@keyframes hireFadeIn{
  from{
    opacity:0;
    transform: translateY(6px);
  }
  to{
    opacity:1;
    transform: translateY(0);
  }
}