/* ============================================================
   site.css — WorkDirectory.ca, applied site-wide
   ------------------------------------------------------------
   Load AFTER tokens.css. Uses ONLY tokens from tokens.css.
   The chrome (header / nav / footer) is injected by chrome.js;
   the classes here style it plus every page-level component.
   ============================================================ */

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--surface-1);
  color:var(--ink-1);
  font-family:var(--font-sans);
  font-size:var(--size-md);
  line-height:var(--leading-body);
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;padding:0;color:inherit}
h1,h2,h3,h4{margin:0}
img{max-width:100%}
.container{max-width:1240px;margin:0 auto;padding:0 var(--space-6)}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);
  padding:9px 16px;border-radius:var(--radius-sm);
  font-size:var(--size-sm);font-weight:var(--weight-medium);line-height:1.2;
  border:1px solid transparent;white-space:nowrap;
  transition:background var(--duration) var(--easing), border-color var(--duration) var(--easing), color var(--duration) var(--easing);
}
.btn-primary,a.btn-primary{background:var(--brand-orange);color:#fff;border-color:var(--brand-orange)}
.btn-primary:hover,a.btn-primary:hover{background:var(--brand-orange-hover);border-color:var(--brand-orange-hover);color:#fff}
.btn-secondary,a.btn-secondary{background:var(--brand-green);color:#fff;border-color:var(--brand-green)}
.btn-secondary:hover,a.btn-secondary:hover{background:var(--brand-green-deep);border-color:var(--brand-green-deep);color:#fff}
.btn-ghost,a.btn-ghost{background:var(--surface-0);color:var(--ink-1);border-color:var(--line-2)}
.btn-ghost:hover,a.btn-ghost:hover{background:var(--surface-1);color:var(--ink-1)}
.btn-block{width:100%}
.btn-lg{padding:12px 20px;font-size:var(--size-md)}

/* ── Header ── */
.header{padding:var(--space-4) 0;border-bottom:1px solid var(--line-1);background:var(--surface-0)}
.header .row{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-6);align-items:center}
.brand{display:flex;flex-direction:column;gap:2px}
.wordmark{font-size:22px;font-weight:var(--weight-bold);letter-spacing:-0.02em;line-height:1}
.wordmark .work{color:var(--brand-green)}
.wordmark .dir{color:var(--brand-orange)}
.wordmark .ca{color:var(--ink-1)}
.brand .tag{font-size:var(--size-xs);color:var(--ink-3);display:flex;align-items:center;gap:6px;letter-spacing:0.02em;white-space:nowrap}
.brand .leaf{width:24px;height:14px;display:inline-block;flex-shrink:0;vertical-align:middle}
.brand .flag-img{width:24px;height:auto;display:inline-block;flex-shrink:0;vertical-align:middle;border-radius:1px}
.header-mid{display:flex;justify-content:center}
.usa-link{
  display:inline-flex;align-items:center;gap:6px;padding:6px 12px;
  border:1px solid var(--line-1);background:var(--surface-1);
  border-radius:var(--radius-sm);font-size:var(--size-xs);color:var(--ink-2);
  transition:background var(--duration) var(--easing)
}
.usa-link:hover{background:var(--surface-0)}
.usa-flag{width:16px;height:10px;background:repeating-linear-gradient(to bottom,#B22 0 1.2px,#fff 1.2px 2.4px);border-radius:1px;position:relative}
.usa-flag::before{content:"";position:absolute;top:0;left:0;width:7px;height:5.5px;background:#234}
.header-right{display:flex;align-items:center;gap:var(--space-3)}
.btn-text{color:var(--ink-2);font-size:var(--size-sm);font-weight:var(--weight-medium);padding:var(--space-2) 0}
.btn-text:hover{color:var(--ink-1)}
.acct-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:5px 12px 5px 5px;border:1px solid var(--line-1);border-radius:var(--radius-pill);background:var(--surface-0)}
.acct-chip:hover{border-color:var(--line-2);background:var(--surface-1)}
.acct-chip .acct-av{width:28px;height:28px;border-radius:50%;background:var(--brand-green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--size-xs);font-weight:var(--weight-bold)}
.acct-chip .acct-nm{font-size:var(--size-sm);font-weight:var(--weight-medium);color:var(--ink-1);max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Nav ── */
.nav{border-bottom:1px solid var(--line-1);background:var(--surface-0);position:sticky;top:0;z-index:40}
.nav ul{list-style:none;margin:0;padding:6px 0;display:flex;gap:2px}
.nav li{position:relative}
.nav > .container > ul > li > a{
  display:inline-flex;align-items:center;gap:6px;
  padding:var(--space-2) var(--space-3);
  font-size:var(--size-sm);font-weight:var(--weight-medium);
  color:var(--ink-2);border-radius:var(--radius-sm);cursor:pointer;
  transition:background var(--duration) var(--easing), color var(--duration) var(--easing);
}
.nav > .container > ul > li > a:hover{background:var(--surface-1);color:var(--ink-1)}
.nav a.active{background:var(--brand-green-tint);color:var(--brand-green)}
.nav .chev{font-size:9px;opacity:.6}
.nav .menu{
  list-style:none;margin:0;padding:var(--space-2);position:absolute;left:0;top:100%;
  min-width:210px;background:var(--surface-0);border:1px solid var(--line-1);
  border-radius:var(--radius-sm);box-shadow:var(--shadow-2);
  display:grid;gap:1px;opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity var(--duration) var(--easing),transform var(--duration) var(--easing),visibility var(--duration);
  z-index:50
}
.nav .has-menu:hover .menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav .menu a{display:block;padding:8px 10px;border-radius:3px;font-size:var(--size-sm);color:var(--ink-2)}
.nav .menu a:hover{background:var(--surface-1);color:var(--ink-1)}

/* ── Footer ── */
.site-footer{
  background:var(--surface-0);border-top:1px solid var(--line-1);
  padding:var(--space-16) 0 var(--space-6);color:var(--ink-2);font-size:var(--size-sm);margin-top:var(--space-16)
}
.site-footer .cols{
  display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:var(--space-8);
  padding-bottom:var(--space-8);border-bottom:1px solid var(--line-1)
}
.site-footer h4{
  font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.08em;
  color:var(--ink-3);font-weight:var(--weight-medium);margin:0 0 var(--space-3)
}
.site-footer ul{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-2)}
.site-footer a{color:var(--ink-2)}
.site-footer a:hover{color:var(--ink-1);text-decoration:underline;text-underline-offset:3px}
.site-footer .foot-brand{font-size:20px;margin-bottom:var(--space-2)}
.site-footer .foot-tag{color:var(--ink-3);max-width:300px;line-height:1.55}
.site-footer .foot-bottom{
  margin-top:var(--space-6);display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:var(--space-3);color:var(--ink-3);font-size:var(--size-xs)
}

/* ── Page-title bar + breadcrumb ── */
.page-title{background:var(--surface-0);border-bottom:1px solid var(--line-1);padding:var(--space-8) 0}
.page-title h1{font-size:var(--size-2xl);font-weight:var(--weight-bold);letter-spacing:-0.025em;line-height:var(--leading-tight)}
.crumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--size-xs);color:var(--ink-3);margin-bottom:var(--space-3);flex-wrap:wrap}
.crumb a:hover{color:var(--ink-1)}
.crumb i{font-style:normal;color:var(--line-2)}
.crumb span{color:var(--ink-2)}

/* ── Generic page main ── */
.page-main{padding:var(--space-12) 0}
.layout{display:grid;grid-template-columns:260px 1fr;gap:var(--space-8);align-items:start}
.layout-rev{grid-template-columns:1fr 320px}

/* ── Hero (homepage) ── */
.hero{
  background:linear-gradient(180deg,var(--brand-green) 0%,var(--brand-green-deep) 100%);
  color:#fff;padding:var(--space-16) 0 var(--space-12);position:relative;overflow:hidden
}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(800px 400px at 95% 100%,rgba(255,255,255,0.06),transparent 60%)}
.hero .container{position:relative;z-index:1}
.eyebrow{
  display:inline-flex;align-items:center;gap:var(--space-2);padding:5px 12px;border-radius:var(--radius-pill);
  background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.18);
  color:#fff;font-size:var(--size-xs);font-weight:var(--weight-medium);margin-bottom:var(--space-4);letter-spacing:0.02em
}
.eyebrow .led{width:6px;height:6px;border-radius:50%;background:#9DE39B;box-shadow:0 0 0 3px rgba(157,227,155,0.25)}
.hero h1{font-size:var(--size-2xl);font-weight:var(--weight-bold);letter-spacing:-0.025em;line-height:1.05;color:#fff;max-width:18ch}
.hero .sub{margin-top:var(--space-4);font-size:var(--size-lg);color:rgba(255,255,255,0.82);max-width:52ch;line-height:1.5}

/* ── Search composite ── */
.search-card{
  margin-top:var(--space-8);background:var(--surface-0);border-radius:var(--radius-sm);padding:6px;
  display:grid;grid-template-columns:1.4fr 1fr auto;align-items:stretch;box-shadow:var(--shadow-2);max-width:780px
}
.search-card.on-surface{box-shadow:none;border:1px solid var(--line-1)}
.search-card .field{display:grid;gap:2px;padding:10px 16px;border-right:1px solid var(--line-1)}
.search-card .field:nth-of-type(2){border-right:0}
.search-card .field label{font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-3);font-weight:var(--weight-medium)}
.search-card .field input,.search-card .field select{
  border:0;background:transparent;outline:none;font:inherit;font-size:var(--size-md);
  color:var(--ink-1);padding:2px 0 0;width:100%;appearance:none;-webkit-appearance:none
}
.search-card .field input::placeholder{color:var(--ink-3)}
.search-card .field:focus-within label{color:var(--brand-green)}
.search-card .field.field-select{position:relative}
.search-card .field.field-select::after{
  content:"";position:absolute;right:18px;top:50%;width:8px;height:8px;
  border-right:1.5px solid var(--ink-2);border-bottom:1.5px solid var(--ink-2);
  transform:translateY(-70%) rotate(45deg);pointer-events:none
}
.search-card .field.field-select select{cursor:pointer;padding-right:24px}
.search-card button.submit{
  margin:4px;padding:0 22px;background:var(--brand-orange);color:#fff;border-radius:var(--radius-sm);
  font-weight:var(--weight-medium);font-size:var(--size-sm);display:inline-flex;align-items:center;gap:var(--space-2)
}
.search-card button.submit:hover{background:var(--brand-orange-hover)}

/* active strip + tabs (homepage) */
.active-strip{margin-top:var(--space-4);display:flex;justify-content:space-between;align-items:center;color:rgba(255,255,255,0.78);font-size:var(--size-sm);gap:var(--space-3) var(--space-4);flex-wrap:wrap}
.active-strip .chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:5px 12px;border-radius:var(--radius-pill);background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.18);color:#fff;font-weight:var(--weight-medium);font-size:var(--size-xs)}
.active-strip .chip b{font-variant-numeric:tabular-nums}
.active-strip .links{display:flex;gap:var(--space-4);flex-wrap:wrap}
.active-strip .links a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.tabs-wrap{margin-top:calc(var(--space-6) * -1);position:relative;z-index:2;display:flex;justify-content:center}
.tabs{display:inline-flex;gap:2px;padding:4px;background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);box-shadow:var(--shadow-2)}
.tabs button{padding:var(--space-2) var(--space-4);border-radius:3px;font-size:var(--size-sm);font-weight:var(--weight-medium);color:var(--ink-2);transition:background var(--duration) var(--easing),color var(--duration) var(--easing)}
.tabs button.on{background:var(--ink-1);color:#fff}
.tabs button:not(.on):hover{color:var(--ink-1);background:var(--surface-1)}

/* ── Section header ── */
.section{padding:var(--space-16) 0 var(--space-12)}
.section-head{margin-bottom:var(--space-8)}
.eyebrow-label{font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.1em;color:var(--ink-3);font-weight:var(--weight-medium);margin-bottom:var(--space-2)}
.section-title{font-size:var(--size-xl);font-weight:var(--weight-bold);letter-spacing:-0.015em;line-height:var(--leading-tight);color:var(--ink-1)}
.section-sub{margin-top:var(--space-3);display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-4);flex-wrap:wrap}
.section-sub p{margin:0;color:var(--ink-2);max-width:50ch}
.section-sub .controls{display:flex;gap:var(--space-4);font-size:var(--size-sm);color:var(--ink-2)}
.section-sub .controls a{cursor:pointer}
.section-sub .controls a:hover{color:var(--ink-1);text-decoration:underline;text-underline-offset:3px}

