/* ===================== Maven — minimal white & gold ===================== */
:root{
  --paper:#FCFBF8;
  --ink:#1C1A14;
  --ink-soft:#7A745F;
  --ink-faint:#A8A289;
  --line:#ECE7D8;
  --line-2:#F3EFE4;
  --gold:#C9A227;
  --gold-lt:#E6C66B;
  --gold-wash:#FAF4E2;
  --white:#FFFFFF;
  --r:16px;
  --ease:cubic-bezier(.22,.61,.18,1);
}
*{box-sizing:border-box;margin:0;padding:0}
*{scrollbar-width:none}
*::-webkit-scrollbar{display:none}

html,body{height:100%}
body{
  font-family:"Space Grotesk",system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  min-height:100dvh;
  display:flex;flex-direction:column;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
}

/* ===================== topbar ===================== */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px clamp(16px,2.4vw,30px) 8px;
  width:100%;max-width:1280px;margin:0 auto;
}
.brand{display:flex;align-items:center;gap:11px}
.mark{display:grid;place-items:center}
.mark svg{overflow:visible}
/* micro: gentle twinkle + a quicker mini-spark */
.spark-main{transform-origin:20px 20px;animation:twinkle 5.5s var(--ease) infinite}
.spark-mini{transform-origin:34px 10px;animation:twinkleMini 4s var(--ease) infinite}
@keyframes twinkle{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.94) rotate(0.5deg);opacity:.9}}
@keyframes twinkleMini{0%,100%{transform:scale(.7);opacity:.5}45%{transform:scale(1.05);opacity:1}}
.brand-text h1{font-family:"Fraunces",serif;font-weight:600;font-size:25px;letter-spacing:-.5px;line-height:1}

/* tabs — flat, single hairline */
.tabs{position:relative;display:flex;gap:2px}
.tab{position:relative;z-index:2;border:0;background:transparent;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:500;color:var(--ink-soft);
  padding:8px 16px;border-radius:999px;transition:color .3s var(--ease)}
.tab.is-active{color:var(--ink)}
.tab:not(.is-active):hover{color:var(--ink)}
.tab-ink{position:absolute;z-index:1;bottom:-1px;left:0;height:2px;border-radius:2px;
  background:var(--gold);transition:transform .4s var(--ease),width .4s var(--ease)}

/* ===================== stage / views ===================== */
.stage{flex:1;min-height:0;width:100%;max-width:1280px;margin:0 auto;
  display:flex;flex-direction:column;padding:18px clamp(16px,2.4vw,30px) 6px}
.view{display:none}
.view.is-active{display:flex;flex-direction:column;flex:1;min-height:0;
  animation:viewIn .45s var(--ease) both}
.view:not(.chat).is-active{overflow-y:auto}
.view.chat.is-active{overflow:hidden}
@keyframes viewIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---- chat thread + composer ---- */
.thread{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;
  gap:18px;padding:10px 2px 10px;scroll-behavior:smooth}
.thread .empty{margin:auto}
.composer{flex:0 0 auto;padding:12px 0 4px;
  background:linear-gradient(to top,var(--paper) 72%,transparent)}

/* priority dial — custom segmented control (no native element) */
.priority{display:flex;align-items:center;gap:11px;margin-bottom:10px;padding:0 2px}
.prio-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:600}
.prio-seg{display:inline-flex;background:var(--line-2);border:1px solid var(--line);
  border-radius:999px;padding:3px;gap:2px}
.prio-opt{font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink-soft);
  background:transparent;border:0;cursor:pointer;padding:6px 14px;border-radius:999px;
  transition:color .2s var(--ease),background .25s var(--ease)}
