/* ELEME(NT) NET. — Broker Application Landing
   Single-page, conversion-focused. Brand-manual aligned. */

body{background:var(--beige)}

/* ---------- LAYOUT ---------- */
.apply-shell{min-height:100vh;display:flex;flex-direction:column}
.apply-section{padding:80px 64px;position:relative}
.apply-container{max-width:1200px;margin:0 auto}

/* ---------- HEADER ---------- */
.apply-bar{
  position:sticky;top:0;z-index:50;
  background:var(--burgundy);color:var(--beige);
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 24px;height:52px;
}
.apply-bar .left img{height:22px;width:auto;display:block}
.apply-bar .right{
  display:flex;align-items:center;gap:18px;
  font-family:var(--f-display);
  font-size:10px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;
}
.apply-bar .pulse{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--yellow);
}
.apply-bar .pulse-dot{
  width:6px;height:6px;border-radius:50%;background:var(--yellow);
  animation:pulse 1.6s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(249,176,1,.7);opacity:1}
  50%{box-shadow:0 0 0 8px rgba(249,176,1,0);opacity:.7}
}

/* ---------- HERO ---------- */
.apply-hero{
  background:
    linear-gradient(135deg, rgba(91,9,9,.92), rgba(0,0,0,.96)),
    radial-gradient(ellipse at 70% 30%, #7a1414 0%, #3d0606 55%, #000 100%);
  color:var(--beige);
  position:relative;overflow:hidden;
  padding:96px 64px;
}
.apply-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 1000px 500px at 80% 20%, rgba(255,255,255,.1), transparent 60%),
    radial-gradient(ellipse 700px 800px at 10% 80%, rgba(0,0,0,.5), transparent 60%);
  pointer-events:none;
}
.apply-hero .hero-deco{
  position:absolute;right:-80px;bottom:-100px;
  opacity:.12;color:var(--beige);pointer-events:none;
}
.apply-hero .grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;
}
.apply-hero .marker{
  font-family:var(--f-display);
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:rgba(233,224,217,.6);font-weight:700;margin-bottom:24px;
  display:inline-flex;align-items:center;gap:10px;
}
.apply-hero h1{
  font-family:var(--f-display);
  font-weight:900;font-size:80px;line-height:.94;letter-spacing:-3px;
  text-transform:uppercase;
}
.apply-hero h1 em{font-style:normal;font-weight:400;color:rgba(233,224,217,.65)}
.apply-hero .lede{
  margin-top:28px;font-size:17px;line-height:1.65;
  color:rgba(233,224,217,.85);max-width:520px;
}
.apply-hero .meta-row{
  margin-top:36px;display:flex;gap:32px;flex-wrap:wrap;
  font-family:var(--f-display);
}
.apply-hero .meta-row .m .v{
  font-weight:900;font-size:32px;letter-spacing:-1px;
  color:var(--yellow);line-height:1;
}
.apply-hero .meta-row .m .l{
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(233,224,217,.6);font-weight:700;margin-top:8px;
}

/* ---------- FORM CARD ---------- */
.apply-card{
  background:var(--beige);
  border-radius:12px;
  padding:20px 18px;
  max-width:420px;
  margin-left:auto;
  box-shadow:0 24px 80px rgba(0,0,0,.4);
  position:relative;
  /* Slides in from the right on first scroll */
  opacity:0;
  transform:translateX(80px);
  transition: opacity 1s ease-out,
              transform 1.1s cubic-bezier(.16,1,.3,1);
  will-change: opacity, transform;
}
body.scrolled-once .apply-card{
  opacity:1;
  transform:none;
}
@media (prefers-reduced-motion: reduce){
  .apply-card{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
}
.apply-card .form-head{margin-bottom:12px;text-align:center}
.apply-card .form-head .badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:999px;
  background:rgba(91,9,9,.08);
  font-family:var(--f-display);font-size:9px;letter-spacing:1.6px;
  text-transform:uppercase;color:var(--burgundy);font-weight:700;
  margin-bottom:8px;
}
.apply-card .form-head h2{
  font-family:var(--f-display);
  font-weight:900;font-size:18px;color:var(--burgundy);
  text-transform:uppercase;letter-spacing:-.4px;line-height:1;
}
.apply-card .form-head p{
  margin-top:5px;color:var(--text-dim);font-size:11.5px;
}
.apply-card form{display:flex;flex-direction:column;gap:8px}
.apply-card .row2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.apply-card .form-group{margin:0}
.apply-card label{
  font-size:9px;letter-spacing:1.3px;margin-bottom:4px;
}
.apply-card input,
.apply-card select,
.apply-card textarea{
  background:#fff;border:1px solid var(--border);
  font-size:12.5px;padding:7px 10px;
}
.apply-card textarea{min-height:54px;line-height:1.4}
.apply-card .submit-btn{
  width:100%;padding:11px 20px;
  font-size:11.5px;letter-spacing:1.3px;
  margin-top:2px;
  position:relative;
  z-index:1;
}
/* Pulsating attention ring — radiates outward from the button continuously */
.apply-card .submit-btn::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  box-shadow:0 0 0 0 rgba(91,9,9,.55);
  animation: apply-pulse 1.8s ease-out infinite;
  z-index:-1;
}
@keyframes apply-pulse{
  0%   { box-shadow: 0 0 0 0   rgba(91,9,9,.55); }
  70%  { box-shadow: 0 0 0 16px rgba(91,9,9,0); }
  100% { box-shadow: 0 0 0 0   rgba(91,9,9,0); }
}
/* Stop pulsing while submitting or after success */
.apply-card .submit-btn:disabled::before,
.apply-card.submitted .submit-btn::before{
  animation:none;
  box-shadow:none;
}
@media (prefers-reduced-motion: reduce){
  .apply-card .submit-btn::before{ animation:none; }
}
.apply-card .fineprint{
  font-size:10px;color:var(--text-mute);text-align:center;
  margin-top:4px;line-height:1.4;
}