/* ── List rows (employers / locations / categories) ── */
.dir-list{display:grid;grid-template-columns:repeat(4,1fr);column-gap:var(--space-8);list-style:none;padding:0;margin:0}
.dir-list.cols-3{grid-template-columns:repeat(3,1fr)}
.dir-list.cols-2{grid-template-columns:repeat(2,1fr)}
.dir-list li{margin:0}
.dir-list li a{
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:var(--space-3);
  padding:var(--space-3) var(--space-4) var(--space-3) 0;border-bottom:1px solid var(--line-1);
  font-size:var(--size-sm);color:var(--ink-1);transition:background var(--duration) var(--easing),color var(--duration) var(--easing)
}
.dir-list li a:hover{background:var(--surface-1);color:var(--brand-green)}
.dir-list .name{font-weight:var(--weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.dir-list .count{color:var(--ink-3);font-size:var(--size-xs);font-variant-numeric:tabular-nums;flex-shrink:0}
.more-row{margin-top:var(--space-8);display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap;padding-top:var(--space-6);border-top:1px solid var(--line-1)}

/* ── Job result rows ── */
.results-head{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-4)}
.results-head .count-label{font-size:var(--size-sm);color:var(--ink-2)}
.results-head .count-label b{color:var(--ink-1);font-variant-numeric:tabular-nums}
.results-head .sort{font-size:var(--size-sm);color:var(--ink-2);display:flex;gap:var(--space-4)}
.results-head .sort a{cursor:pointer}
.results-head .sort a:hover{color:var(--ink-1)}
.job-list{display:grid;gap:var(--space-3)}
.job-card{
  background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);
  padding:var(--space-6);display:grid;grid-template-columns:48px 1fr auto;gap:var(--space-4);align-items:start;
  transition:border-color var(--duration) var(--easing),box-shadow var(--duration) var(--easing)
}
.job-card:hover{border-color:var(--line-2);box-shadow:var(--shadow-2)}
.job-logo{width:48px;height:48px;border-radius:var(--radius-sm);background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-weight:var(--weight-bold);color:var(--ink-3);font-size:var(--size-lg);overflow:hidden}
.job-card .title{font-size:var(--size-lg);font-weight:var(--weight-bold);letter-spacing:-0.01em;line-height:1.25}
.job-card .title a:hover{color:var(--brand-green)}
.job-meta{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);margin-top:var(--space-2);font-size:var(--size-sm);color:var(--ink-2)}
.job-meta .m{display:inline-flex;align-items:center;gap:6px}
.job-meta svg{width:13px;height:13px;color:var(--ink-3);flex-shrink:0}
.job-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}
.tag-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-pill);background:var(--surface-1);border:1px solid var(--line-1);font-size:var(--size-xs);color:var(--ink-2);font-weight:var(--weight-medium)}
.tag-chip.verified{color:var(--accent-blue)}
.tag-chip.verified .led{width:6px;height:6px;border-radius:50%;background:var(--accent-blue)}
.job-card .aside{display:grid;gap:var(--space-2);justify-items:end;text-align:right}
.job-card .posted{font-size:var(--size-xs);color:var(--ink-3);white-space:nowrap}
.job-card .salary{font-size:var(--size-sm);font-weight:var(--weight-bold);color:var(--ink-1);white-space:nowrap}

