/* ═══════════════════════════════════════════════════════════════
   ATS Resume Checker — standalone styles
   Self-contained: does NOT depend on /css/style.css.
   Scoped under #ats-app so it won't leak into any host page.
═══════════════════════════════════════════════════════════════ */

/* ---------- design tokens (scoped) ---------- */
#ats-app{
  --ats-bg:        #ffffff;
  --ats-bg-soft:   #f6f8ff;
  --ats-bg-deep:   #0f1635;
  --ats-ink:       #1a1f36;
  --ats-ink-soft:  #5b6478;
  --ats-line:      #e5e8f0;
  --ats-brand:     #275df5;
  --ats-brand-700: #1c47c4;
  --ats-accent:    #fec924;
  --ats-ok:        #16a34a;
  --ats-warn:      #f59e0b;
  --ats-bad:       #ef4444;
  --ats-radius:    14px;
  --ats-radius-sm: 8px;
  --ats-shadow:    0 4px 14px rgba(20,30,80,0.06);
  --ats-shadow-lg: 0 12px 32px rgba(20,30,80,0.12);
  --ats-font:      "Satoshi", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--ats-ink);
  font-family: var(--ats-font);
  font-size: 16px;
  line-height: 1.5;
  background: var(--ats-bg);
  -webkit-font-smoothing: antialiased;
}
#ats-app *,#ats-app *::before,#ats-app *::after{box-sizing:border-box}
#ats-app img,#ats-app svg{max-width:100%;display:block}

.ats-container{max-width:1180px;margin:0 auto;padding:0 24px}