/* ---------- SUCCESS STATE ---------- */
.apply-success{
  display:none;text-align:center;padding:32px 16px 16px;
}
.apply-success.show{display:block}
.apply-card.submitted form{display:none}
.apply-card.submitted .form-head{display:none}
.apply-success .check{
  display:inline-flex;width:64px;height:64px;border-radius:50%;
  background:var(--burgundy);color:var(--beige);
  align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:34px;font-weight:900;
  margin-bottom:22px;
}
.apply-success h2{
  font-family:var(--f-display);
  font-weight:900;font-size:30px;color:var(--burgundy);
  text-transform:uppercase;letter-spacing:-.6px;margin-bottom:10px;
}
.apply-success p{color:var(--text-dim);font-size:14px;line-height:1.6;max-width:340px;margin:0 auto 24px}
.apply-success .ref{
  font-family:var(--f-mono);font-size:11px;
  background:rgba(91,9,9,.06);padding:8px 14px;border-radius:6px;
  color:var(--burgundy);display:inline-block;
}

/* ---------- WHY JOIN SECTION ---------- */
.apply-why{background:var(--beige)}
.apply-why .head{text-align:center;max-width:760px;margin:0 auto 56px}
.apply-why .marker{
  font-family:var(--f-display);font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--text-mute);font-weight:700;margin-bottom:14px;
}
.apply-why h2{
  font-family:var(--f-display);
  font-weight:900;font-size:54px;line-height:.98;letter-spacing:-2px;
  text-transform:uppercase;color:var(--burgundy);
}
.apply-why h2 em{font-style:normal;font-weight:400;color:var(--text-dim)}
.apply-why .grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.why-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:32px 28px;
  position:relative;
}
.why-card .num{
  font-family:var(--f-display);font-weight:900;font-size:36px;
  color:var(--burgundy);letter-spacing:-1px;line-height:1;margin-bottom:18px;
}
.why-card h3{
  font-family:var(--f-display);font-weight:900;font-size:18px;
  text-transform:uppercase;color:var(--text);letter-spacing:-.3px;
  margin-bottom:10px;
}
.why-card p{font-size:13.5px;line-height:1.65;color:var(--text-dim)}

/* ---------- TIMELINE / WHAT HAPPENS NEXT ---------- */
.apply-next{
  background:#000;color:var(--beige);
  position:relative;overflow:hidden;
}
.apply-next::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 1200px 700px at 50% -10%, rgba(91,9,9,.5), transparent 60%);
}
.apply-next .head{position:relative;z-index:2;text-align:center;max-width:760px;margin:0 auto 56px}
.apply-next .marker{
  font-family:var(--f-display);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:rgba(233,224,217,.6);font-weight:700;margin-bottom:14px;
}
.apply-next h2{
  font-family:var(--f-display);
  font-weight:900;font-size:54px;line-height:.98;letter-spacing:-2px;
  text-transform:uppercase;color:var(--beige);
}
.apply-next h2 em{font-style:normal;font-weight:400;color:var(--yellow)}
.apply-next .steps{
  position:relative;z-index:2;
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.next-step{
  border-left:2px solid var(--yellow);
  padding:14px 22px;
}
.next-step .num{
  font-family:var(--f-display);font-weight:900;font-size:44px;
  color:var(--yellow);line-height:1;letter-spacing:-1.5px;margin-bottom:14px;
}
.next-step h4{
  font-family:var(--f-display);font-weight:900;font-size:15px;
  text-transform:uppercase;color:var(--beige);margin-bottom:8px;letter-spacing:-.2px;
}
.next-step p{font-size:13px;line-height:1.6;color:rgba(233,224,217,.75)}
.next-step .when{
  display:inline-block;
  font-family:var(--f-display);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--yellow);font-weight:700;
  margin-top:10px;
}