.prio-opt:hover:not(.is-on){color:var(--ink)}
.prio-opt.is-on{background:var(--white);color:#5a4a14;box-shadow:0 1px 3px rgba(120,96,20,.18)}

/* priority chip on the verdict */
.prio-note{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
  font-size:12px;font-weight:600;color:#7a6412;background:var(--gold-wash);
  border:1px solid var(--line);padding:5px 12px 5px 10px;border-radius:999px;
  animation:rise .4s var(--ease) both}
.prio-note svg{color:var(--gold);flex:0 0 auto}
.msg{animation:rise .42s var(--ease) both;max-width:100%}
.msg-user{align-self:flex-end;max-width:82%}
.msg-user .bubble{background:var(--gold-wash);border:1px solid var(--line);
  padding:11px 16px;border-radius:16px 16px 5px 16px;font-size:15px;
  color:var(--ink);line-height:1.5;white-space:pre-wrap;word-break:break-word}
.msg-user .bubble .u-atts{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.msg-user .bubble .u-att{font-size:11.5px;color:#5a4a14;background:var(--white);
  border:1px solid var(--line);padding:2px 8px;border-radius:999px}
.msg-maven{align-self:stretch;display:flex;flex-direction:column;gap:14px}
.msg-maven .specialist{margin-top:0}
.msg-maven .ranked{margin-top:0}

/* ---- thinking trace ---- */
.think{gap:8px}
.think-head{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink-soft)}
.think.done .think-head{cursor:pointer}
.think-title{font-weight:600}
.think-spin{flex:0 0 auto;width:14px;height:14px;border-radius:50%;
  border:2px solid var(--gold-wash);border-top-color:var(--gold);animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.think.done .think-spin{display:none}
.think-check{display:none;width:15px;height:15px;border-radius:50%;background:var(--gold);
  color:#fff;place-items:center;flex:0 0 auto}
.think.done .think-check{display:grid}
.think-chev{display:none;margin-left:auto;color:var(--ink-soft);transition:transform .3s var(--ease)}
.think.done .think-chev{display:block}
.think.open .think-chev{transform:rotate(180deg)}

.think-steps{position:relative;display:flex;flex-direction:column;overflow:hidden;
  transition:max-height .4s var(--ease);margin-left:2px}
/* line center sits at x=7.5; nodes are left:0 width:15 → center 7.5 → exactly aligned */
.think-steps::before{content:"";position:absolute;left:6.75px;top:9px;bottom:9px;width:1.5px;background:var(--line-2)}
.step{position:relative;display:flex;gap:11px;align-items:flex-start;padding:5px 0 5px 27px;
  animation:stepIn .3s var(--ease) both}
@keyframes stepIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.step-ic{position:absolute;left:0;top:5px;flex:0 0 auto;width:15px;height:15px;border-radius:50%;
  background:var(--paper);border:1.5px solid var(--line);display:grid;place-items:center;
  color:#fff;transition:all .25s var(--ease)}
.step .ic-check{opacity:0;transition:opacity .2s}
.step.running .step-ic{border-color:var(--gold-lt)}
.step.running .step-ic::after{content:"";width:6px;height:6px;border-radius:50%;
  background:var(--gold);animation:pulse 1s infinite}
.step.done .step-ic{background:var(--gold);border-color:var(--gold)}
.step.done .ic-check{opacity:1}
.step-body{display:flex;flex-direction:column;gap:1px;min-width:0}
.step-mod{font-size:13px;font-weight:600;color:var(--ink)}
.step-do{font-size:12.5px;color:var(--ink-soft)}
.step.running .step-do{color:var(--gold)}

.eyebrow{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;margin:8px 2px 16px}

/* ===================== ask / input ===================== */
.reveal{animation:rise .5s var(--ease) both}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.field{position:relative;display:flex;gap:10px;align-items:flex-end;
  background:var(--white);border:1px solid var(--line);border-radius:var(--r);
  padding:12px 12px 12px 12px;
  transition:border-color .35s var(--ease),box-shadow .35s var(--ease)}
.field.focus{border-color:var(--gold-lt);box-shadow:0 0 0 3px var(--gold-wash)}
.field.drop{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-wash);border-style:dashed}
.field-main{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}
#taskInput{border:0;outline:0;resize:none;background:transparent;
  font-family:inherit;font-size:16px;line-height:1.55;color:var(--ink);
  min-height:104px;max-height:260px;overflow:auto}
#taskInput::placeholder{color:#BDB7A2}

/* ---- attach (+) ---- */
.field-left{position:relative;flex:0 0 auto}
.attach-btn{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;
  border:1px solid var(--line);background:var(--white);color:var(--ink-soft);cursor:pointer;
  transition:all .22s var(--ease)}
.attach-btn:hover{border-color:var(--gold-lt);color:var(--gold);background:var(--gold-wash)}
.attach-btn svg{transition:transform .3s var(--ease)}
.attach-btn.open{border-color:var(--gold-lt);color:var(--gold);background:var(--gold-wash)}
.attach-btn.open svg{transform:rotate(135deg)}

.attach-menu{position:absolute;left:0;bottom:44px;z-index:10;width:190px;
  background:var(--white);border:1px solid var(--line);border-radius:14px;
  padding:6px;box-shadow:0 14px 40px -18px rgba(120,96,20,.5);
  transform-origin:bottom left;animation:menuPop .22s var(--ease) both}
@keyframes menuPop{from{opacity:0;transform:scale(.9) translateY(6px)}to{opacity:1;transform:none}}
.am-item{display:flex;align-items:center;gap:10px;width:100%;border:0;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:500;color:var(--ink);
  background:transparent;padding:10px 11px;border-radius:9px;transition:background .18s}
.am-item:hover{background:var(--gold-wash);color:#5a4a14}
.am-item svg{color:var(--gold)}
.am-section{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;padding:8px 11px 4px}
.am-section:not(:first-child){border-top:1px solid var(--line-2);margin-top:4px;padding-top:9px}
.am-toggle{display:flex;align-items:center;gap:10px;width:100%;border:0;cursor:pointer;
  font-family:inherit;font-size:13.5px;font-weight:500;color:var(--ink);
  background:transparent;padding:8px 11px;border-radius:9px;transition:background .18s}
.am-toggle:hover{background:var(--gold-wash)}
.amt-box{flex:0 0 auto;width:15px;height:15px;border-radius:5px;border:1.5px solid var(--line);
  display:grid;place-items:center;transition:all .18s var(--ease)}
.am-toggle.on .amt-box{background:var(--gold);border-color:var(--gold)}
.amt-box::after{content:"";width:7px;height:4px;border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg) scale(0);transform-origin:center;margin-top:-1px;transition:transform .2s var(--ease)}
.am-toggle.on .amt-box::after{transform:rotate(-45deg) scale(1)}
.am-hint{display:block;font-size:11.5px;color:var(--ink-soft);padding:8px 11px 5px;
  border-top:1px solid var(--line-2);margin-top:4px}

/* active-constraint chip in the tray */
.att.att-c{background:var(--gold-wash);padding:7px 8px 7px 11px}
.att.att-c .att-name{color:#5a4a14;font-weight:600;max-width:none}

/* ---- attachments tray ---- */
.attachments{display:flex;flex-wrap:wrap;gap:8px}
.attachments[hidden]{display:none}
.att{position:relative;display:flex;align-items:center;gap:8px;
  background:var(--line-2);border-radius:10px;padding:6px 8px;max-width:200px;
  animation:attIn .28s var(--ease) both}
@keyframes attIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:none}}
.att-thumb{width:30px;height:30px;border-radius:7px;object-fit:cover;flex:0 0 auto;
  background:var(--white);display:grid;place-items:center;color:var(--gold)}
.att-name{font-size:12.5px;color:var(--ink);white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;max-width:120px}
.att-x{flex:0 0 auto;display:grid;place-items:center;width:18px;height:18px;border-radius:50%;
  border:0;cursor:pointer;background:#E4DCC6;color:#6a5e3a;font-size:12px;line-height:1;
  transition:all .18s}
.att-x:hover{background:var(--gold);color:#fff}

.judge-btn{position:relative;overflow:hidden;border:0;cursor:pointer;
  font-family:inherit;font-weight:600;font-size:14.5px;color:#3a2f06;
  padding:12px 22px;border-radius:12px;background:var(--gold-lt);
  transition:transform .16s var(--ease),background .3s var(--ease)}
.judge-btn:hover{background:var(--gold);color:#2a2204;transform:translateY(-1px)}
.judge-btn:active{transform:translateY(0) scale(.97)}
.jb-spark{position:absolute;inset:0;background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.6) 50%,transparent 65%);transform:translateX(-120%)}
.judge-btn.busy .jb-spark{animation:spark .7s var(--ease)}
.judge-btn.busy .jb-label{opacity:.6}
@keyframes spark{to{transform:translateX(120%)}}

/* ===================== specialist banner ===================== */
.specialist{display:flex;align-items:center;gap:11px;margin-top:18px;
  background:var(--gold-wash);border:1px solid var(--line);border-radius:var(--r);
  padding:13px 16px;animation:rise .45s var(--ease) both}
.sp-dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 0 4px var(--gold-wash);animation:pulse 1.8s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 7px transparent}}
.specialist p{font-size:14px;color:var(--ink-soft)}
.specialist strong{color:var(--ink);font-weight:600}