/* ---------- typography ---------- */
.ats-h1{font-size:44px;line-height:1.15;font-weight:800;margin:0 0 14px;letter-spacing:-0.02em;color:var(--ats-ink)}
.ats-h2{font-size:30px;line-height:1.2;font-weight:800;margin:0 0 10px;letter-spacing:-0.01em;color:var(--ats-ink)}
.ats-lead{font-size:17px;color:var(--ats-ink-soft);margin:0 0 18px}
.ats-sub{font-size:15px;color:var(--ats-ink-soft);margin:0 0 28px;max-width:680px}
.ats-eyebrow{display:inline-block;padding:5px 12px;border-radius:99px;background:#eaf0ff;color:var(--ats-brand);font-size:12px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;margin-bottom:18px}

/* ---------- buttons ---------- */
.ats-cta-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:var(--ats-brand);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;text-decoration:none;transition:background .15s ease,transform .1s ease;font-family:inherit}
.ats-cta-primary:hover{background:var(--ats-brand-700)}
.ats-cta-primary:active{transform:translateY(1px)}
.ats-cta-primary:disabled{background:#c2cde6;cursor:not-allowed}
.ats-cta-large{padding:18px 36px;font-size:17px;border-radius:12px}
.ats-cta-ghost{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;background:transparent;color:var(--ats-brand);border:1px solid var(--ats-brand);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s ease;font-family:inherit}
.ats-cta-ghost:hover{background:#eaf0ff}

/* ═══ HERO + UPLOAD ═══ */
.ats-hero{padding:64px 0 56px;background:linear-gradient(180deg,#f6f8ff 0%,#ffffff 100%)}
.ats-hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center}
.ats-hero-copy{max-width:560px}
.ats-bullets{list-style:none;padding:0;margin:8px 0 0;display:grid;gap:10px}
.ats-bullets li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--ats-ink-soft)}
.ats-tick{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#dcfce7;color:var(--ats-ok);font-size:12px;font-weight:700;flex:none;margin-top:2px}

.ats-upload-card{background:#fff;border:1px solid var(--ats-line);border-radius:var(--ats-radius);box-shadow:var(--ats-shadow-lg);padding:28px}
.ats-dropzone{border:2px dashed #c2cde6;border-radius:var(--ats-radius);padding:36px 24px;text-align:center;cursor:pointer;color:var(--ats-ink-soft);transition:border-color .15s ease,background .15s ease;outline:none}
.ats-dropzone:hover,.ats-dropzone:focus-visible,.ats-dropzone.is-drag{border-color:var(--ats-brand);background:#f6f8ff;color:var(--ats-brand)}
.ats-dz-icon{margin:0 auto 10px;color:var(--ats-brand)}
.ats-dz-title{font-weight:600;color:var(--ats-ink);margin-bottom:6px;font-size:16px}
.ats-dz-browse{color:var(--ats-brand);text-decoration:underline}
.ats-dz-sub{font-size:13px;color:var(--ats-ink-soft)}

.ats-file-pill{display:inline-flex;align-items:center;gap:8px;margin-top:14px;padding:8px 12px;background:#eaf0ff;color:var(--ats-brand);border-radius:99px;font-size:14px;font-weight:600;max-width:100%}
.ats-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:240px}
.ats-file-clear{background:transparent;border:none;color:var(--ats-brand);font-size:18px;line-height:1;cursor:pointer;padding:0 4px;font-weight:700}

.ats-jd{margin-top:18px}
.ats-jd-label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--ats-ink)}
.ats-jd-opt{font-weight:400;color:var(--ats-ink-soft)}
.ats-jd textarea{width:100%;padding:12px 14px;border:1px solid var(--ats-line);border-radius:var(--ats-radius-sm);font-family:inherit;font-size:14px;color:var(--ats-ink);resize:vertical;min-height:90px;transition:border-color .15s ease;background:#fff}
.ats-jd textarea:focus{outline:none;border-color:var(--ats-brand)}

.ats-cta-primary#ats-analyze-btn{width:100%;margin-top:18px}
.ats-privacy{margin-top:12px;text-align:center;font-size:12px;color:var(--ats-ink-soft)}

/* ═══ TRUST STRIP ═══ */
.ats-trust{padding:28px 0;background:#fff;border-top:1px solid var(--ats-line);border-bottom:1px solid var(--ats-line)}
.ats-trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.ats-trust-grid > div{display:flex;flex-direction:column;align-items:center;gap:2px}
.ats-trust-grid strong{font-size:24px;font-weight:800;color:var(--ats-ink);letter-spacing:-0.01em}
.ats-trust-grid span{font-size:13px;color:var(--ats-ink-soft)}

/* ═══ RESULTS ═══ */
.ats-results{padding:64px 0;background:var(--ats-bg-soft)}
.ats-results-head{margin-bottom:32px;text-align:center}
.ats-results-head p{font-size:15px;color:var(--ats-ink-soft);max-width:620px;margin:0 auto}
#ats-score-inline{color:var(--ats-brand)}

.ats-results-grid{display:grid;grid-template-columns:320px 1fr;gap:32px;align-items:start}

.ats-score-card{background:#fff;border:1px solid var(--ats-line);border-radius:var(--ats-radius);padding:28px;text-align:center;box-shadow:var(--ats-shadow);position:sticky;top:24px}
.ats-gauge{position:relative;width:160px;height:160px;margin:0 auto 18px}
#ats-gauge-ring{transition:stroke-dashoffset 800ms ease,stroke 300ms ease}
.ats-gauge-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ats-gauge-num{font-size:42px;font-weight:800;color:var(--ats-ink);line-height:1;letter-spacing:-0.02em}
.ats-gauge-label{font-size:12px;color:var(--ats-ink-soft);letter-spacing:.4px;text-transform:uppercase;margin-top:4px}
.ats-score-band{display:inline-block;padding:6px 14px;border-radius:99px;font-size:13px;font-weight:600;margin-bottom:14px}
.ats-band-good{background:#dcfce7;color:var(--ats-ok)}
.ats-band-warn{background:#fef3c7;color:#92400e}
.ats-band-bad{background:#fee2e2;color:#991b1b}

.ats-cat-list{list-style:none;padding:0;margin:0;display:grid;gap:16px}
.ats-cat{background:#fff;border:1px solid var(--ats-line);border-radius:var(--ats-radius);padding:16px 20px}
.ats-cat-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.ats-cat-head > span:first-child{font-weight:700;font-size:15px;color:var(--ats-ink)}
.ats-cat-score{font-weight:700;font-size:14px;color:var(--ats-ink-soft)}
.ats-bar{height:6px;background:#eef0f6;border-radius:99px;overflow:hidden}
.ats-bar span{display:block;height:100%;border-radius:99px;background:var(--ats-brand);transition:width .4s ease}
.ats-cat[data-status="ok"]   .ats-bar span{background:var(--ats-ok)}
.ats-cat[data-status="warn"] .ats-bar span{background:var(--ats-warn)}
.ats-cat[data-status="bad"]  .ats-bar span{background:var(--ats-bad)}
.ats-cat[data-status="ok"]   .ats-cat-score{color:var(--ats-ok)}
.ats-cat[data-status="warn"] .ats-cat-score{color:var(--ats-warn)}
.ats-cat[data-status="bad"]  .ats-cat-score{color:var(--ats-bad)}
.ats-cat-note{margin-top:8px;font-size:13px;color:var(--ats-ink-soft);line-height:1.5}

/* Score-bar widths in 5% steps — keeps CSS data-driven without inline styles.
   ats.js rounds the score to the nearest 5% and applies the matching class. */
.ats-bar span.w-0{width:0%}
.ats-bar span.w-5{width:5%}
.ats-bar span.w-10{width:10%}
.ats-bar span.w-15{width:15%}
.ats-bar span.w-20{width:20%}
.ats-bar span.w-25{width:25%}
.ats-bar span.w-30{width:30%}
.ats-bar span.w-35{width:35%}
.ats-bar span.w-40{width:40%}
.ats-bar span.w-45{width:45%}
.ats-bar span.w-50{width:50%}
.ats-bar span.w-55{width:55%}
.ats-bar span.w-60{width:60%}
.ats-bar span.w-65{width:65%}
.ats-bar span.w-70{width:70%}
.ats-bar span.w-75{width:75%}
.ats-bar span.w-80{width:80%}
.ats-bar span.w-85{width:85%}
.ats-bar span.w-90{width:90%}
.ats-bar span.w-95{width:95%}
.ats-bar span.w-100{width:100%}

/* ═══ WHAT WE CHECK ═══ */
.ats-what{padding:72px 0;background:#fff}
.ats-what-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:12px}
.ats-what-card{background:#fff;border:1px solid var(--ats-line);border-radius:var(--ats-radius);padding:24px;transition:transform .15s ease,box-shadow .15s ease}
.ats-what-card:hover{transform:translateY(-2px);box-shadow:var(--ats-shadow)}
.ats-icon{font-size:28px;margin-bottom:10px;line-height:1}
.ats-what-card h3{font-size:16px;font-weight:700;margin:0 0 6px;color:var(--ats-ink)}
.ats-what-card p{font-size:14px;color:var(--ats-ink-soft);margin:0;line-height:1.55}

/* ═══ HOW IT WORKS ═══ */
.ats-how{padding:72px 0;background:var(--ats-bg-soft)}
.ats-steps{list-style:none;padding:0;margin:32px 0 0;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;counter-reset:ats-step}
.ats-steps li{background:#fff;border:1px solid var(--ats-line);border-radius:var(--ats-radius);padding:32px 28px;position:relative}
.ats-step-num{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--ats-brand);color:#fff;font-weight:800;font-size:18px;margin-bottom:16px}
.ats-steps h3{font-size:18px;font-weight:700;margin:0 0 8px;color:var(--ats-ink)}
.ats-steps p{font-size:14px;color:var(--ats-ink-soft);margin:0;line-height:1.55}

/* ═══ FAQ ═══ */
.ats-faq{padding:72px 0;background:#fff}
.ats-faq-list{display:grid;gap:12px;margin-top:24px;max-width:820px;margin-left:auto;margin-right:auto}
.ats-faq-item{background:#fff;border:1px solid var(--ats-line);border-radius:var(--ats-radius);padding:18px 22px;transition:border-color .15s ease}
.ats-faq-item[open]{border-color:var(--ats-brand)}
.ats-faq-item summary{cursor:pointer;font-weight:600;font-size:15px;color:var(--ats-ink);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.ats-faq-item summary::-webkit-details-marker{display:none}
.ats-faq-item summary::after{content:"+";font-size:22px;font-weight:300;color:var(--ats-brand);transition:transform .2s ease;line-height:1;width:20px;text-align:center;flex:none}
.ats-faq-item[open] summary::after{content:"−"}
.ats-faq-item > div{margin-top:12px;font-size:14px;color:var(--ats-ink-soft);line-height:1.6}

/* ═══ FINAL CTA ═══ */
.ats-final-cta{padding:72px 0;background:var(--ats-bg-deep);color:#fff;text-align:center}
.ats-final-cta .ats-h2{color:#fff;margin-bottom:8px}
.ats-final-cta p{font-size:16px;color:#aab2c8;margin:0 0 24px}
.ats-final-cta .ats-cta-primary{background:var(--ats-accent);color:#0f1635}
.ats-final-cta .ats-cta-primary:hover{background:#ffd84a}

/* ═══ RESPONSIVE ═══ */
@media (max-width:1024px){
  .ats-h1{font-size:36px}
  .ats-hero-grid{grid-template-columns:1fr;gap:32px}
  .ats-upload-card{max-width:560px}
  .ats-what-grid{grid-template-columns:repeat(2,1fr)}
  .ats-results-grid{grid-template-columns:1fr;gap:24px}
  .ats-score-card{position:static;max-width:420px;margin:0 auto}
  .ats-steps{grid-template-columns:1fr}
}
@media (max-width:640px){
  .ats-container{padding:0 18px}
  .ats-hero{padding:40px 0 32px}
  .ats-h1{font-size:30px}
  .ats-h2{font-size:24px}
  .ats-lead{font-size:15px}
  .ats-trust-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .ats-trust-grid strong{font-size:20px}
  .ats-what-grid{grid-template-columns:1fr}
  .ats-results,.ats-what,.ats-how,.ats-faq,.ats-final-cta{padding:48px 0}
  .ats-upload-card{padding:20px}
  .ats-dropzone{padding:24px 16px}
  .ats-cta-large{padding:14px 22px;font-size:15px}
}
