/* profile.css — shared design tokens + components for /contractor/* profile pages.
   Single source of truth: every contractor profile links this so the look stays
   consistent. Matches the approved contractor-profile-reference design in the real
   site palette. The global header/nav (.bhd) is stamped separately by sync_chrome;
   do not restyle it here. */
:root{
  --navy:#16384f;--navy2:#1f4d6e;--red:#b8432f;--bg:#f7f6f2;--card:#fff;--ink:#26323c;--mut:#5c6b78;--line:#e3e1da;
  --green:#3e7d4f;--green-bg:#eaf3ec;--amber:#b07514;--amber-bg:#f8f0df;--slate:#3d566b;--slate-bg:#eaf0f4;
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.65;font-size:16.5px;-webkit-font-smoothing:antialiased}
.wrap{max-width:840px;margin:0 auto;padding:0 20px}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--mut)}
.microlabel{font-size:11px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;color:var(--mut)}
main h1{font-size:clamp(28px,5vw,36px);letter-spacing:-.6px;line-height:1.08;color:var(--navy);font-weight:800}
main h2{font-size:20px;color:var(--navy);letter-spacing:-.2px;font-weight:800;margin:0 0 var(--s3)}
main a{color:var(--navy2);font-weight:600;text-decoration:none}main a:hover{text-decoration:underline}
.bc{font-size:12.5px;color:var(--mut);padding:var(--s5) 0 0}
.hero{padding:var(--s4) 0 var(--s5);border-bottom:1px solid var(--line)}
.hero-top{display:flex;gap:var(--s4);align-items:center}
.mono{width:62px;height:62px;border-radius:14px;background:var(--navy);color:#fff;font-weight:800;font-size:24px;letter-spacing:-.5px;display:flex;align-items:center;justify-content:center;flex:none}
.plogo{width:96px;height:72px;border-radius:14px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;flex:none;overflow:hidden;padding:6px}
.plogo img{max-width:100%;max-height:100%;object-fit:contain}
.plogo.fallback{display:none}
.whofor{margin:var(--s4) 0 0;padding:14px 16px;background:#fff;border:1px solid var(--line);border-radius:12px;font-size:15px;color:var(--ink)}
.whofor .microlabel{display:block;margin-bottom:4px}
.svcmap{margin:var(--s4) 0 var(--s3)}
.svcmap img{width:100%;height:auto;border-radius:14px;display:block}
.svcmap figcaption{font-size:12.5px;color:var(--mut);margin-top:8px;line-height:1.6}
.asklist{margin:var(--s3) 0 0;padding:0;list-style:none;counter-reset:q}
.asklist li{counter-increment:q;position:relative;padding:12px 0 12px 44px;border-top:1px solid var(--line);font-size:15px}
.asklist li:before{content:counter(q);position:absolute;left:0;top:12px;width:26px;height:26px;border-radius:8px;background:var(--navy);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center}
.asklist li b{color:var(--navy)}
.asklist li .why{display:block;font-size:12.5px;color:var(--mut)}
.hero .who{flex:1;min-width:0}
.hero h1{margin:2px 0 6px}
.hero .sub{color:var(--mut);font-size:15.5px}
.verbadge{display:inline-flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:var(--s4);padding:7px 12px;border-radius:10px;background:var(--amber-bg);color:var(--amber);font-weight:700;font-size:13.5px}
.verbadge .n{color:var(--mut);font-weight:600;font-size:12.5px}
.actions{display:flex;gap:10px;margin-top:var(--s4);flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;padding:12px 20px;border-radius:10px;text-decoration:none;cursor:pointer;border:1.5px solid transparent}
.btn.primary{background:var(--red);color:#fff}
.btn.ghost{background:#fff;color:var(--navy);border-color:var(--line)}
.btn:hover{text-decoration:none;opacity:.94}
.lc{font-size:12.5px;color:var(--mut);margin-top:var(--s3)}
.psec{padding:var(--s6) 0;border-bottom:1px solid var(--line)}
.psec.last{border-bottom:none}
.legend{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 var(--s4)}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:4px 10px;border-radius:99px;white-space:nowrap}
.chip svg{width:13px;height:13px}
.chip.v{background:var(--green-bg);color:var(--green)}
.chip.w{background:var(--slate-bg);color:var(--slate)}
.chip.n{background:var(--amber-bg);color:var(--amber)}
.rec{display:grid;grid-template-columns:170px 1fr;gap:2px var(--s4);align-items:start}
.rec .row{display:contents}
.rec .k{padding:14px 0;border-top:1px solid var(--line);color:var(--mut);font-size:13.5px;font-weight:600}
.rec .v{padding:14px 0;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.rec .v .val{font-weight:600;color:var(--ink)}
.rec .v .val.missing{color:var(--mut)}
.rec .v .src{font-size:12px;color:var(--mut);flex-basis:100%}
.rec .row.key .k,.rec .row.key .v{background:#fbf6ec}
.svcs{display:flex;flex-wrap:wrap;gap:8px}
.svc{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--navy);background:#fff;border:1px solid var(--line);border-radius:99px;padding:8px 14px}
.svc svg{width:15px;height:15px;color:var(--navy2)}
.bars{margin-top:var(--s3)}
.bar{display:grid;grid-template-columns:120px 1fr 34px;align-items:center;gap:10px;margin-bottom:9px;font-size:13.5px}
.bar .cl{color:var(--navy);font-weight:600}
.bar .tr{height:16px;background:#edeae2;border-radius:99px;overflow:hidden}
.bar .tr i{display:block;height:100%;border-radius:99px}
.bar .sc{font-weight:800;color:var(--ink);text-align:right}
.insight{margin-top:var(--s4);font-size:15px;background:#0e2233;color:#fff;border-radius:12px;padding:16px 18px;line-height:1.5}
.insight b{color:#fff}.insight a{color:#9fc6e0}
.empties{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.empty{border:1.5px dashed var(--line);border-radius:12px;padding:22px 18px;text-align:center;color:var(--mut)}
.empty svg{width:22px;height:22px;color:#b7c2c9;margin-bottom:6px}
.empty b{display:block;color:var(--navy);font-size:14px;margin-bottom:2px}
.empty a{font-size:12.5px}
.pmeta{font-size:12.5px;color:var(--mut);line-height:1.7}
.pmeta .microlabel{display:block;margin-bottom:6px}
.stickycta{display:none}
.pfoot{border-top:1px solid var(--line);margin-top:var(--s6);padding:var(--s5) 0 var(--s7);font-size:12px;color:var(--mut);line-height:1.7}
@media(max-width:640px){
  .rec{grid-template-columns:1fr;gap:0}
  .rec .k{padding:12px 0 2px;border-top:1px solid var(--line)}
  .rec .v{padding:0 0 12px;border-top:none}
  .empties{grid-template-columns:1fr}
  .actions .btn{flex:1 1 auto;justify-content:center}
  .stickycta{display:block;position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);padding:10px 16px;z-index:30}
  .stickycta .btn{width:100%;justify-content:center}
  body{padding-bottom:76px}
}