/* ── Filter sidebar ── */
.filter{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);overflow:hidden;position:sticky;top:64px}
.filter h3{font-size:var(--size-sm);font-weight:var(--weight-bold);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--line-1)}
.filter-list{list-style:none;margin:0;padding:var(--space-2)}
.filter-list a{display:flex;justify-content:space-between;gap:var(--space-3);padding:8px 12px;border-radius:var(--radius-sm);font-size:var(--size-sm);color:var(--ink-2)}
.filter-list a:hover{background:var(--surface-1);color:var(--ink-1)}
.filter-list a.on{background:var(--brand-green-tint);color:var(--brand-green);font-weight:var(--weight-medium)}
.filter-list .count{color:var(--ink-3);font-variant-numeric:tabular-nums}
.filter-list a.on .count{color:var(--brand-green)}

/* ── Job detail ── */
.detail-card{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);padding:var(--space-12)}
.detail-head{display:flex;gap:var(--space-6);align-items:flex-start;padding-bottom:var(--space-6);border-bottom:1px solid var(--line-1);margin-bottom:var(--space-6)}
.detail-head .job-logo{width:64px;height:64px;font-size:var(--size-xl)}
.detail-head h1{font-size:var(--size-2xl);font-weight:var(--weight-bold);letter-spacing:-0.02em;line-height:1.1}
.detail-head .by{margin-top:var(--space-2);color:var(--ink-2);font-size:var(--size-md)}
.detail-head .by b{color:var(--ink-1)}
.fact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}
.fact{border:1px solid var(--line-1);border-radius:var(--radius-sm);padding:var(--space-4)}
.fact .lab{font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);font-weight:var(--weight-medium)}
.fact .val{font-size:var(--size-md);font-weight:var(--weight-medium);color:var(--ink-1);margin-top:4px}
.prose{color:var(--ink-2);line-height:1.7;max-width:68ch}
.prose h2,.prose h3{color:var(--ink-1);margin:var(--space-8) 0 var(--space-3);font-size:var(--size-lg)}
.prose p{margin:0 0 var(--space-4)}
.prose strong{color:var(--ink-1)}
.prose ul{margin:0 0 var(--space-4);padding-left:var(--space-6)}
.prose li{margin-bottom:var(--space-2)}
.prose a{color:var(--accent-blue);text-decoration:underline;text-underline-offset:2px}
.prose a:hover{color:var(--accent-blue-hover)}

