/* ===================================================================
   PIECEWORK — workwear-label aesthetic
   cream paper · ink navy · amber · stitched frames · pixel type
   =================================================================== */

:root{
  --paper:#EAE2D0;
  --paper2:#E2D8C2;
  --paper3:#D9CDB3;
  --ink:#202432;
  --ink2:#33384a;
  --soft:#7c7768;
  --amber:#D88A2C;
  --amber-d:#b06f22;
  --warm:#C6BCA6;
  --line:#b6aa90;
  --good:#3f9a6d;
  --pixel:'Silkscreen', monospace;
  --term:'VT323', monospace;
  --shadow:0 6px 0 rgba(32,36,50,.10);
}
body.night{
  --paper:#191d2c;
  --paper2:#13172333;
  --paper2:#141826;
  --paper3:#10131f;
  --ink:#ECE4D2;
  --ink2:#cdc6b6;
  --soft:#8b91a8;
  --warm:#2b3046;
  --line:#39405a;
  --shadow:0 6px 0 rgba(0,0,0,.30);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--term);
  font-size:20px;
  line-height:1.25;
  -webkit-font-smoothing:none;
  image-rendering:pixelated;
  overflow-x:hidden;
  transition:background .4s, color .4s;
}
img{image-rendering:pixelated}
a{color:inherit;text-decoration:none}

/* paper grain */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;
  background-image:radial-gradient(var(--warm) 1px, transparent 1px);
  background-size:7px 7px;
  mix-blend-mode:multiply;
}
body.night .grain{mix-blend-mode:screen;opacity:.16}

