/* Emerald Coast Systems Group brand palette (mirrors the ECSG site css/site.css) */
:root {
  --blue:#0c2842;          /* navy — topbar, headings, score default */
  --navy2:#15395b;
  --accent:#0e7c64;        /* emerald — links, primary actions */
  --acc-d:#0a5e4c;
  --grad:linear-gradient(96deg,#0a5e4c,#0e7c64,#22b894);
  --mint:#22b894;
  --bg:#f3f6f9; --line:#e3e9f0; --muted:#6a7c8e;
  --sans:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --display:'Archivo',var(--sans);
}
* { box-sizing: border-box; }
body { margin:0; font-family: var(--sans); background:var(--bg); color:#26323d; }
h1, h2, h3, .brand, .screen-title, .home-hello, .sub, .stat-val { font-family: var(--display); letter-spacing:-.01em; }
.muted { color:var(--muted); }
.tiny { font-size:11px; }
.hidden { display:none !important; }

/* auth */
body.auth { display:flex; align-items:center; justify-content:center; min-height:100vh; }
.auth-card { width:360px; }
.auth-brand { display:flex; align-items:center; gap:10px; }
.auth-brand svg { width:34px; height:34px; }
.auth-brand h1 { margin:0; }
.card { background:#fff; border:1px solid var(--line); border-radius:12px; padding:20px; box-shadow:0 1px 3px rgba(0,0,0,.05); }
.card h1 { color:var(--blue); margin:0 0 6px; }
.tabs { display:flex; gap:8px; margin:14px 0; }
.tab { flex:1; padding:8px; border:1px solid var(--line); background:#fff; border-radius:8px; cursor:pointer; }
.tab.active { background:var(--blue); color:#fff; border-color:var(--blue); }
form { display:flex; flex-direction:column; gap:8px; }
input, select { padding:9px 10px; border:1px solid var(--line); border-radius:8px; font-size:14px; }
button { cursor:pointer; font-size:14px; }
button.primary { background:var(--accent); color:#fff; border:none; padding:9px 14px; border-radius:8px; }
button.primary:hover { background:var(--acc-d); }
button.ghost { background:#fff; border:1px solid var(--line); padding:8px 12px; border-radius:8px; }
button.small, a.small { font-size:12px; padding:5px 10px; }
a.small { display:inline-block; text-decoration:none; }
.oauth { margin-top:6px; display:flex; flex-direction:column; gap:6px; }
.divider { display:flex; align-items:center; text-align:center; color:var(--muted); margin:16px 0 10px; font-size:12px; }
.divider::before, .divider::after { content:""; flex:1; border-bottom:1px solid var(--line); }
.divider span { padding:0 10px; }
a.social { display:flex; align-items:center; justify-content:center; gap:8px; text-decoration:none; color:#222; font-weight:500; padding:10px; }
a.social:hover { background:#f6f8fb; }
.g-icon { display:inline-flex; align-items:center; justify-content:center; width:18px; height:18px; border-radius:50%; background:#fff; color:#4285F4; font-weight:700; border:1px solid var(--line); font-family:Arial, sans-serif; }
.in-icon, .fb-icon { display:inline-flex; align-items:center; justify-content:center; width:18px; height:18px; border-radius:3px; color:#fff; font-weight:700; font-family:Arial, sans-serif; font-size:12px; }
a.social.linkedin { background:#0a66c2; color:#fff; border-color:#0a66c2; }
a.social.linkedin:hover { background:#084e96; }
.in-icon { background:#fff; color:#0a66c2; border-radius:3px; }
a.social.facebook { background:#1877f2; color:#fff; border-color:#1877f2; }
a.social.facebook:hover { background:#145dbf; }
.fb-icon { background:#fff; color:#1877f2; border-radius:50%; }
a.social.logingov { background:#1a4480; color:#fff; border-color:#1a4480; }
a.social.logingov:hover { background:#162e51; }
a.social.logingov b { font-weight:700; letter-spacing:0.3px; }
.msg { color:#b00; margin-top:10px; font-size:13px; min-height:18px; }

/* app layout */
.topbar { display:flex; align-items:center; gap:16px; background:var(--blue); color:#fff; padding:10px 18px; position:sticky; top:0; z-index:40; }
.topbar .brand { display:flex; align-items:center; gap:10px; font-weight:700; font-size:17px; white-space:nowrap; }
.topbar .brand .logo { width:30px; height:30px; flex:none; }
.brandtext { display:flex; flex-direction:column; line-height:1.05; }
/* footer credit (promotes ECSG) */
.appfoot { border-top:1px solid var(--line); background:#fff; color:var(--muted); font-size:12.5px;
  text-align:center; padding:16px; margin-top:30px; }
.appfoot b { color:var(--blue); }
.topbar .who { margin-left:auto; display:flex; align-items:center; white-space:nowrap; }
.topbar .ghost { color:#fff; background:transparent; border-color:#ffffff55; margin-left:10px; }
.mainnav { display:flex; gap:3px; align-items:center; }
.mainnav a, .navdrop-btn { color:#dfe7f2; text-decoration:none; font-size:13px; font-weight:500;
  padding:7px 12px; border-radius:7px; background:none; border:none; cursor:pointer; font-family:inherit; }
.mainnav a:hover, .navdrop-btn:hover { background:#ffffff1a; color:#fff; }
.mainnav a.active, .navdrop-btn.active { background:#fff; color:var(--blue); }
/* reports dropdown */
.navdrop { position:relative; }
.navdrop-menu { position:absolute; top:100%; left:0; background:#fff; border:1px solid var(--line);
  border-radius:8px; box-shadow:0 6px 20px rgba(0,0,0,.18); padding:5px; min-width:160px;
  display:none; z-index:60; }
.navdrop:hover .navdrop-menu { display:block; }
.navdrop-menu a { display:block; color:#1a1a1a; padding:7px 11px; border-radius:6px; font-weight:500; }
.navdrop-menu a:hover { background:#eef3fb; color:var(--blue); }
.navdrop-menu a.active { background:var(--blue); color:#fff; }
.grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; padding:16px; max-width:1100px; margin:0 auto; }
.card.wide { grid-column:1 / -1; }

/* screens */
.screen { max-width:1100px; margin:0 auto; padding:18px 16px 60px; }
.screen-title { color:var(--blue); margin:4px 0 14px; font-size:22px; }
.sub { color:var(--blue); font-size:16px; margin:22px 0 8px; }
.pad { padding:24px 16px; }
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; max-width:1100px; }
@media (max-width:820px){ .grid2 { grid-template-columns:1fr; } }

/* filter bar */
.filterbar { display:flex; flex-wrap:wrap; gap:8px; align-items:center; background:#fff; border:1px solid var(--line); border-radius:10px; padding:10px; margin-bottom:12px; }
.filterbar input, .filterbar select { font-size:13px; padding:7px 9px; }
.filterbar input { min-width:160px; }
.filterbar label { font-size:13px; display:flex; align-items:center; gap:5px; }
.resultmeta { margin:4px 2px 10px; font-size:13px; }
.pager { display:flex; align-items:center; gap:12px; justify-content:center; margin-top:18px; }

/* job meta chips */
.metarow { display:flex; gap:6px; flex-wrap:wrap; margin:6px 0 2px; }
.chip { background:#eef2f8; border-radius:999px; padding:1px 8px; }
.job.dim { opacity:.55; }
.dl { font-size:12px; color:var(--accent); text-decoration:none; margin-right:8px; font-weight:600; }
.dl:hover { text-decoration:underline; }
.dls { display:inline-flex; gap:2px; }

/* insights */
.stats { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; }
@media (max-width:820px){ .stats { grid-template-columns:repeat(2,1fr); } }
.stat { background:#fff; border:1px solid var(--line); border-radius:10px; padding:14px; text-align:center; }
.stat-val { font-size:24px; font-weight:700; color:var(--blue); }
.stat-lbl { font-size:12px; margin-top:3px; }
.sector-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
@media (max-width:820px){ .sector-grid { grid-template-columns:1fr; } }
.sector-card { background:#fff; border:1px solid var(--line); border-radius:10px; padding:12px; cursor:pointer; }
.sector-card:hover { border-color:var(--accent); box-shadow:0 1px 6px rgba(37,99,235,.12); }
.sector-name { font-weight:600; color:var(--blue); }
.sector-stats { font-size:13px; margin-top:6px; }

/* home */
.home-hello { color:var(--blue); margin:4px 0 2px; font-size:24px; }
.home-sub { margin:0 0 16px; }
.home-section { margin-top:22px; }
.home-links { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
@media (max-width:820px){ .home-links { grid-template-columns:repeat(2,1fr); } }
.home-link { display:block; background:#fff; border:1px solid var(--line); border-radius:10px;
  padding:14px; text-decoration:none; color:#1a1a1a; }
.home-link:hover { border-color:var(--accent); box-shadow:0 1px 6px rgba(37,99,235,.12); }
.home-link b { color:var(--blue); display:block; margin-bottom:3px; }

/* map */
.leaflet { height:560px; border:1px solid var(--line); border-radius:10px; }
.mp b { color:var(--blue); }
.mp-job { display:flex; align-items:center; gap:7px; padding:4px 0; border-top:1px solid var(--line); margin-top:4px; }
.mp-job a { color:var(--accent); text-decoration:none; font-weight:600; font-size:13px; }
.mp-job a:hover { text-decoration:underline; }
.leaflet-popup-content { margin:10px 12px; }
.ready-row .dls { margin:0 4px; }

/* brand tagline */
.brand { display:flex; flex-direction:column; line-height:1.12; }
.brand .tag { font-size:10px; font-weight:400; color:#aebfd6; letter-spacing:.2px; }

/* download chips (ATS / Premium / Cover) */
.chip-dl { display:inline-block; font-size:11px; font-weight:600; color:var(--accent);
  background:#eef3fb; border:1px solid #d6e2f5; border-radius:6px; padding:2px 8px; margin-right:5px;
  text-decoration:none; }
.chip-dl:hover { background:#dbe8fb; }
.chip-dl.prem { color:#92500e; background:#fef7e6; border-color:#f3e0ad; }
.chip-dl.pkg { color:#fff; background:var(--accent); border-color:var(--accent); }
.chip-dl.pkg:hover { background:var(--acc-d); }

/* ready: per-company in-house recruiter line */
.rec-line { background:#eef5ff; border:1px solid #d6e2f5; border-radius:8px; padding:7px 10px;
  font-size:13px; margin:4px 0 8px; }
.rec-line a { color:var(--accent); text-decoration:none; }
.rec-line details { margin-top:4px; }
.rec-line summary { cursor:pointer; color:var(--blue); font-size:12px; }
.rec-line pre { white-space:pre-wrap; font:inherit; font-size:12px; background:#fff; border:1px solid var(--line);
  border-radius:6px; padding:8px; margin:6px 0 0; }
.ready-co { padding:14px 16px; }
.ready-co .report-coname { display:flex; align-items:baseline; gap:8px; }
.ready-row { gap:12px; padding:7px 0; border-top:1px solid var(--line); }
.ready-row .report-title { flex:1; min-width:200px; }
.row { display:flex; align-items:center; gap:10px; }
.row.spread { justify-content:space-between; }
.status { font-size:13px; color:var(--muted); margin:8px 0; min-height:18px; }

/* profile */
.profile-box { margin-top:12px; border-top:1px solid var(--line); padding-top:10px; }
.completeness { margin-bottom:8px; }
.skill-group { font-size:13px; margin-bottom:5px; }

/* chat */
.chat-log { height:240px; overflow-y:auto; border:1px solid var(--line); border-radius:8px; padding:10px; margin:8px 0; background:#fafbfd; }
.bubble { max-width:85%; padding:8px 11px; border-radius:12px; margin-bottom:8px; font-size:13px; line-height:1.4; white-space:pre-wrap; }
.bubble.assistant { background:#eef3f9; }
.bubble.user { background:var(--accent); color:#fff; margin-left:auto; }
#chat-form { flex-direction:row; }
#chat-input { flex:1; }

/* results */
.job { border:1px solid var(--line); border-radius:10px; padding:12px; margin:10px 0; }
.job-head { display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; }
.score { background:var(--blue); color:#fff; font-weight:700; border-radius:6px; padding:2px 9px; min-width:34px; text-align:center; }
.score.small { padding:1px 7px; min-width:28px; font-size:12px; }
/* fit grading by tier */
.score.grade-a { background:#15803d; }   /* 85+  excellent */
.score.grade-b { background:#2563eb; }   /* 70+  strong */
.score.grade-c { background:#b45309; }   /* 55+  moderate */
.score.grade-d { background:#9ca3af; }   /* <55  weak */
.score.grade-none { background:#cbd5e1; color:#475569; }
.job-title { font-weight:600; color:var(--accent); text-decoration:none; }
.job-title:hover { text-decoration:underline; }
.job-title.big { font-size:18px; }
.rationale { font-size:13px; margin:6px 0; }
.job-actions { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:8px; }
.gen-status { font-size:12px; }
.gen-status a { color:var(--accent); }

/* status pills */
.pill { font-size:10px; text-transform:uppercase; letter-spacing:.4px; padding:2px 7px; border-radius:999px; font-weight:700; }
.pill-applied { background:#dcfce7; color:#166534; }
.pill-generated { background:#dbeafe; color:#1e40af; }
.pill-dismissed { background:#f1f5f9; color:#64748b; }

/* view tabs */
.viewtabs { display:flex; gap:6px; }
.viewtabs .tab { flex:none; padding:6px 14px; font-size:13px; }

/* by-company report */
.report-co { border:1px solid var(--line); border-radius:10px; padding:10px 14px; margin:10px 0; }
.report-coname { margin:0 0 6px; font-size:15px; color:var(--blue); }
.report-row { display:flex; align-items:center; gap:10px; padding:4px 0; flex-wrap:wrap; }
.report-title { font-weight:600; color:var(--accent); text-decoration:none; }
.report-title:hover { text-decoration:underline; }

/* modal */
.modal { position:fixed; inset:0; background:rgba(15,23,42,.55); display:flex; align-items:flex-start; justify-content:center; padding:40px 16px; overflow-y:auto; z-index:50; }
.modal-card { background:#fff; border-radius:12px; width:680px; max-width:100%; padding:22px; position:relative; box-shadow:0 12px 40px rgba(0,0,0,.25); }
.modal-x { position:absolute; top:10px; right:14px; background:none; border:none; font-size:26px; line-height:1; color:var(--muted); }
.modal-sect { border-top:1px solid var(--line); margin-top:14px; padding-top:10px; }
.modal-sect summary { cursor:pointer; font-weight:600; color:var(--blue); }
.modal-sect textarea { width:100%; border:1px solid var(--line); border-radius:8px; padding:9px; font:inherit; font-size:13px; margin-top:8px; }
.modal-gaps { font-size:13px; margin:6px 0; background:#fff7ed; border:1px solid #fed7aa; border-radius:8px; padding:8px 10px; }
.posting { white-space:pre-wrap; font-size:13px; line-height:1.5; max-height:320px; overflow-y:auto; margin-top:8px; color:#333; }

/* recruiters */
.rec-row { display:grid; grid-template-columns:1fr auto; gap:8px 12px; align-items:center; border-top:1px dashed var(--line); padding:8px 0; }
.rec-row .rec-draft { grid-column:1 / -1; }
.rec-draft textarea { width:100%; border:1px solid var(--line); border-radius:8px; padding:8px; font:inherit; font-size:13px; }
.conf { font-size:10px; text-transform:uppercase; padding:1px 6px; border-radius:999px; margin-left:6px; }
.conf-high { background:#dcfce7; color:#166534; }
.conf-medium { background:#fef9c3; color:#854d0e; }
.conf-low { background:#f1f5f9; color:#64748b; }

/* recruiter tracker table */
.tbl { width:100%; border-collapse:collapse; font-size:13px; margin-top:8px; }
.tbl th { text-align:left; color:var(--muted); font-weight:600; font-size:11px; text-transform:uppercase; letter-spacing:.4px; border-bottom:1px solid var(--line); padding:6px 8px; }
.tbl td { border-bottom:1px solid var(--line); padding:7px 8px; vertical-align:top; }
.tbl select, .tbl input { width:100%; font-size:13px; padding:5px 7px; }
.tbl a { color:var(--accent); text-decoration:none; }

/* skill gaps */
.gap-row { border:1px solid var(--line); border-radius:10px; padding:10px 12px; margin:10px 0; }
.gap-head { display:flex; align-items:baseline; gap:8px; flex-wrap:wrap; }
.gap-samples { margin:5px 0; line-height:1.4; }
.gap-resp { width:100%; border:1px solid var(--line); border-radius:8px; padding:8px; font:inherit; font-size:13px; margin-top:6px; }