/* sidebar widget */
.widget{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);padding:var(--space-6);display:grid;gap:var(--space-4)}
.widget + .widget{margin-top:var(--space-4)}
.widget h3{font-size:var(--size-sm);font-weight:var(--weight-bold)}
.widget .share{display:flex;gap:var(--space-2)}
.widget .share a{width:36px;height:36px;border:1px solid var(--line-1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--ink-2)}
.widget .share a:hover{background:var(--surface-1);color:var(--brand-green);border-color:var(--line-2)}
.mini-list{display:grid;gap:0}
.mini-list a{display:block;padding:var(--space-3) 0;border-top:1px solid var(--line-1);font-size:var(--size-sm)}
.mini-list a:first-child{border-top:0}
.mini-list a:hover .mt{color:var(--brand-green)}
.mini-list .mt{font-weight:var(--weight-medium);color:var(--ink-1)}
.mini-list .ms{font-size:var(--size-xs);color:var(--ink-3);display:flex;align-items:center;gap:4px;margin-top:2px}

/* ── Forms ── */
.form-card{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);padding:var(--space-12)}
.form-card + .form-card{margin-top:var(--space-6)}
.form-section-title{font-size:var(--size-lg);font-weight:var(--weight-bold);margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1px solid var(--line-1)}
.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
.form-grid .span-2{grid-column:span 2}
.form-grid .span-3{grid-column:1 / -1}
.field-row{display:grid;gap:var(--space-1)}
.field-row label{font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);font-weight:var(--weight-medium)}
.field-row label .req{color:var(--status-danger);margin-left:2px}
.input,.select,.textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line-2);border-radius:var(--radius-sm);
  background:var(--surface-0);font:inherit;font-size:var(--size-md);color:var(--ink-1);
  transition:border-color var(--duration) var(--easing),box-shadow var(--duration) var(--easing)
}
.select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--ink-2) 50%),linear-gradient(135deg,var(--ink-2) 50%,transparent 50%);background-position:calc(100% - 18px) 18px,calc(100% - 12px) 18px;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:36px;cursor:pointer}
.textarea{min-height:120px;resize:vertical;line-height:1.6}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand-green);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand-green) 18%,transparent)}
.input::placeholder{color:var(--ink-3)}
.check{display:flex;gap:var(--space-3);align-items:flex-start;font-size:var(--size-sm);color:var(--ink-2);line-height:1.5}
.check input{width:18px;height:18px;margin-top:1px;accent-color:var(--brand-green);flex-shrink:0}
.captcha{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}
.captcha .glyphs{font-family:var(--font-mono);font-size:24px;letter-spacing:6px;font-weight:var(--weight-bold);color:var(--ink-1);background:var(--surface-1);border:1px dashed var(--line-2);border-radius:var(--radius-sm);padding:8px 16px;user-select:none;text-decoration:line-through}
.captcha .refresh{font-size:var(--size-xs);color:var(--brand-green);cursor:pointer}
.form-actions{margin-top:var(--space-8);display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}
.form-note{font-size:var(--size-sm);color:var(--ink-3)}