/* ---------- shared framing ---------- */
.stitch{
  border:2px dashed var(--ink);
  background:var(--paper2);
  position:relative;
}
.plusframe::before,.plusframe::after,
.plusframe>.pl,.plusframe>.pr{}
.plusframe{
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11'%3E%3Cpath d='M5 1h1v9h-1z M1 5h9v1h-9z' fill='%23D88A2C'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11'%3E%3Cpath d='M5 1h1v9h-1z M1 5h9v1h-9z' fill='%23D88A2C'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11'%3E%3Cpath d='M5 1h1v9h-1z M1 5h9v1h-9z' fill='%23D88A2C'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11'%3E%3Cpath d='M5 1h1v9h-1z M1 5h9v1h-9z' fill='%23D88A2C'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:6px 6px, calc(100% - 6px) 6px, 6px calc(100% - 6px), calc(100% - 6px) calc(100% - 6px);
}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--pixel);
  font-size:11px;
  letter-spacing:.5px;
  padding:13px 18px;
  border:2px solid var(--ink);
  background:var(--paper);
  color:var(--ink);
  cursor:pointer;
  box-shadow:var(--shadow);
  transition:transform .08s, box-shadow .08s, background .15s;
  display:inline-flex;align-items:center;gap:8px;
  text-transform:uppercase;
}
.btn small{font-family:var(--term);font-size:15px;letter-spacing:0;opacity:.7;text-transform:none}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 0 rgba(32,36,50,.16)}
.btn:active{transform:translateY(3px);box-shadow:0 1px 0 rgba(32,36,50,.16)}
.btn-amber{background:var(--amber);color:#231a10;border-color:#231a10}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ghost{background:transparent}
.btn.big{font-size:13px;padding:16px 24px}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:18px;
  padding:12px 28px;
  background:var(--paper);
  border-bottom:2px dashed var(--ink);
}
.brand{font-family:var(--pixel);font-size:20px;display:flex;align-items:center;gap:2px}
.brand-piece{color:var(--ink)}
.brand-work{color:var(--amber)}
.brand-moon{color:var(--amber);margin-left:8px;font-size:16px}
.nav-links{display:flex;gap:22px;font-size:21px}
.nav-links a{position:relative;color:var(--soft);transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-links a::after{content:'';position:absolute;left:0;right:100%;bottom:-3px;height:2px;background:var(--amber);transition:right .2s}
.nav-links a:hover::after{right:0}
.nav-right{display:flex;align-items:center;gap:12px}
.night-toggle{
  width:38px;height:38px;border:2px solid var(--ink);background:var(--paper);
  color:var(--amber);font-size:18px;cursor:pointer;line-height:1;
}
.night-toggle:hover{background:var(--ink);color:var(--amber)}

/* ---------- HERO ---------- */
.hero{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;
  max-width:1200px;margin:0 auto;padding:70px 28px 40px;
}
.kicker{font-family:var(--pixel);font-size:10px;letter-spacing:1px;color:var(--soft);margin-bottom:22px}
.kicker .tick{color:var(--amber)}
.hero h1{
  font-family:var(--pixel);font-size:54px;line-height:1.05;letter-spacing:1px;
  text-shadow:4px 4px 0 var(--warm);
}
.amber{color:var(--amber)}
.lede{font-size:25px;color:var(--ink2);max-width:30ch;margin:24px 0 30px;line-height:1.15}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats b{font-family:var(--pixel);font-size:22px;color:var(--ink)}
.hero-stats span{font-size:16px;color:var(--soft);letter-spacing:.5px}

.hero-art{display:flex;flex-direction:column;align-items:center;gap:14px}
.frame{
  width:100%;max-width:420px;aspect-ratio:1;padding:14px;
  box-shadow:var(--shadow);
}
.stack{position:relative;width:100%;height:100%;background:var(--paper3);overflow:hidden}
.stack img{
  position:absolute;inset:0;width:100%;height:100%;
  image-rendering:pixelated;
}
.frame-tag{
  position:absolute;bottom:6px;right:8px;font-family:var(--pixel);font-size:8px;
  color:var(--paper);background:var(--ink);padding:3px 6px;letter-spacing:1px;z-index:30;
}
.hero-caption{font-family:var(--pixel);font-size:10px;letter-spacing:3px;color:var(--soft)}

/* cut-lines overlay */
.cutlines{position:absolute;inset:0;pointer-events:none;z-index:25;opacity:0;transition:opacity .3s}
.cutlines.idle{opacity:.55}
.cutlines::before,.cutlines::after{
  content:'';position:absolute;left:6%;right:6%;height:0;
  border-top:2px dashed rgba(32,36,50,.45);
}
body.night .cutlines::before,body.night .cutlines::after{border-top-color:rgba(255,255,255,.30)}
.cutlines::before{top:38%}
.cutlines::after{top:64%}

/* assembly anim */
.stack img.layer{opacity:0}
.stack img.in{animation:dropIn .42s cubic-bezier(.2,1.3,.4,1) forwards}
@keyframes dropIn{
  0%{opacity:0;transform:translateY(-14px) scale(1.02)}
  60%{opacity:1}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

/* scanline sweep on randomize */
.scan{position:absolute;inset:0;z-index:28;pointer-events:none;opacity:0}
.scan.go{opacity:1;animation:scan .5s linear}
.scan::before{content:'';position:absolute;left:0;right:0;height:14%;
  background:linear-gradient(transparent,rgba(216,138,44,.5),transparent)}
@keyframes scan{0%{}100%{}}
.scan.go::before{animation:sweep .5s linear}
@keyframes sweep{0%{top:-14%}100%{top:100%}}

/* ---------- MARQUEE ---------- */
.marquee{position:relative;z-index:2;overflow:hidden;border-top:2px dashed var(--ink);border-bottom:2px dashed var(--ink);background:var(--paper2);padding:10px 0;margin-top:20px}
.marquee-track{display:flex;gap:10px;width:max-content;animation:roll 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track img{width:58px;height:58px;background:var(--paper3);border:1px solid var(--line)}
@keyframes roll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- section heads ---------- */
.section-head{max-width:1100px;margin:0 auto;padding:60px 28px 0;text-align:center}
.section-head h2{font-family:var(--pixel);font-size:26px;letter-spacing:1px}
.section-head p{font-size:22px;color:var(--soft);margin:14px auto 0;max-width:54ch}

/* ---------- BUILDER ---------- */
.builder{position:relative;z-index:2;padding-bottom:30px}
.builder-grid{
  max-width:1100px;margin:34px auto 0;padding:0 28px;
  display:grid;grid-template-columns:430px 1fr;gap:34px;align-items:start;
}
.builder-preview{position:sticky;top:78px;display:flex;flex-direction:column;gap:14px}
.builder-preview .frame{max-width:none}

/* badge / punch card */
.badge{padding:12px 14px;background:var(--paper);box-shadow:var(--shadow)}
.badge-row{display:flex;justify-content:space-between;align-items:center}
.badge-co{font-family:var(--pixel);font-size:9px;letter-spacing:1px;color:var(--amber)}
.badge-id{font-family:var(--pixel);font-size:9px;color:var(--soft)}
.badge-name{
  width:100%;border:none;border-bottom:2px dashed var(--line);background:transparent;
  font-family:var(--pixel);font-size:13px;color:var(--ink);
  padding:8px 0 6px;margin:6px 0;letter-spacing:1px;text-transform:uppercase;
}
.badge-name:focus{outline:none;border-bottom-color:var(--amber)}
.badge-name::placeholder{color:var(--line);letter-spacing:.5px}
.badge-rule{height:0;border-top:2px dashed var(--line);margin:4px 0 8px}
.badge-label{font-family:var(--pixel);font-size:9px;color:var(--soft)}
.badge-rarity{font-family:var(--pixel);font-size:12px;color:var(--ink)}
.rarity-bar{height:10px;border:2px solid var(--ink);margin-top:7px;background:var(--paper3)}
.rarity-bar i{display:block;height:100%;width:0;background:var(--amber);transition:width .4s}
.badge-foot{font-size:16px;color:var(--soft);margin-top:6px}

.preview-actions{display:flex;gap:10px}
.preview-actions .btn{flex:1;justify-content:center}

/* category tabs */
.cat-tabs{display:flex;flex-wrap:wrap;gap:8px}
.cat-tabs button{
  font-family:var(--pixel);font-size:9px;letter-spacing:.5px;
  padding:9px 11px;border:2px solid var(--ink);background:var(--paper);color:var(--ink);
  cursor:pointer;text-transform:uppercase;
}
.cat-tabs button.active{background:var(--ink);color:var(--paper)}
.cat-tabs button:hover{transform:translateY(-1px)}
.cat-tabs button.locked{border-color:var(--amber)}
.cat-tabs button.locked::after{content:'🔒';font-size:9px;margin-left:5px}

/* control bar */
.trait-meta{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:18px 2px 12px}
.tm-left{display:flex;align-items:center;gap:8px;min-width:0}
.tm-names{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.tm-names #catLabel{font-family:var(--pixel);font-size:13px}
.tm-current{font-size:17px;color:var(--amber);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.cycle{
  width:30px;height:30px;flex:none;border:2px solid var(--ink);background:var(--paper);
  color:var(--ink);font-size:18px;line-height:1;cursor:pointer;font-family:var(--term);
}
.cycle:hover{background:var(--ink);color:var(--paper)}
.tm-right{display:flex;align-items:center;gap:10px;flex:none}
.lock{
  font-family:var(--pixel);font-size:9px;padding:7px 9px;border:2px solid var(--ink);
  background:var(--paper);color:var(--ink);cursor:pointer;letter-spacing:.5px;
}
.lock.on{background:var(--amber);color:#231a10;border-color:#231a10}
.trait-count{font-size:16px;color:var(--soft)}

/* trait grid */
.trait-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:10px;
  max-height:560px;overflow-y:auto;padding:4px;
}
.trait-grid::-webkit-scrollbar{width:10px}
.trait-grid::-webkit-scrollbar-thumb{background:var(--line);border:2px solid var(--paper)}
.swatch{
  position:relative;aspect-ratio:1;border:2px solid var(--line);background:var(--paper3);
  cursor:pointer;overflow:hidden;transition:transform .08s,border-color .1s;
}
.swatch img{width:100%;height:100%;display:block}
.swatch:hover{transform:translateY(-2px);border-color:var(--ink)}
.swatch.sel{border-color:var(--amber);box-shadow:0 0 0 2px var(--amber)}
.swatch .tip{
  position:absolute;left:0;right:0;bottom:0;font-size:12px;line-height:1.05;
  background:rgba(32,36,50,.82);color:#fff;padding:3px 4px;
  opacity:0;transition:opacity .12s;text-align:center;
}
.swatch:hover .tip{opacity:1}
.swatch.none{display:flex;align-items:center;justify-content:center;background:var(--paper)}
.swatch.none span{font-family:var(--pixel);font-size:9px;color:var(--soft)}
.swatch .rare-dot{position:absolute;top:3px;right:3px;width:8px;height:8px;background:var(--amber);border:1px solid var(--ink)}
/* clearance tier tags (informational while building) */
.swatch .tier-tag{position:absolute;top:3px;left:3px;font-family:var(--pixel);font-size:7px;padding:2px 3px;background:var(--ink);color:var(--paper);letter-spacing:.5px}
.swatch .tier-tag.beyond{background:var(--amber);color:#231a10}
/* clearance readout on the badge */
.badge-clear{font-family:var(--pixel);font-size:11px;color:var(--amber)}
.clear-hint{font-size:15px;color:var(--soft);margin-top:6px;line-height:1.18}
.status-clear{font-family:var(--pixel);font-size:10px;color:var(--amber);margin:10px 0 0;letter-spacing:.5px}

/* ---------- section rhythm ---------- */
.band{background:var(--paper2);border-block:2px dashed var(--ink)}

/* ---------- HOW ---------- */
.how{position:relative;z-index:2}
.steps{max-width:1100px;margin:34px auto 0;padding:0 28px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.step{padding:26px 22px;box-shadow:var(--shadow)}
.step-no{font-family:var(--pixel);font-size:30px;color:var(--amber)}
.step h3{font-family:var(--pixel);font-size:13px;margin:14px 0 10px;letter-spacing:.5px}
.step p{font-size:19px;color:var(--ink2);line-height:1.2}

/* ---------- SCHEDULE / TIMELINE ---------- */
.schedule{position:relative;z-index:2;padding-bottom:60px}
.timeline{max-width:760px;margin:36px auto 0;padding:0 28px;list-style:none;position:relative}
.timeline::before{content:'';position:absolute;left:54px;top:8px;bottom:8px;width:0;border-left:2px dashed var(--ink)}
.timeline li{position:relative;padding:0 0 26px 86px;min-height:44px}
.timeline li::before{
  content:'';position:absolute;left:48px;top:4px;width:14px;height:14px;
  background:var(--paper);border:2px solid var(--ink);
}
.timeline li.t-done::before{background:var(--ink)}
.timeline li.t-now::before{background:var(--amber);border-color:#231a10;box-shadow:0 0 0 4px rgba(216,138,44,.25)}
.t-time{font-family:var(--pixel);font-size:9px;color:var(--soft);position:absolute;left:-2px;top:2px;width:46px;text-align:right}
.timeline h3{font-family:var(--pixel);font-size:13px;letter-spacing:.5px}
.timeline p{font-size:18px;color:var(--ink2);margin-top:6px;line-height:1.2;max-width:48ch}
.t-stamp{
  position:absolute;right:0;top:0;font-family:var(--pixel);font-size:8px;padding:4px 7px;
  border:2px solid var(--ink);color:var(--soft);
}
.t-done .t-stamp{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.t-now .t-stamp{background:var(--amber);color:#231a10;border-color:#231a10}

/* ---------- CTA BAND ---------- */
.cta-band{position:relative;z-index:2;padding:60px 28px;display:flex;justify-content:center}
.cta-inner{width:100%;max-width:680px;text-align:center;padding:40px 28px;box-shadow:var(--shadow)}
.punch{font-family:var(--pixel);font-size:9px;letter-spacing:1.5px;color:var(--amber);margin-bottom:16px}
.cta-inner h2{font-family:var(--pixel);font-size:24px;letter-spacing:1px;text-shadow:3px 3px 0 var(--warm)}
.cta-inner>p{font-size:21px;color:var(--ink2);margin:14px auto 22px;max-width:42ch}
.notify{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.notify input{
  font-family:var(--pixel);font-size:11px;letter-spacing:.5px;padding:13px 16px;
  border:2px solid var(--ink);background:var(--paper);color:var(--ink);min-width:240px;text-transform:uppercase;
}
.notify input:focus{outline:none;border-color:var(--amber)}
.notify input::placeholder{color:var(--line)}
.cta-fine{font-size:15px;color:var(--soft);margin-top:14px;letter-spacing:.5px}

/* ---------- GRAILS ---------- */
.grail-grid{max-width:1140px;margin:34px auto 0;padding:0 28px;display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.grail{position:relative;box-shadow:var(--shadow);cursor:default}
.grail .frame{padding:8px;max-width:none}
.grail img{width:100%;display:block;background:var(--paper3)}
.grail .gname{
  font-family:var(--pixel);font-size:8px;text-align:center;padding:8px 4px;
  background:var(--ink);color:var(--paper);letter-spacing:.5px;
}
.grail::after{content:'1/1';position:absolute;top:12px;left:12px;z-index:20;
  font-family:var(--pixel);font-size:8px;background:var(--amber);color:#231a10;padding:3px 5px}

/* ---------- TRAITS ---------- */
.trait-stats{max-width:1000px;margin:30px auto 0;padding:0 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.tstat{padding:20px 16px;text-align:center;box-shadow:var(--shadow)}
.tstat b{font-family:var(--pixel);font-size:26px;color:var(--amber);display:block}
.tstat span{font-size:17px;color:var(--soft);letter-spacing:.5px}

/* ---------- FAQ ---------- */
.faq-list{max-width:820px;margin:30px auto 0;padding:0 28px;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--paper2);border:2px dashed var(--ink);box-shadow:var(--shadow)}
.faq-q{font-family:var(--pixel);font-size:12px;padding:16px 18px;cursor:pointer;display:flex;justify-content:space-between;gap:12px;letter-spacing:.3px}
.faq-q .pm{color:var(--amber)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s;font-size:19px;color:var(--ink2);line-height:1.3}
.faq-a div{padding:0 18px 16px}
.faq-item.open .faq-a{max-height:200px}

/* ---------- FOOTER ---------- */
.footer{position:relative;z-index:2;text-align:center;padding:56px 28px 70px;margin-top:60px;border-top:2px dashed var(--ink);background:var(--paper2)}
.foot-brand{font-family:var(--pixel);font-size:24px}
.foot-tag{font-family:var(--pixel);font-size:9px;letter-spacing:2px;color:var(--soft);margin:16px 0}
.foot-links{display:flex;gap:20px;justify-content:center;font-size:20px;margin-bottom:18px}
.foot-links a{color:var(--soft)}.foot-links a:hover{color:var(--amber)}
.foot-fine{font-size:15px;color:var(--line);letter-spacing:.5px}

/* ---------- nav status link ---------- */
.nav-status{font-family:var(--pixel);font-size:10px;color:var(--soft);letter-spacing:.5px;padding:6px 4px}
.nav-status:hover{color:var(--amber)}
.apply-cta{width:100%;justify-content:center;font-size:13px;padding:15px}

/* ---------- MODAL ---------- */
.modal{
  position:fixed;inset:0;z-index:80;display:none;align-items:flex-start;justify-content:center;
  background:rgba(20,18,24,.72);padding:28px 16px;overflow-y:auto;
}
.modal.open{display:flex}
.modal-card{
  width:100%;max-width:600px;background:var(--paper);padding:26px 26px 20px;position:relative;
  box-shadow:0 14px 0 rgba(0,0,0,.3);margin:auto;
}
.modal-x{position:absolute;top:10px;right:12px;background:none;border:none;font-size:30px;line-height:1;color:var(--soft);cursor:pointer;font-family:var(--term)}
.modal-x:hover{color:var(--amber)}
.modal-head{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:14px}
.modal-co{font-family:var(--pixel);font-size:10px;color:var(--amber);letter-spacing:1px}
.modal-title{font-family:var(--pixel);font-size:15px;letter-spacing:.5px}

/* stepper */
.stepper{display:flex;gap:5px;justify-content:center;margin-bottom:20px;flex-wrap:wrap}
.stepper .dot{
  font-family:var(--pixel);font-size:8px;letter-spacing:.5px;padding:5px 7px;border:2px solid var(--line);color:var(--soft);
}
.stepper .dot.done{border-color:var(--ink);color:var(--ink)}
.stepper .dot.active{background:var(--amber);color:#231a10;border-color:#231a10}

/* panes */
.panes{min-height:248px}
.pane{display:none}
.pane.show{display:block;animation:fadeUp .25s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.pane h3{font-family:var(--pixel);font-size:14px;letter-spacing:.5px;margin-bottom:8px}
.pane .muted{font-size:18px;color:var(--soft);margin-bottom:16px;line-height:1.25}
.pane .muted.sm-note{font-size:16px;margin:14px 0 8px}
.err{font-size:16px;color:#c0463c;min-height:20px;margin-top:8px}
body.night .err{color:#e87a6e}

/* fields */
.field{display:flex;align-items:center;gap:8px;border:2px solid var(--ink);background:var(--paper2);padding:0 12px}
.field .at{font-family:var(--pixel);font-size:14px;color:var(--soft)}
.field input{flex:1;border:none;background:none;font-family:var(--term);font-size:22px;color:var(--ink);padding:13px 0;letter-spacing:.5px}
.field input:focus{outline:none}
.field input::placeholder{color:var(--line)}
.field input[readonly]{color:var(--soft)}
.btn.sm{font-size:9px;padding:9px 11px}

/* worker preview */
.apply-worker{display:flex;gap:18px;align-items:center}
.apply-worker canvas{width:160px;height:160px;border:2px dashed var(--ink);background:var(--paper3);image-rendering:pixelated;flex:none}
.apply-worker p{font-size:18px;color:var(--ink2);line-height:1.25;margin-bottom:12px}

/* tasks */
.tasks{list-style:none;display:flex;flex-direction:column;gap:9px}
.tasks li{display:flex;align-items:center;gap:11px;border:2px dashed var(--line);padding:11px 12px;background:var(--paper2)}
.tasks li.done{border-style:solid;border-color:var(--good)}
.t-ic{font-family:var(--term);font-size:20px;width:22px;text-align:center;color:var(--amber)}
.t-lbl{flex:1;font-size:18px;letter-spacing:.3px}
.t-chk{font-family:var(--term);font-size:22px;color:var(--line);width:22px;text-align:center}
.tasks li.done .t-chk{color:var(--good)}
.tasks li.done .t-do{opacity:.5}

/* card preview */
.card-preview{width:100%;border:2px solid var(--ink);background:var(--paper3);display:block;image-rendering:pixelated}
.card-acts{display:flex;gap:10px;margin-top:12px}
.card-acts .btn{flex:1;justify-content:center}

/* submitted / status */
.submitted{text-align:center}
.stamp-big{
  display:inline-block;font-family:var(--pixel);font-size:13px;padding:9px 16px;border:3px solid var(--amber);
  color:var(--amber);transform:rotate(-4deg);letter-spacing:1px;margin-bottom:14px;
}
.stamp-big.hired{border-color:var(--good);color:var(--good)}
.stamp-big.wait{border-color:var(--soft);color:var(--soft)}
.submitted h3{font-family:var(--pixel);font-size:16px;margin-bottom:8px}
.app-meta{display:flex;justify-content:center;gap:22px;margin:18px 0;flex-wrap:wrap}
.app-meta div{display:flex;flex-direction:column}
.app-meta span{font-size:14px;color:var(--soft);letter-spacing:.5px}
.app-meta b{font-family:var(--pixel);font-size:12px}
.ref-box{border:2px dashed var(--ink);background:var(--paper2);padding:16px;margin-top:8px}
.ref-label{font-family:var(--pixel);font-size:9px;color:var(--amber);letter-spacing:1px;display:block;margin-bottom:10px}
.ref-box .field{margin-bottom:10px}
.ref-count{font-size:17px;color:var(--amber);font-family:var(--term);margin-bottom:12px;letter-spacing:.3px}
.ref-box .btn-amber{width:100%;justify-content:center}

/* step nav */
.step-nav{display:flex;gap:10px;margin-top:20px;border-top:2px dashed var(--line);padding-top:16px}
.step-nav .btn{flex:1;justify-content:center}
.step-nav .btn[disabled]{opacity:.4;cursor:not-allowed;transform:none;box-shadow:var(--shadow)}

@media(max-width:520px){
  .apply-worker{flex-direction:column;text-align:center}
  .modal-card{padding:22px 16px 16px}
}

/* ---------- toast ---------- */
.toast{
  position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(120%);
  background:var(--ink);color:var(--paper);font-family:var(--pixel);font-size:11px;
  padding:14px 20px;z-index:99;border:2px solid var(--amber);transition:transform .3s;letter-spacing:.5px;
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- preloader ---------- */
.preloader{
  position:fixed;inset:0;z-index:200;background:var(--paper);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s ease, visibility .5s;
}
.preloader.gone{opacity:0;visibility:hidden}
.pre-inner{text-align:center}
.pre-mark{font-family:var(--pixel);font-size:26px;letter-spacing:1px;margin-bottom:18px}
.pre-moon{color:var(--amber)}
.pre-bar{width:220px;height:12px;border:2px solid var(--ink);margin:0 auto;background:var(--paper3)}
.pre-bar i{display:block;height:100%;width:0;background:var(--amber);transition:width .25s}
.pre-msg{font-family:var(--pixel);font-size:9px;color:var(--soft);letter-spacing:1.5px;margin-top:14px}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease, transform .55s cubic-bezier(.2,.8,.3,1)}
.reveal.in-view{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ---------- reassemble btn ---------- */
.hero-caption{display:inline-flex;align-items:center;gap:10px}
.reassemble{
  width:26px;height:26px;border:2px solid var(--ink);background:var(--paper);color:var(--amber);
  font-size:15px;line-height:1;cursor:pointer;font-family:var(--term);
}
.reassemble:hover{background:var(--ink);transform:rotate(180deg);transition:transform .3s}

/* ---------- CREW WALL ---------- */
.crew{position:relative;z-index:2;padding-bottom:40px}
.crew-wall{max-width:1100px;margin:30px auto 0;padding:0 28px;display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.crew-card{position:relative;border:2px solid var(--ink);background:var(--paper3);cursor:pointer;overflow:hidden;box-shadow:var(--shadow);transition:transform .1s}
.crew-card img{width:100%;display:block;image-rendering:pixelated}
.crew-card:hover{transform:translateY(-3px)}
.crew-card .cc-load{
  position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;padding-bottom:8px;
  background:linear-gradient(transparent 55%, rgba(32,36,50,.82));opacity:0;transition:opacity .15s;
  font-family:var(--pixel);font-size:8px;color:#fff;letter-spacing:.5px;
}
.crew-card:hover .cc-load{opacity:1}
.crew-cta{text-align:center;margin-top:24px}

/* ---------- LEADERBOARD ---------- */
.leaderboard{position:relative;z-index:2}
.board{max-width:680px;margin:30px auto 0;padding:0 28px;display:flex;flex-direction:column;gap:8px}
.board-row{display:flex;align-items:center;gap:14px;border:2px dashed var(--ink);background:var(--paper2);padding:12px 16px;box-shadow:var(--shadow)}
.board-row .rank{font-family:var(--pixel);font-size:13px;color:var(--soft);width:34px}
.board-row.top1{border-style:solid;border-color:var(--amber)}
.board-row.top1 .rank,.board-row.top2 .rank,.board-row.top3 .rank{color:var(--amber)}
.board-row .who{flex:1;font-size:20px}
.board-row .cnt{font-family:var(--pixel);font-size:11px;color:var(--ink)}
.board-empty{text-align:center;border:2px dashed var(--line);background:var(--paper2);padding:30px 20px;color:var(--soft);font-size:19px}
.board-empty b{color:var(--amber);font-family:var(--pixel);font-size:12px;display:block;margin-bottom:8px;letter-spacing:.5px}

/* ---------- CLEARANCE section ---------- */
.clearance-sec{position:relative;z-index:2}
.clear-grid{max-width:1000px;margin:30px auto 0;padding:0 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.clear-card{padding:22px 16px;text-align:center;box-shadow:var(--shadow);position:relative}
.clear-card.hi{border-style:solid;border-color:var(--amber)}
.cc-lvl{font-family:var(--pixel);font-size:26px;color:var(--amber)}
.cc-name{font-family:var(--pixel);font-size:12px;margin:8px 0 12px;letter-spacing:.5px}
.cc-unlock{font-size:19px;color:var(--ink);border-top:2px dashed var(--line);padding-top:12px}
.cc-how{font-size:16px;color:var(--soft);margin-top:8px;line-height:1.2}
.clear-note{max-width:760px;margin:26px auto 0;padding:14px 28px;text-align:center;font-size:19px;color:var(--ink2);line-height:1.3}
.clear-note b{color:var(--amber)}

/* ---------- a11y / motion ---------- */
:focus-visible{outline:3px solid var(--amber);outline-offset:2px}
body.modal-open{overflow:hidden}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;text-align:center}
  .hero h1{font-size:42px}
  .lede{margin-left:auto;margin-right:auto}
  .hero-cta,.hero-stats{justify-content:center}
  .hero-art{order:-1}
  .builder-grid{grid-template-columns:1fr}
  .builder-preview{position:static}
  .builder-preview .frame{max-width:420px;margin:0 auto}
  .steps{grid-template-columns:1fr}
  .grail-grid{grid-template-columns:repeat(3,1fr)}
  .crew-wall{grid-template-columns:repeat(4,1fr)}
  .clear-grid{grid-template-columns:repeat(2,1fr)}
  .trait-stats{grid-template-columns:repeat(2,1fr)}
  .nav{flex-wrap:wrap;gap:10px;padding:10px 16px}
  .nav-links{order:3;width:100%;gap:14px;overflow-x:auto;font-size:18px;padding-bottom:2px;-webkit-overflow-scrolling:touch}
  .nav-links a{white-space:nowrap}
  .brand{font-size:17px}
}
@media(max-width:520px){
  .grail-grid{grid-template-columns:repeat(2,1fr)}
  .crew-wall{grid-template-columns:repeat(3,1fr)}
  .hero h1{font-size:32px}
}
