/* Brand: Dark navy + vivid green accents reminiscent of S3 example */
:root{
  --bg:#202737;           /* deep navy */
  --bg-2:#172634;         /* lighter panel navy */
  --text:#e6eef6;
  --muted:#a3b1c0;
  --primary:#00C542;      /* vivid green */
  --primary-700:#009e35;  /* darker green for hover states */
  --card:#1a2838;
  --border:#2a3d52;
  --shadow:0 10px 20px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
/* Avoid percentage heights that some CDNs/minifiers mis-handle */
/* html,body{height:100%} */
body{
  margin:0; font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; color:var(--text); background:linear-gradient(180deg,var(--bg),#0a141c 60%); line-height:1.6;
}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}
.sr-only{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}

/* Header */
.site-header{position:sticky;top:0;z-index:20;background:rgba(10,20,28,.85);backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid var(--border)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;gap:10px;align-items:center;color:var(--text);text-decoration:none;font-weight:700;letter-spacing:.12em}
.brand .brand-mark{display:grid;place-items:center;height:28px;width:28px;border-radius:7px;background:var(--primary);color:#061218;font-weight:900}
.brand .brand-text{opacity:.9}
.brand .brand-img{display:block;max-height:40px;max-width:300px;height:auto}
.main-nav a{color:var(--muted);margin-left:22px;text-decoration:none}
.main-nav a:hover{color:var(--text)}

/* Buttons */
.btn{appearance:none;border:1px solid transparent;border-radius:999px;padding:10px 16px;font-weight:600;cursor:pointer;transition:.2s;}
.btn-primary{background:linear-gradient(90deg,var(--primary),#4df08b);color:#07131b;box-shadow:0 6px 18px rgba(46,230,107,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(46,230,107,.35)}
.btn-ghost{border-color:var(--border);color:var(--text);background:transparent}
.btn-ghost:hover{background:#122231}
.icon-btn{background:transparent;border:0;color:var(--muted);font-size:20px;cursor:pointer}

/* Hero */
.hero{padding:72px 0 40px;background:radial-gradient(1100px 500px at 25% -50%, rgba(46,230,107,.25), transparent 60%), linear-gradient(180deg,#172634 0%,transparent 60%)}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
.hero h1{font-size:48px;line-height:1.1;margin:.1em 0 .2em;letter-spacing:.02em}
.hero p{color:var(--muted);max-width:56ch}
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;transform:rotate(-12deg);filter:drop-shadow(0 14px 24px rgba(0,0,0,.5))}
.tile{height:110px;border-radius:10px;background:linear-gradient(180deg,#2a3f52,#0f1b25);border:1px solid #2b4055}
@media (max-width:900px){.hero .wrap{grid-template-columns:1fr}.tile-grid{transform:none}}

/* Sections */
.eyebrow{color:var(--primary);text-transform:uppercase;letter-spacing:.2em;font-weight:700;font-size:12px;margin:56px 0 8px}
.about h3{margin:.2em 0 10px;font-size:28px}

/* Jobs */
.jobs .section-head{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between}
.filters{display:flex;gap:10px}
.filters input, .filters select{background:#0f1b25;border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:10px;outline:0;min-width:220px}
.job-list{list-style:none;margin:24px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:900px){.job-list{grid-template-columns:1fr}}
.job-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s,border-color .2s}
.job-card:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(0,0,0,.45);border-color:#3a5066}
.job-card .job-meta{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;margin-bottom:12px}
.job-card .badge{background:rgba(0,197,66,.12);color:#00ff5e;border:1px solid rgba(0,197,66,.3);padding:6px 12px;border-radius:999px;font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase}
.job-card .dot{height:4px;width:4px;border-radius:50%;background:#4d6881;display:inline-block}
.job-card .title{margin:.6em 0 .4em;font-size:22px;font-weight:700;line-height:1.3;color:var(--text)}
.job-card .summary{color:var(--muted);margin:.2em 0 18px;line-height:1.6;font-size:14px}
.job-actions{display:flex;gap:12px;margin-top:auto}

/* Benefits */
.benefit-grid{list-style:none;padding:0;margin:18px 0;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.benefit-grid li{background:#0f1b25;border:1px solid var(--border);border-radius:12px;padding:16px}
.benefit-grid h4{margin:.2em 0}
@media (max-width:900px){.benefit-grid{grid-template-columns:1fr 1fr}}

/* Footer */
.site-footer{border-top:1px solid var(--border);margin:64px 0 0;padding:28px 0;color:var(--muted)}
.site-footer .small-link{color:var(--primary)}

/* Dialogs */
dialog{border:0;border-radius:20px;padding:0;background:transparent}
dialog::backdrop{background:rgba(2,10,16,.75);backdrop-filter:blur(4px)}
/* Use pixel-based max-height for broad parser compatibility */
dialog article{background:var(--card);border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,0,0,.5);padding:0;border-radius:20px;max-width:840px;display:flex;flex-direction:column;max-height:740px;overflow:hidden}
dialog article header, dialog article footer{padding:20px 24px;border-bottom:1px solid var(--border);background:var(--bg-2)}
dialog article footer{border-bottom:0;border-top:1px solid var(--border);position:sticky;bottom:0;z-index:2}
dialog article header{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:2}
dialog article header h3{font-size:24px;margin:0;font-weight:700;color:var(--text)}
dialog article #dialog-body{padding:24px;color:var(--muted);overflow-y:auto;flex:1 1 auto;min-height:0}
dialog article #dialog-body h4{color:var(--text);margin:24px 0 14px;font-size:18px;font-weight:700}
dialog article #dialog-body p{margin:0 0 16px;color:#c5d3e1;line-height:1.75;font-size:15px}
dialog article #dialog-body .job-req-list{margin:0 0 20px 20px;padding-left:20px;color:#d0dce8;list-style:disc}
dialog article #dialog-body .job-req-list.job-req-list--numbered{list-style:decimal}
dialog article #dialog-body .job-req-list li{margin-bottom:10px;line-height:1.6;padding-left:6px}
dialog article #dialog-body .job-section{margin:0 0 28px;padding:0 0 20px;border-bottom:1px solid rgba(42,61,82,.5)}
dialog article #dialog-body .job-section:last-of-type{border-bottom:0;padding-bottom:0;margin-bottom:0}
dialog article #dialog-body .job-section h4{margin:0 0 16px;font-size:16px;color:#00ff5e;letter-spacing:.08em;text-transform:uppercase;font-weight:700}
dialog article #dialog-body .job-section--description p{color:#d0dce8}
dialog article #dialog-body .job-meta-grid{margin:0;display:grid;gap:14px 20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
dialog article #dialog-body .job-meta-grid div{background:rgba(15,27,37,.8);border:1px solid rgba(42,61,82,.8);border-radius:14px;padding:16px 18px;transition:background .2s}
dialog article #dialog-body .job-meta-grid div:hover{background:rgba(20,32,42,.9)}
dialog article #dialog-body .job-meta-grid dt{margin:0 0 8px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}
dialog article #dialog-body .job-meta-grid dd{margin:0;color:var(--text);font-weight:600;font-size:16px}

/* Enhanced Apply modal */
#apply-modal article header h3{color:var(--text)}
dialog article h4.form-section-title{margin:20px 20px 12px;color:#00ff5e;font-size:13px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding-bottom:8px;border-bottom:1px solid rgba(42,61,82,.4)}
#apply-form{padding:0 20px 12px;flex:1 1 auto;overflow:auto}
#apply-form fieldset{border:1px solid rgba(42,61,82,.7);border-radius:14px;padding:14px 16px;margin:10px 0;background:rgba(15,27,37,.5)}
#apply-form legend{padding:0 6px;color:var(--text);font-weight:600}
#apply-form .options{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
#apply-form .options label{position:relative;display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);padding:10px 14px 10px 38px;border-radius:999px;color:var(--text);transition:border-color .15s, background .15s;cursor:pointer}
/* Visually hide the native control but keep it accessible */
#apply-form .options label input{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;margin:0;opacity:0;cursor:pointer}
/* Custom radio ring */
#apply-form .options label::before{content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;border:2px solid #3d556b;background:transparent;box-sizing:border-box;transition:border-color .15s, background .15s, box-shadow .15s}
/* Custom radio inner dot (hidden by default) */
#apply-form .options label::after{content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--primary);opacity:0;transition:opacity .15s}
#apply-form .options label:hover{border-color:#2f4152}
#apply-form .options label:has(input:checked){background:rgba(0,197,66,.18);border-color:var(--primary)}
/* When checked, highlight the ring and show inner dot */
#apply-form .options label:has(input:checked)::before{border-color:var(--primary)}
#apply-form .options label:has(input:checked)::after{opacity:1}
/* JS fallback mirrors :has() by toggling .is-checked */
#apply-form .options label.is-checked{background:rgba(0,197,66,.18);border-color:var(--primary)}
#apply-form .options label.is-checked::before{border-color:var(--primary)}
#apply-form .options label.is-checked::after{opacity:1}
#apply-form .options label:focus-within{outline:2px solid rgba(0,197,66,.35);outline-offset:2px}
#apply-form .muted{color:var(--muted);font-weight:400}

/* Form */
#apply-form .grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:8px}
#apply-form label{display:flex;flex-direction:column;gap:8px;font-size:14px;color:#b8c8d8;font-weight:500}
#apply-form input:not([type="radio"]):not([type="checkbox"]), #apply-form textarea{background:rgba(15,27,37,.7);border:1px solid rgba(42,61,82,.8);color:var(--text);padding:12px 14px;border-radius:12px;transition:border-color .2s,background .2s}
#apply-form input[type="radio"], #apply-form input[type="checkbox"]{appearance:auto;-webkit-appearance:auto;accent-color:var(--primary);background:transparent;border:0}
#apply-form input::placeholder, #apply-form textarea::placeholder{color:var(--muted);opacity:.8}
#apply-form input:focus-visible, #apply-form textarea:focus-visible{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(0,197,66,.25)}
#apply-form textarea{min-height:120px}
#apply-form .full{grid-column:1/-1}
#apply-form menu{display:flex;justify-content:flex-end;gap:12px;padding:14px 0 0}

@media (max-width: 760px){
  #apply-form .grid{grid-template-columns:1fr}
  #apply-form .options{gap:8px}
}
.success{color:#8ff1b9}
.hidden{display:none}

/* LinkedIn Import Styles */
.linkedin-import-section{
  padding:16px 20px 18px;
  border-bottom:1px solid rgba(42,61,82,.6);
  margin-bottom:16px;
  background:rgba(15,27,37,.4);
}
.btn-linkedin{
  background:linear-gradient(135deg,#0a7fbf,#0095d9);
  color:#ffffff;
  border:1px solid rgba(0,149,217,.4);
  display:flex;
  align-items:center;
  gap:8px;
  box-shadow:0 4px 12px rgba(0,119,181,.2);
}
.btn-linkedin:hover{
  background:linear-gradient(135deg,#085f93,#0077b5);
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(0,119,181,.4);
}
.btn-linkedin svg{
  flex-shrink:0;
}
.btn-sm{
  padding:6px 12px;
  font-size:12px;
}
.linkedin-preview{
  display:flex;
  align-items:center;
  gap:12px;
  margin-top:12px;
  padding:12px;
  background:rgba(0,119,181,.1);
  border:1px solid rgba(0,119,181,.3);
  border-radius:12px;
}
.profile-photo{
  width:48px;
  height:48px;
  border-radius:50%;
  object-fit:cover;
  border:2px solid var(--border);
}
.profile-info{
  flex:1;
  min-width:0;
}
.profile-name{
  font-weight:600;
  color:var(--text);
  font-size:14px;
}
.profile-title{
  color:var(--muted);
  font-size:12px;
  margin-top:2px;
}