/* ── Auth card ── */
.auth-wrap{max-width:440px;margin:0 auto}
.auth-card{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);box-shadow:var(--shadow-2);padding:var(--space-12)}
.auth-card h1,.auth-card h2{font-size:var(--size-xl);font-weight:var(--weight-bold);letter-spacing:-0.015em;margin-bottom:var(--space-2)}
.auth-card .lead{color:var(--ink-2);font-size:var(--size-sm);margin-bottom:var(--space-8)}
.auth-card .field-row{margin-bottom:var(--space-4)}
.auth-row{display:flex;justify-content:space-between;align-items:center;font-size:var(--size-sm);margin:var(--space-2) 0 var(--space-6)}
.auth-row a{color:var(--brand-green)}
.auth-row a:hover{text-decoration:underline;text-underline-offset:2px}
.auth-foot{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--line-1);text-align:center;font-size:var(--size-sm);color:var(--ink-2)}
.auth-foot a{color:var(--brand-green);font-weight:var(--weight-medium)}
.auth-aside{background:var(--brand-green);color:#fff;border-radius:var(--radius-sm);padding:var(--space-8);align-self:start}
.auth-aside h2{font-size:var(--size-lg);margin-bottom:var(--space-4)}
.auth-aside ul{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-3);font-size:var(--size-sm);color:rgba(255,255,255,0.88)}
.auth-aside li{display:flex;gap:var(--space-2)}
.auth-aside li::before{content:"✓";color:#9DE39B;font-weight:var(--weight-bold)}
/* Auth two-up (login form + green aside). 2-col on desktop, single-col on mobile
   (form first, green card below) — replaces per-page inline grid so it stays responsive. */
.auth-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-12);max-width:880px;margin:0 auto;align-items:center}

/* ── Pricing ── */
.price-tiers{display:grid;gap:var(--space-3)}
.tier{
  background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);
  padding:var(--space-6) var(--space-8);display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-6);align-items:center;
  transition:border-color var(--duration) var(--easing),box-shadow var(--duration) var(--easing)
}
.tier:hover{border-color:var(--line-2);box-shadow:var(--shadow-2)}
.tier.featured{border-color:var(--brand-green);box-shadow:var(--shadow-2)}
.tier .days{font-size:var(--size-2xl);font-weight:var(--weight-bold);letter-spacing:-0.02em;line-height:1;color:var(--ink-1)}
.tier .days small{display:block;font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);font-weight:var(--weight-medium);margin-top:4px}
.tier .desc{color:var(--ink-2);font-size:var(--size-sm)}
.tier .desc .free{color:var(--status-success);font-weight:var(--weight-medium)}
.tier .price{font-size:var(--size-xl);font-weight:var(--weight-bold);color:var(--ink-1);white-space:nowrap}
.tier .price small{font-size:var(--size-xs);color:var(--ink-3);font-weight:var(--weight-regular)}