/* ---------- FAQ ---------- */
.apply-faq{background:var(--beige-warm)}
.apply-faq .head{text-align:center;max-width:680px;margin:0 auto 48px}
.apply-faq .marker{
  font-family:var(--f-display);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:var(--text-mute);font-weight:700;margin-bottom:14px;
}
.apply-faq h2{
  font-family:var(--f-display);
  font-weight:900;font-size:48px;line-height:1;letter-spacing:-1.5px;
  text-transform:uppercase;color:var(--burgundy);
}
.apply-faq .list{max-width:780px;margin:0 auto}
.faq-item{
  background:#fff;
  border:1px solid var(--border);
  border-radius:10px;
  padding:22px 26px;margin-bottom:10px;
}
.faq-item summary{
  cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--f-display);font-weight:900;font-size:15px;
  color:var(--text);text-transform:uppercase;letter-spacing:-.2px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';font-family:var(--f-display);font-weight:400;
  color:var(--burgundy);font-size:24px;line-height:1;transition:transform .2s;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .body{
  margin-top:14px;color:var(--text-dim);font-size:14px;line-height:1.65;
}

/* ---------- FINAL CTA ---------- */
.apply-final{
  background:var(--burgundy);color:var(--beige);
  position:relative;overflow:hidden;text-align:center;
  padding:96px 64px;
}
.apply-final::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 900px 500px at 50% 0%, rgba(255,255,255,.08), transparent 60%);
}
.apply-final .container{position:relative;z-index:2}
.apply-final h2{
  font-family:var(--f-display);font-weight:900;font-size:72px;line-height:.96;
  letter-spacing:-2.5px;text-transform:uppercase;color:var(--beige);margin-bottom:18px;
}
.apply-final h2 em{font-style:normal;font-weight:400;color:var(--yellow)}
.apply-final p{font-size:17px;color:rgba(233,224,217,.82);max-width:540px;margin:0 auto 36px;line-height:1.6}
.apply-final .btn-light{
  background:var(--beige);color:var(--burgundy);border-color:var(--beige);
  padding:16px 32px;font-size:13px;
}
.apply-final .btn-light:hover{background:#fff;border-color:#fff}
.apply-final .foot{
  margin-top:64px;padding-top:24px;border-top:1px solid rgba(233,224,217,.15);
  font-family:var(--f-display);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:rgba(233,224,217,.5);font-weight:700;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
}

/* ────────────────────────────────────────────────────────────
   RESPONSIVE
   - 900px : tablet — stack hero, single-column grids
   - 640px : phone  — phone-tuned sizing, iOS zoom fix, tap targets
   - 380px : tiny phones (older iPhone SE, foldable inner displays)
   ──────────────────────────────────────────────────────────── */

/* ===== TABLET (≤900px) ===== */
@media (max-width:900px){
  .apply-section{padding:56px 24px}
  .apply-hero{padding:64px 24px}
  .apply-hero .grid{grid-template-columns:1fr;gap:32px}
  .apply-hero h1{font-size:48px}
  .apply-hero .meta-row{gap:24px}
  .apply-hero .meta-row .m .v{font-size:24px}
  .apply-card{
    padding:24px 20px;
    margin:0 auto; /* center on stacked layout (was right-aligned for desktop split) */
  }
  .apply-card .row2{grid-template-columns:1fr}
  .apply-why h2,.apply-next h2,.apply-faq h2,.apply-final h2{font-size:36px}
  .apply-why .grid{grid-template-columns:1fr}
  .apply-next .steps{grid-template-columns:1fr}
}

/* ===== PHONE (≤640px) ===== */
@media (max-width:640px){
  /* Top bar — drop the "View Full Proposal" link, keep logo + pulse */
  .apply-bar{padding:8px 16px;height:48px}
  .apply-bar .left img{height:18px}
  .apply-bar .right{gap:0;font-size:9px;letter-spacing:1.5px}
  .apply-bar .right a{display:none}     /* hide secondary link on phones */
  .apply-bar .pulse{font-size:9px}

  /* Hero — much smaller padding + headline */
  .apply-hero{padding:48px 18px}
  .apply-hero .grid{gap:28px}
  .apply-hero .marker{font-size:10px;letter-spacing:2.2px;margin-bottom:18px}
  .apply-hero h1{font-size:36px;letter-spacing:-1.5px;line-height:1}
  .apply-hero .lede{font-size:15px;margin-top:18px;line-height:1.55}
  .apply-hero .meta-row{margin-top:24px;gap:16px 22px}
  .apply-hero .meta-row .m .v{font-size:22px}
  .apply-hero .meta-row .m .l{font-size:9px;margin-top:5px;letter-spacing:1.5px}

  /* Form card — full width, centered, iOS zoom-fix (16px inputs) */
  .apply-card{
    padding:22px 18px;
    max-width:none;
    border-radius:14px;
  }
  .apply-card .form-head h2{font-size:20px}
  .apply-card .form-head p{font-size:12px;margin-top:6px}
  .apply-card .form-head .badge{font-size:9.5px;padding:5px 11px}
  .apply-card label{font-size:10px;margin-bottom:5px;letter-spacing:1.3px}
  /* CRITICAL: 16px prevents iOS Safari from zooming when a field is focused */
  .apply-card input,
  .apply-card select,
  .apply-card textarea{
    font-size:16px;
    padding:11px 12px;
    border-radius:8px;
  }
  .apply-card textarea{min-height:80px}
  .apply-card form{gap:11px}
  /* Big tappable submit (≥44px tall — Apple HIG minimum) */
  .apply-card .submit-btn{
    padding:15px 24px;
    font-size:13px;
    letter-spacing:1.5px;
    margin-top:6px;
    border-radius:10px;
  }
  .apply-card .fineprint{font-size:11px;line-height:1.5;margin-top:8px}

  /* Sections — tighter padding + smaller heads */
  .apply-section{padding:48px 18px}
  .apply-why .head, .apply-next .head, .apply-faq .head{margin:0 auto 32px}
  .apply-why h2,.apply-next h2,.apply-faq h2{font-size:30px;letter-spacing:-1px}
  .apply-why .marker, .apply-next .marker, .apply-faq .marker{
    font-size:10px;letter-spacing:2.2px;margin-bottom:10px;
  }

  /* Why cards */
  .why-card{padding:24px 22px}
  .why-card .num{font-size:30px;margin-bottom:12px}
  .why-card h3{font-size:16px}
  .why-card p{font-size:13px;line-height:1.55}

  /* Timeline — smaller numbers + tighter spacing */
  .next-step{padding:10px 18px}
  .next-step .num{font-size:36px;margin-bottom:10px}
  .next-step h4{font-size:14px}
  .next-step p{font-size:12.5px;line-height:1.55}
  .next-step .when{font-size:9.5px;margin-top:8px}

  /* FAQ — tappable rows */
  .faq-item{padding:18px 20px;border-radius:12px}
  .faq-item summary{font-size:13.5px;letter-spacing:-.1px}
  .faq-item summary::after{font-size:22px}
  .faq-item .body{font-size:13px;margin-top:12px;line-height:1.6}

  /* Final CTA */
  .apply-final{padding:64px 18px}
  .apply-final h2{font-size:34px;letter-spacing:-1.2px;margin-bottom:14px}
  .apply-final p{font-size:14.5px;margin-bottom:24px;line-height:1.55}
  .apply-final .btn-light{padding:15px 26px;font-size:12.5px;border-radius:10px;width:100%;max-width:320px}
  .apply-final .foot{
    margin-top:40px;padding-top:18px;font-size:9px;letter-spacing:1.8px;
    flex-direction:column;gap:8px;text-align:center;
  }

  /* Success state */
  .apply-success{padding:24px 12px 12px}
  .apply-success .check{width:56px;height:56px;font-size:30px;margin-bottom:18px}
  .apply-success h2{font-size:24px}
  .apply-success p{font-size:13.5px}
}

/* ===== TINY PHONES (≤380px — older SE, foldables) ===== */
@media (max-width:380px){
  .apply-hero h1{font-size:30px}
  .apply-hero .lede{font-size:14px}
  .apply-hero .meta-row{gap:14px 18px}
  .apply-hero .meta-row .m .v{font-size:19px}
  .apply-why h2,.apply-next h2,.apply-faq h2{font-size:26px}
  .apply-final h2{font-size:28px}
  .apply-card{padding:20px 16px}
  .faq-item{padding:16px 18px}
}