/* multi-turn "refining last task" chip */
.refine-note{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
  font-size:12px;font-weight:600;color:#7a6412;background:var(--gold-wash);
  border:1px solid var(--line);padding:5px 12px 5px 10px;border-radius:999px;
  animation:rise .4s var(--ease) both}
.refine-note svg{color:var(--gold);flex:0 0 auto}

/* learning-loop chip — past correction reshaped this verdict */
.learn-note{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
  font-size:12px;font-weight:600;color:#4f7a4a;background:#eef6ea;
  border:1px solid #dcebd5;padding:5px 12px 5px 10px;border-radius:999px;
  animation:rise .4s var(--ease) both}
.learn-note svg{flex:0 0 auto}

/* conversational answer (Maven "talks") */
.maven-say{font-size:16.5px;line-height:1.6;color:var(--ink);max-width:64ch;
  animation:rise .45s var(--ease) both}
.maven-say strong{font-weight:600;color:#5a4a14}
.maven-say:empty{display:none}

/* ===================== verdict / winner ===================== */
.verdict{margin-top:22px}
.winner{position:relative;overflow:hidden;background:var(--white);
  border:1px solid var(--line);border-radius:20px;padding:24px 26px 22px;
  animation:winIn .5s var(--ease) both}
@keyframes winIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.shimmer{position:absolute;top:0;left:0;width:50%;height:100%;
  background:linear-gradient(105deg,transparent,rgba(250,244,226,.7),transparent);
  transform:translateX(-180%) skewX(-12deg)}
.winner.lit .shimmer{animation:sweep 1s var(--ease) .1s}
@keyframes sweep{to{transform:translateX(320%) skewX(-12deg)}}

.win-head{display:flex;justify-content:space-between;align-items:center}
.rank-badge{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft)}
.confidence{font-size:13px;font-weight:600;color:var(--gold)}
.win-name{font-family:"Fraunces",serif;font-weight:600;font-size:38px;letter-spacing:-.8px;
  margin:10px 0 6px;line-height:1}