/* ── Pagination ── */
.pagination{display:flex;gap:var(--space-2);justify-content:center;margin-top:var(--space-8);align-items:center}
.pagination a,.pagination span{min-width:36px;height:36px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line-1);border-radius:var(--radius-sm);font-size:var(--size-sm);color:var(--ink-2);background:var(--surface-0)}
.pagination a:hover{border-color:var(--line-2);color:var(--ink-1)}
.pagination .on{background:var(--ink-1);color:#fff;border-color:var(--ink-1);font-weight:var(--weight-medium)}
.pagination .gap{border:0;background:none}

/* ── Empty state ── */
.empty{background:var(--surface-0);border:1px dashed var(--line-2);border-radius:var(--radius-sm);padding:var(--space-16);text-align:center}
.empty h3{font-size:var(--size-lg);margin-bottom:var(--space-2)}
.empty p{color:var(--ink-2);max-width:42ch;margin:0 auto}

/* ── Content page (about / advertise prose) ── */
.content-card{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);padding:var(--space-12)}

/* ════════════════════════════════════════════════════════════
   DASHBOARD (logged-in) — shells, tables, stats, wizard, checkout
   ════════════════════════════════════════════════════════════ */
.dash{padding:var(--space-8) 0 var(--space-16)}
.dash-grid{display:grid;grid-template-columns:248px 1fr;gap:var(--space-8);align-items:start}
.dash-side{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);overflow:hidden;position:sticky;top:64px}
.dash-user{display:flex;gap:var(--space-3);align-items:center;padding:var(--space-6);border-bottom:1px solid var(--line-1)}
.dash-user .avatar{width:44px;height:44px;border-radius:50%;background:var(--brand-green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--weight-bold);font-size:var(--size-md);flex-shrink:0}
.dash-user .who{min-width:0}
.dash-user .who .nm{font-weight:var(--weight-bold);font-size:var(--size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-user .who .rl{font-size:var(--size-xs);color:var(--ink-3)}
.dash-nav{list-style:none;margin:0;padding:var(--space-2)}
.dash-nav a{display:flex;align-items:center;gap:var(--space-3);padding:10px 12px;border-radius:var(--radius-sm);font-size:var(--size-sm);color:var(--ink-2);font-weight:var(--weight-medium)}
.dash-nav a:hover{background:var(--surface-1);color:var(--ink-1)}
.dash-nav a.on{background:var(--brand-green-tint);color:var(--brand-green)}
.dash-nav svg{width:16px;height:16px;flex-shrink:0;color:currentColor}
.dash-nav .sep{height:1px;background:var(--line-1);margin:var(--space-2) 8px}
.dash-main{min-width:0;display:grid;gap:var(--space-6)}
.dash-head{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-4);flex-wrap:wrap}
.dash-head h1{font-size:var(--size-xl);font-weight:var(--weight-bold);letter-spacing:-0.015em}
.dash-head p{margin:4px 0 0;color:var(--ink-2);font-size:var(--size-sm)}

.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}
.stat{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);padding:var(--space-6)}
.stat .v{font-size:var(--size-2xl);font-weight:var(--weight-bold);letter-spacing:-0.02em;line-height:1;font-variant-numeric:tabular-nums}
.stat .l{font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);font-weight:var(--weight-medium);margin-top:var(--space-2)}
.stat.accent .v{color:var(--brand-green)}
.stat.info .v{color:var(--accent-blue)}
.stat.info{border-top:2px solid var(--accent-blue)}

/* trust / verification chip (blue = trust, distinct from success-green) */
.chip-verified{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-pill);background:var(--accent-blue-tint);color:var(--accent-blue);font-size:var(--size-xs);font-weight:var(--weight-medium)}
.chip-verified svg{width:13px;height:13px}

/* informational banner (system tip / notice — NOT an action) */
.info-tip{display:flex;gap:var(--space-3);align-items:flex-start;background:var(--accent-blue-tint);border:1px solid color-mix(in srgb,var(--accent-blue) 22%,transparent);border-radius:var(--radius-sm);padding:14px var(--space-6);font-size:var(--size-sm);color:var(--ink-2)}
.info-tip svg{width:18px;height:18px;color:var(--accent-blue);flex-shrink:0;margin-top:1px}
.info-tip b{color:var(--ink-1)}
.info-tip a{color:var(--accent-blue);font-weight:var(--weight-medium)}
.info-tip a:hover{color:var(--accent-blue-hover);text-decoration:underline;text-underline-offset:3px}

.panel{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);overflow:hidden}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--line-1)}
.panel-head h2{font-size:var(--size-sm);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-2)}
.panel-head a{font-size:var(--size-sm);color:var(--accent-blue);font-weight:var(--weight-medium)}
.panel-head a:hover{color:var(--accent-blue-hover);text-decoration:underline;text-underline-offset:3px}
.panel-body{padding:var(--space-6)}
.panel-body.flush{padding:0}

