/* 
=============================================================
|  Tred-Mark Communications | Developed by Javorsky Studio  |
|   Viewing File: ~/public-site/assets/css/pages/apply.css  |
| ---  Styling/CSS for `~/public-site/apply/index.html  --- |
============================================================= 
*/

.page-apply{
  min-height:100vh;
  color:var(--text);
  background:#070a12;
}

.page-apply::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  background:url("/assets/media/apply/page-bg.webp") center/cover no-repeat;
}

.page-apply::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(7,10,18,.7), rgba(7,10,18,.96)),
    linear-gradient(90deg, rgba(7,10,18,.5), rgba(12,24,42,.76));
}

/* =========================================================
   Page Shell
   ========================================================= */

.apply-page{
  width:min(1180px, calc(100% - 2rem));
  margin:0 auto;
  padding:clamp(6rem, 10vw, 9rem) 0 var(--space-7);
}

/* =========================================================
   Shared Cards
   ========================================================= */

.apply-hero,
.apply-info-card,
.application-section{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:rgba(7,10,18,.78);
  box-shadow:0 24px 80px rgba(0,0,0,.3);
  backdrop-filter:blur(16px);
}

/* =========================================================
   Hero
   ========================================================= */

.apply-hero{
  padding:clamp(2rem, 6vw, 5rem);
  background:
    linear-gradient(135deg, rgba(7,10,18,.88), rgba(12,24,42,.72)),
    radial-gradient(circle at 85% 10%, rgba(76,183,255,.26), transparent 36%);
}

.apply-hero .eyebrow,
.section-heading p{
  margin:0 0 .6rem;
  color:var(--accent);
  font-size:.78rem;
  font-weight:850;
  letter-spacing:.17em;
  text-transform:uppercase;
}

.apply-hero h1{
  max-width:850px;
  margin:0;
  padding-bottom:.15em;
  font-size:clamp(2.6rem, 7vw, 5.5rem);
  line-height:.96;
  letter-spacing:-.07em;
  color:transparent;
  background:linear-gradient(90deg, #fff, #7de3ff 55%, #8a5cff);
  background-clip:text;
}

.apply-hero > p:last-child{
  max-width:780px;
  margin:1.25rem 0 0;
  color:var(--muted);
  font-size:clamp(1rem, 1.6vw, 1.2rem);
  line-height:1.7;
}

/* =========================================================
   Intro Cards
   ========================================================= */

.apply-intro-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:var(--space-4);
  margin:var(--space-4) 0;
}

.apply-info-card{
  padding:clamp(1.4rem, 3vw, 2.25rem);
}

.apply-info-card h2{
  margin:0 0 1.2rem;
  font-size:clamp(1.5rem, 3vw, 2.2rem);
}

.role-card{
  padding:1rem 0;
  border-top:1px solid rgba(255,255,255,.1);
}

.role-card h3{
  margin:0 0 .35rem;
  color:#fff;
}

.role-card p{
  margin:0;
  color:var(--muted);
  line-height:1.6;
}

/* =========================================================
   Benefits
   ========================================================= */

.benefits-list{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:.75rem;
  margin:0;
  padding:0;
  list-style:none;
}

.benefits-list li{
  padding:.8rem 1rem;
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  background:rgba(255,255,255,.04);
}

/* =========================================================
   Application Form
   ========================================================= */

.application-form{
  display:grid;
  gap:var(--space-4);
}

.application-section{
  padding:clamp(1.4rem, 4vw, 2.75rem);
}

.section-heading{
  display:flex;
  align-items:flex-start;
  gap:1rem;
  margin-bottom:1.6rem;
}

.section-heading > span{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  flex:0 0 42px;
  border:1px solid rgba(125,227,255,.35);
  border-radius:50%;
  color:var(--accent);
  font-weight:850;
}

.section-heading h2{
  margin:0;
  font-size:clamp(1.55rem, 3vw, 2.4rem);
  letter-spacing:-.04em;
}

.section-heading p{
  margin-bottom:.25rem;
}

/* =========================================================
   Form Grid
   ========================================================= */

.application-grid{
  display:grid;
  gap:1rem;
}

.application-grid.two-col{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.application-grid .full-width{
  grid-column:1 / -1;
}

/* =========================================================
   Fields
   ========================================================= */

.application-form label{
  display:grid;
  gap:.45rem;
  color:var(--text);
  font-size:.9rem;
  font-weight:750;
}

.application-form input,
.application-form select,
.application-form textarea{
  width:100%;
  padding:.9rem 1rem;
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  background:rgba(255,255,255,.055);
  color:var(--text);
  font:inherit;
  outline:none;
  transition:.18s ease;
}

.application-form input:focus,
.application-form select:focus,
.application-form textarea:focus{
  border-color:rgba(125,227,255,.72);
  box-shadow:0 0 0 4px rgba(125,227,255,.11);
  background:rgba(255,255,255,.075);
}

.application-form select option{
  color:#07101d;
}

.application-form textarea{
  resize:vertical;
}

.application-form small{
  color:var(--muted);
  font-weight:500;
}

/* =========================================================
   File Upload
   ========================================================= */

.application-form input[type="file"]{
  padding:.7rem;
}

.application-form input[type="file"]::file-selector-button{
  margin-right:.8rem;
  padding:.55rem .8rem;
  border:0;
  border-radius:9px;
  background:rgba(125,227,255,.14);
  color:var(--text);
  font-weight:750;
  cursor:pointer;
}

/* =========================================================
   Certification Checkbox
   ========================================================= */

.certification-check{
  grid-template-columns:auto 1fr !important;
  align-items:start !important;
  margin:1.5rem 0 1rem;
  padding:1rem;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(255,255,255,.035);
  line-height:1.55;
}

.certification-check input{
  width:18px;
  height:18px;
  margin:.18rem 0 0;
}

/* =========================================================
   Submit + Status
   ========================================================= */

.application-notice{
  color:var(--muted);
  font-size:.88rem;
  line-height:1.6;
}

.application-submit{
  min-width:220px;
  margin-top:.5rem;
}

.application-submit:disabled{
  opacity:.55;
  cursor:wait;
}

.form-status{
  min-height:1.5rem;
  margin:.8rem 0 0;
}

.form-status.is-pending{
  color:var(--accent);
}

.form-status.is-success{
  color:#67e08a;
}

.form-status.is-error{
  color:#ff8f8f;
}

/* =========================================================
   Honeypot
   ========================================================= */

.form-honeypot{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

/* =========================================================
   Responsive
   ========================================================= */

@media(max-width:800px){

  .apply-intro-grid,
  .application-grid.two-col{
    grid-template-columns:1fr;
  }

  .application-grid .full-width{
    grid-column:auto;
  }

  .benefits-list{
    grid-template-columns:1fr;
  }

  .apply-page{
    padding-top:6rem;
  }

  .application-submit{
    width:100%;
  }
}

@media(max-width:480px){

  .apply-page{
    width:calc(100% - 1rem);
  }

  .apply-hero,
  .application-section,
  .apply-info-card{
    padding:1.2rem;
  }

  .section-heading{
    gap:.7rem;
  }

  .section-heading > span{
    width:36px;
    height:36px;
    flex-basis:36px;
  }
}