.win-reason{font-size:15px;color:var(--ink-soft);line-height:1.55;max-width:58ch}

/* cost-aware "best value" line */
.value-pick{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:15px;
  font-size:13px;color:var(--ink-soft);animation:rise .4s var(--ease) both}
.value-pick[hidden]{display:none}
.value-pick strong{color:var(--ink);font-weight:600}
.vp-tag{font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  color:#7a6412;background:var(--gold-wash);border:1px solid var(--line);
  padding:3px 9px;border-radius:999px}

/* ---- cost & speed estimate badge ---- */
.estimate{display:flex;align-items:center;gap:9px;margin:13px 0 2px;flex-wrap:wrap;
  animation:rise .45s var(--ease) both;animation-delay:.3s}
.est-item{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;
  color:var(--ink);background:var(--line-2);border:1px solid var(--line);
  padding:5px 11px 5px 9px;border-radius:999px;font-variant-numeric:tabular-nums}
.est-item svg{flex:none;opacity:.85}
.est-time{color:var(--ink-soft)}
.est-cost[data-tier="free"]{color:#4f7a4a;background:#eef6ea;border-color:#dcebd5}
.est-cost[data-tier="low"] {color:#5b7c3e;background:#f1f4e8;border-color:#e6ecd6}
.est-cost[data-tier="mid"] {color:#8a6d12;background:var(--gold-wash);border-color:var(--line)}
.est-cost[data-tier="high"]{color:#9c4a32;background:#f8ece6;border-color:#eed9cf}
.est-note{font-size:11px;color:var(--ink-faint);letter-spacing:.02em}

.pills{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 4px}
.pill{display:flex;flex-direction:column;gap:2px;background:var(--line-2);
  border-radius:11px;padding:9px 14px;min-width:110px;
  animation:pillIn .45s var(--ease) both}
.pill:nth-child(1){animation-delay:.04s}.pill:nth-child(2){animation-delay:.11s}
.pill:nth-child(3){animation-delay:.18s}.pill:nth-child(4){animation-delay:.25s}
@keyframes pillIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.pk{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.pv{font-size:14.5px;font-weight:600;color:var(--ink)}

.win-actions{display:flex;align-items:center;gap:16px;margin-top:16px;flex-wrap:wrap}
.copy-btn{display:inline-flex;align-items:center;gap:7px;font-family:inherit;
  font-size:13px;font-weight:600;color:#7a6412;background:var(--gold-wash);
  border:1px solid var(--line);cursor:pointer;padding:7px 13px;border-radius:999px;
  transition:all .2s var(--ease)}
.copy-btn:hover{border-color:var(--gold-lt);background:#F6ECCF;color:#5a4a14}
.copy-btn.copied{background:var(--gold);border-color:var(--gold);color:#fff}
.copy-btn svg{flex:0 0 auto}
.why-toggle{display:inline-flex;align-items:center;gap:6px;
  font-family:inherit;font-size:13px;font-weight:500;color:var(--ink-soft);
  background:transparent;border:0;cursor:pointer;transition:color .2s}
.why-toggle:hover{color:var(--gold)}
.why-toggle svg{transition:transform .3s var(--ease)}
.why-toggle.open svg{transform:rotate(180deg)}
.why{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.why-list{list-style:none;display:grid;gap:7px;padding:14px 0 2px}
.why-list li{display:flex;gap:12px;align-items:baseline;font-size:13px}
.wm{flex:0 0 80px;font-weight:600;color:var(--gold)}
.wd{color:var(--ink-soft)}

/* ===================== ranked list ===================== */
.ranked{margin-top:26px}
.ranked-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);margin:0 2px 10px;font-weight:600}
.rank-item{border-bottom:1px solid var(--line-2)}
.rank-item:last-child{border-bottom:0}
.row{display:grid;grid-template-columns:20px 140px 1fr 34px 14px;align-items:center;gap:14px;
  padding:13px 4px;cursor:pointer;
  opacity:0;transform:translateY(8px);transition:transform .3s var(--ease),background .25s}
.row.in{opacity:1;transform:none}
.row:hover{background:var(--line-2);border-radius:10px}
.row-chev{color:var(--ink-faint);transition:transform .3s var(--ease);justify-self:center}
.rank-item.open .row-chev{transform:rotate(180deg);color:var(--gold)}
.row-why{max-height:0;overflow:hidden;transition:max-height .35s var(--ease);
  font-size:12.5px;color:var(--ink-soft);line-height:1.5;padding-left:34px}
.row-why .rw-q{font-weight:600;color:var(--gold)}
.rank-item.open .row-why{padding-bottom:13px}
.row-rank{font-family:"Fraunces",serif;font-size:15px;color:#C7BC97;font-weight:600}
.row-name{font-weight:600;font-size:15px}
.row-name small{display:block;font-weight:400;font-size:11.5px;color:var(--ink-soft);margin-top:1px}
.bar{height:5px;border-radius:999px;background:var(--line-2);overflow:hidden}
.bar i{display:block;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--gold-lt),var(--gold));
  transition:width 1s var(--ease)}
.row.in .bar i{width:var(--w)}
.row-score{font-weight:600;font-size:14.5px;color:#8a7320;text-align:right}

/* ===================== "what to do" note ===================== */
.howto{display:flex;flex-direction:column;gap:6px;
  background:var(--line-2);border-left:3px solid var(--gold-lt);
  border-radius:0 12px 12px 0;padding:13px 16px;animation:rise .45s var(--ease) both}
.howto-label{display:inline-flex;align-items:center;gap:6px;
  font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:#8a6d12}
.howto-label svg{flex:0 0 auto;color:var(--gold)}
.howto-text{font-size:14px;line-height:1.55;color:var(--ink-soft)}
.howto-text strong{color:var(--ink);font-weight:600}

/* ===================== recommended pipeline ===================== */
.pipeline{background:var(--gold-wash);border:1px solid var(--line);border-radius:18px;
  padding:17px 20px 18px;animation:rise .45s var(--ease) both}
.pipeline[hidden]{display:none}
.pipeline-label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:#7a6412;font-weight:600;margin:0 0 14px}
.pipe-steps{position:relative;display:flex;flex-direction:column;gap:4px}
.pipe-steps::before{content:"";position:absolute;left:12.75px;top:16px;bottom:16px;width:1.5px;
  background:var(--gold-lt);opacity:.55}
.pipe-step{position:relative;display:flex;align-items:center;gap:13px;padding:8px 0 8px 38px;
  animation:rise .42s var(--ease) both}
.pipe-num{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:1;
  width:26px;height:26px;border-radius:50%;background:var(--gold);color:#fff;
  display:grid;place-items:center;font-family:"Fraunces",serif;font-size:13px;font-weight:600;
  box-shadow:0 0 0 4px var(--gold-wash)}
.pipe-body{display:flex;flex-direction:column;gap:1px;min-width:0}
.pipe-stage{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600}
.pipe-tool{font-family:"Fraunces",serif;font-size:18px;font-weight:600;color:var(--ink);
  letter-spacing:-.3px;line-height:1.15}
.pipe-meta{font-size:12px;color:#8a7320;margin-top:1px}
.pipe-copy{margin-left:auto;flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;
  font-family:inherit;font-size:12px;font-weight:600;color:#8a7320;background:var(--white);
  border:1px solid var(--line);cursor:pointer;padding:6px 11px;border-radius:999px;
  transition:all .2s var(--ease)}
.pipe-copy:hover{border-color:var(--gold-lt);color:#5a4a14}
.pipe-copy.copied{background:var(--gold);border-color:var(--gold);color:#fff}
.pipe-copy svg{flex:0 0 auto}

/* ===================== empty ===================== */
.empty{text-align:center;padding:50px 20px 30px;max-width:42ch;margin:10px auto 0;
  animation:rise .5s var(--ease) both}
.empty-star{margin:0 auto 16px;width:34px;height:34px}
.empty-star svg{animation:twinkle 5s var(--ease) infinite}
.empty p{color:var(--ink-soft);font-size:15px;line-height:1.6}
.empty strong{color:var(--gold);font-weight:600}
.starters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:22px}
.starter{font-family:inherit;font-size:12.5px;font-weight:500;color:#7a6412;
  background:var(--white);border:1px solid var(--line);cursor:pointer;
  padding:8px 14px;border-radius:999px;transition:all .2s var(--ease)}
.starter:hover{border-color:var(--gold-lt);background:var(--gold-wash);color:#5a4a14;
  transform:translateY(-1px)}

/* ===================== history ===================== */
.history{display:grid;gap:2px}
.h-empty{color:var(--ink-soft);font-size:14.5px;padding:30px 6px;text-align:center}
.h-row{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center;
  padding:16px 6px;border-bottom:1px solid var(--line-2);
  animation:hIn .45s var(--ease) both;transition:background .25s,padding-left .25s}
.h-row:last-child{border-bottom:0}
.h-row:hover{background:var(--line-2);border-radius:12px;padding-left:14px}
.h-row:nth-child(2){animation-delay:.05s}.h-row:nth-child(3){animation-delay:.1s}
.h-row:nth-child(4){animation-delay:.15s}.h-row:nth-child(5){animation-delay:.2s}
@keyframes hIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
.h-task{font-size:14.5px;font-weight:500;color:var(--ink);line-height:1.4}
.h-meta{display:flex;gap:8px;align-items:center;margin-top:5px;font-size:12px;color:var(--ink-soft)}
.h-pill{font-weight:600;color:#7a6412;background:var(--gold-wash);
  padding:2px 9px;border-radius:999px;font-size:11px}
.h-right{text-align:right}
.h-win{font-family:"Fraunces",serif;font-size:16px;font-weight:600}
.h-conf{font-size:11.5px;color:var(--gold);font-weight:600;margin-top:1px}

/* ===================== roster ===================== */
.roster{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px}
.r-card{background:var(--white);border:1px solid var(--line);border-radius:14px;
  padding:16px;transition:transform .25s var(--ease),border-color .25s;
  animation:rise .45s var(--ease) both}
.r-card:hover{transform:translateY(-2px);border-color:var(--gold-lt)}
.r-top{display:flex;justify-content:space-between;align-items:center}
.r-name{font-family:"Fraunces",serif;font-size:18px;font-weight:600}
.r-tag{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);background:var(--line-2);padding:3px 8px;border-radius:999px}
.r-tag.spec{color:#7a4f12;background:var(--gold-wash)}
.r-best{font-size:12.5px;color:var(--ink-soft);margin:9px 0 11px;line-height:1.5}
.r-dims{display:flex;flex-wrap:wrap;gap:5px}
.r-dim{font-size:10.5px;color:#8a7320;background:var(--line-2);padding:3px 8px;border-radius:999px}

/* ===================== feedback (👍/👎) ===================== */
.feedback{display:flex;align-items:center;gap:8px;margin-top:18px;
  padding-top:14px;border-top:1px solid var(--line-2)}
.feedback[hidden]{display:none}
.fb-q{font-size:12.5px;color:var(--ink-soft);margin-right:2px}
.fb-btn{display:grid;place-items:center;width:30px;height:30px;border-radius:9px;
  border:1px solid var(--line);background:var(--white);color:var(--ink-soft);cursor:pointer;
  transition:all .18s var(--ease)}
.fb-btn:hover{border-color:var(--gold-lt);color:var(--gold);background:var(--gold-wash)}
.fb-down svg{transform:rotate(180deg)}
.fb-alts{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:16px;
  padding-top:14px;border-top:1px solid var(--line-2);animation:rise .35s var(--ease) both}
.fb-alts[hidden]{display:none}
.fba-q{font-size:12.5px;color:var(--ink-soft);margin-right:2px}
.fba{font-family:inherit;font-size:12.5px;font-weight:600;color:#7a6412;
  background:var(--gold-wash);border:1px solid var(--line);cursor:pointer;
  padding:6px 12px;border-radius:999px;transition:all .18s var(--ease)}
.fba:hover{border-color:var(--gold-lt);background:#F6ECCF;color:#5a4a14}
.fba-other{background:var(--white);color:var(--ink-soft)}
.fb-done{margin-top:16px;padding-top:14px;border-top:1px solid var(--line-2);
  font-size:13px;color:#7a6412;font-weight:600;animation:rise .35s var(--ease) both}
.fb-done[hidden]{display:none}

/* corrections list (history tab) */
.corrections{background:var(--gold-wash);border:1px solid var(--line);border-radius:14px;
  padding:14px 16px;margin-bottom:16px;animation:rise .4s var(--ease) both}
.corr-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#7a6412;
  font-weight:600;margin:0 0 8px}
.corr-row{display:flex;justify-content:space-between;gap:14px;align-items:center;
  padding:8px 0;border-bottom:1px solid rgba(201,162,39,.18)}
.corr-row:last-child{border-bottom:0}
.corr-task{font-size:13px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;max-width:58%}
.corr-swap{font-size:12.5px;color:var(--ink-soft);flex:0 0 auto}
.corr-swap em{font-style:normal;color:var(--gold);padding:0 3px}
.corr-swap strong{color:#5a4a14;font-weight:600}

/* ===================== footer ===================== */
.foot{text-align:center;padding:4px 0 8px;font-size:11px;color:#BDB7A2;letter-spacing:.03em}
.foot span{color:var(--gold);font-weight:600}

@media (max-width:560px){
  .topbar{flex-direction:column;gap:14px;align-items:flex-start}
  .field{flex-direction:column;align-items:stretch}
  .judge-btn{width:100%}
  .row{grid-template-columns:18px 1fr 34px 14px}
  .row .bar{display:none}
  .priority{flex-wrap:wrap;gap:8px}
  .prio-seg{width:100%;justify-content:space-between}
  .prio-opt{flex:1;padding:7px 8px;text-align:center}
}