/* data table */
.table{width:100%;border-collapse:collapse;font-size:var(--size-sm)}
.table th{text-align:left;font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);font-weight:var(--weight-medium);padding:12px var(--space-6);border-bottom:1px solid var(--line-1);background:var(--surface-1)}
.table td{padding:14px var(--space-6);border-bottom:1px solid var(--line-1);color:var(--ink-1);vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tbody tr:hover{background:var(--surface-1)}
.table .strong{font-weight:var(--weight-medium)}
.table .muted{color:var(--ink-3);font-variant-numeric:tabular-nums}
.table .row-actions{display:flex;gap:var(--space-2);justify-content:flex-end}
.table .row-actions a{font-size:var(--size-xs);color:var(--ink-2);padding:4px 8px;border:1px solid var(--line-1);border-radius:var(--radius-sm)}
.table .row-actions a:hover{border-color:var(--accent-blue);color:var(--accent-blue)}
.table .row-actions a.danger:hover{color:var(--status-danger);border-color:var(--status-danger)}

.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-pill);font-size:var(--size-xs);font-weight:var(--weight-medium)}
.badge .dot{width:6px;height:6px;border-radius:50%}
.badge.live{background:color-mix(in srgb,var(--status-success) 12%,transparent);color:var(--status-success)}
.badge.live .dot{background:var(--status-success)}
.badge.pending{background:color-mix(in srgb,var(--status-warning) 14%,transparent);color:var(--status-warning)}
.badge.pending .dot{background:var(--status-warning)}
.badge.expired{background:var(--surface-2);color:var(--ink-3)}
.badge.expired .dot{background:var(--ink-3)}
.badge.review{background:var(--accent-blue-tint);color:var(--accent-blue)}
.badge.review .dot{background:var(--accent-blue)}
.badge.new{background:var(--accent-blue-tint);color:var(--accent-blue)}
.badge.new .dot{background:var(--accent-blue)}

/* category checkbox grid (resume prefs) */
.check-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2) var(--space-4)}
.check-grid label{display:flex;gap:var(--space-2);align-items:center;font-size:var(--size-sm);color:var(--ink-2);padding:4px 0;cursor:pointer}
.check-grid input{width:16px;height:16px;accent-color:var(--brand-green);flex-shrink:0}

/* ── Multi-step wizard ── */
.steps{display:flex;align-items:center;gap:0;margin-bottom:var(--space-8);flex-wrap:wrap}
.step{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:160px}
.step .num{width:30px;height:30px;border-radius:50%;border:2px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-size:var(--size-sm);font-weight:var(--weight-bold);color:var(--ink-3);flex-shrink:0;background:var(--surface-0)}
.step .tx{font-size:var(--size-sm);color:var(--ink-3);font-weight:var(--weight-medium)}
.step .bar{flex:1;height:2px;background:var(--line-1);margin:0 var(--space-3)}
.step.done .num{background:var(--brand-green);border-color:var(--brand-green);color:#fff}
.step.done .tx{color:var(--ink-1)}
.step.active .num{border-color:var(--brand-green);color:var(--brand-green)}
.step.active .tx{color:var(--brand-green)}

/* ── Checkout summary ── */
.checkout{display:grid;grid-template-columns:1fr 360px;gap:var(--space-8);align-items:start}
.summary{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);overflow:hidden;position:sticky;top:64px}
.summary .sh{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--line-1);font-size:var(--size-sm);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-2)}
.summary .line{display:flex;justify-content:space-between;gap:var(--space-3);padding:10px var(--space-6);font-size:var(--size-sm);color:var(--ink-2)}
.summary .line.total{border-top:1px solid var(--line-1);margin-top:var(--space-2);padding-top:var(--space-4);font-size:var(--size-lg);font-weight:var(--weight-bold);color:var(--ink-1)}
.summary .line .free{color:var(--status-success);font-weight:var(--weight-medium)}
.summary .foot{padding:var(--space-6);border-top:1px solid var(--line-1)}

/* ── Posting option cards (select plan) ── */
.opt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.opt{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);padding:var(--space-8);display:grid;gap:var(--space-3);cursor:pointer;transition:border-color var(--duration) var(--easing),box-shadow var(--duration) var(--easing)}
.opt:hover{border-color:var(--line-2)}
.opt.on{border-color:var(--brand-green);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand-green) 16%,transparent)}
.opt .tier-name{font-size:var(--size-sm);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);font-weight:var(--weight-medium)}
.opt .tier-price{font-size:var(--size-2xl);font-weight:var(--weight-bold);letter-spacing:-0.02em;line-height:1}
.opt .tier-price small{font-size:var(--size-sm);color:var(--ink-3);font-weight:var(--weight-regular)}
.opt ul{list-style:none;margin:var(--space-2) 0 0;padding:0;display:grid;gap:var(--space-2);font-size:var(--size-sm);color:var(--ink-2)}
.opt ul li{display:flex;gap:var(--space-2)}
.opt ul li::before{content:"✓";color:var(--brand-green);font-weight:var(--weight-bold)}
.opt .ribbon{display:inline-block;align-self:start;background:var(--brand-orange);color:#fff;font-size:var(--size-xs);font-weight:var(--weight-medium);padding:3px 10px;border-radius:var(--radius-pill)}

/* ── Sitemap ── */
.sitemap{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-8)}
.sitemap h3{font-size:var(--size-sm);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);font-weight:var(--weight-medium);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--line-1)}
.sitemap ul{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-2)}
.sitemap a{font-size:var(--size-sm);color:var(--ink-2)}
.sitemap a:hover{color:var(--brand-green)}

/* ── Blog ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
.post{background:var(--surface-0);border:1px solid var(--line-1);border-radius:var(--radius-sm);overflow:hidden;display:flex;flex-direction:column;transition:border-color var(--duration) var(--easing),box-shadow var(--duration) var(--easing)}
.post:hover{border-color:var(--line-2);box-shadow:var(--shadow-2)}
.post .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--brand-green),var(--brand-green-deep));display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.85);font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.08em;font-weight:var(--weight-medium)}
.post .thumb.alt{background:linear-gradient(135deg,var(--brand-orange),var(--brand-orange-hover))}
.post .body{padding:var(--space-6);display:grid;gap:var(--space-2);flex:1}
.post .cat{font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.06em;color:var(--brand-orange);font-weight:var(--weight-medium)}
.post .ti{font-size:var(--size-lg);font-weight:var(--weight-bold);line-height:1.3;letter-spacing:-0.01em}
.post:hover .ti{color:var(--brand-green)}
.post .ex{font-size:var(--size-sm);color:var(--ink-2);line-height:1.55}
.post .meta{margin-top:auto;padding-top:var(--space-3);font-size:var(--size-xs);color:var(--ink-3)}

/* ── Contact ── */
.contact-grid{display:grid;grid-template-columns:1fr 360px;gap:var(--space-8);align-items:start}
.contact-info{display:grid;gap:var(--space-4)}
.contact-info .item{display:flex;gap:var(--space-3);align-items:flex-start}
.contact-info .item svg{width:18px;height:18px;color:var(--brand-green);flex-shrink:0;margin-top:2px}
.contact-info .item .k{font-size:var(--size-xs);text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-3);font-weight:var(--weight-medium)}
.contact-info .item .vv{font-size:var(--size-md);color:var(--ink-1);margin-top:2px}

/* ── Auth: forgot password ── */
.auth-narrow{max-width:440px;margin:0 auto}

/* ── Responsive ── */
@media (max-width:980px){
  .dash-grid{grid-template-columns:1fr}
  .dash-side{position:static}
  .stat-row{grid-template-columns:1fr 1fr}
  .check-grid{grid-template-columns:1fr 1fr}
  .checkout{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .opt-grid{grid-template-columns:1fr}
  .sitemap{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:980px){
  .header .row{grid-template-columns:1fr;gap:var(--space-3)}
  .header-mid{justify-content:flex-start}
  .header-right{justify-content:flex-start;flex-wrap:wrap}
  .layout,.layout-rev,.auth-grid{grid-template-columns:1fr}
  .filter{position:static}
  .dir-list{grid-template-columns:1fr 1fr;column-gap:var(--space-4)}
  .site-footer .cols{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr 1fr}
  .fact-grid{grid-template-columns:1fr 1fr}
  .search-card{grid-template-columns:1fr;padding:var(--space-2)}
  .search-card .field{border-right:0;border-bottom:1px solid var(--line-1)}
  .search-card button.submit{margin:var(--space-2);justify-content:center}
  .hero h1{font-size:28px}
  .nav{position:static}
  .nav ul{flex-wrap:wrap}
  .nav .menu{position:static;box-shadow:none;opacity:1;visibility:visible;transform:none;display:none}
}
@media (max-width:620px){
  .dir-list{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  /* span items must not create implicit extra columns when the grid is 1-col */
  .form-grid .span-2,.form-grid .span-3{grid-column:auto}
  /* roomier prose on small screens (48px padding pinched the measure) */
  .content-card{padding:var(--space-6)}
  /* stack the detail avatar above the title so a long name can't overlap it */
  .detail-head{flex-direction:column;gap:var(--space-3)}
  .fact-grid{grid-template-columns:1fr 1fr}
  .job-card{grid-template-columns:1fr;gap:var(--space-3)}
  .job-card .aside{justify-items:start;text-align:left}
  .tier{grid-template-columns:1fr;gap:var(--space-3);text-align:left}
  .site-footer .cols{grid-template-columns:1fr}
}
