/* ══ Pave Design System ══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#F6F4EF;--surface:#FFF;--ink:#17150F;--ink2:#78756C;--ink3:#B8B5AE;
  --border:rgba(23,21,15,0.08);--border2:rgba(23,21,15,0.045);
  --green:#2A6049;--gbg:#E8F3EC;--gtext:#2A6049;
  --blue:#1A3A8F;--bbg:#EBF0FD;--btext:#1A3A8F;
  --amber:#8B5E0A;--abg:#FEF3C7;--atext:#8B5E0A;
  --red:#991B1B;--rbg:#FEE8E8;--rtext:#991B1B;
  --panel:380px;--r:12px;--rs:8px;
}
body{font-family:'Geist',sans-serif;background:var(--bg);color:var(--ink);height:100vh;display:flex;flex-direction:column;overflow:hidden;}
a{color:inherit;text-decoration:none;}

/* ── Nav ── */
nav{display:flex;align-items:center;justify-content:space-between;padding:0 1.75rem;height:50px;background:var(--surface);border-bottom:1px solid var(--border2);flex-shrink:0;z-index:20;}
.brand{font-family:'Instrument Serif',serif;font-size:1.3rem;}
.nav-c{display:flex;gap:0.15rem;}
.ntab{padding:0.3rem 0.7rem;border-radius:var(--rs);font-size:0.73rem;color:var(--ink3);cursor:pointer;background:transparent;border:none;font-family:'Geist',sans-serif;transition:all 0.12s;}
.ntab:hover{color:var(--ink2);background:var(--bg);}
.ntab.on{color:var(--ink);background:var(--bg);}
.nav-r{display:flex;align-items:center;gap:0.75rem;}
.panel-btn{display:flex;align-items:center;gap:0.45rem;padding:0.3rem 0.75rem;border-radius:99px;border:1px solid var(--border);background:transparent;font-family:'Geist',sans-serif;font-size:0.72rem;color:var(--ink2);cursor:pointer;transition:all 0.15s;position:relative;}
.panel-btn:hover{border-color:rgba(23,21,15,0.18);color:var(--ink);}
.panel-btn.on{border-color:var(--green);color:var(--gtext);background:var(--gbg);}
.pdot{width:6px;height:6px;border-radius:50%;background:var(--ink3);transition:background 0.2s;}
.panel-btn.on .pdot{background:var(--green);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.4;}}
.ava-wrap{position:relative;}
.ava{width:26px;height:26px;border-radius:50%;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:0.6rem;color:var(--ink2);cursor:pointer;transition:border-color 0.12s;}
.ava:hover{border-color:rgba(23,21,15,0.2);}
.ava-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:6px;min-width:140px;box-shadow:0 4px 16px rgba(0,0,0,0.08),0 1px 3px rgba(0,0,0,0.04);opacity:0;pointer-events:none;transform:translateY(-4px);transition:all 0.15s;z-index:100;}
.ava-wrap.open .ava-menu{opacity:1;pointer-events:auto;transform:translateY(0);}
.ava-menu-item{display:flex;align-items:center;gap:0.45rem;width:100%;padding:0.4rem 0.55rem;border:none;background:transparent;font-family:'Geist',sans-serif;font-size:0.72rem;color:var(--ink2);cursor:pointer;border-radius:var(--rs);text-align:left;transition:all 0.1s;}
.ava-menu-item:hover{background:var(--bg);color:var(--ink);}

/* ── Layout ── */
.layout{display:flex;flex:1;min-height:0;}
.main{flex:1;overflow-y:auto;display:flex;justify-content:center;transition:margin-right 0.35s cubic-bezier(0.16,1,0.3,1);}
.main.shifted{margin-right:var(--panel);}
.main::-webkit-scrollbar{width:3px;}
.main::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.page{padding:2rem 2rem 3rem;width:100%;max-width:620px;}

@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

/* ── Brief Head ── */
.brief-head{margin-bottom:1.8rem;animation:fadeUp 0.4s ease both;}
.brief-greeting{font-family:'Instrument Serif',serif;font-size:1.5rem;color:var(--ink);margin-bottom:0.3rem;}
.brief-summary{font-size:0.78rem;color:var(--ink2);line-height:1.7;}
.brief-summary strong{color:var(--ink);font-weight:500;}

/* ── Sections ── */
.sec{margin-bottom:1.6rem;}
.sec-label{display:flex;align-items:center;gap:0.5rem;margin-bottom:0.7rem;animation:fadeUp 0.4s ease both;}
.sec-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.sec-text{font-size:0.63rem;font-weight:500;color:var(--ink3);letter-spacing:0.08em;text-transform:uppercase;}
.sec-count{font-size:0.6rem;color:var(--ink3);background:var(--bg);padding:1px 6px;border-radius:99px;border:1px solid var(--border);}
.sec-more{margin-left:auto;font-size:0.66rem;color:var(--ink3);cursor:pointer;text-decoration:none;transition:color 0.12s;}
.sec-more:hover{color:var(--ink2);}

/* ── Context affordance ── */
.ctx-add{position:absolute;top:8px;right:8px;width:20px;height:20px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--ink3);font-size:0.7rem;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:all 0.15s;z-index:5;font-family:'Geist',sans-serif;line-height:1;}
.acard:hover .ctx-add,.job-mini:hover .ctx-add,.fyi:hover .ctx-add{opacity:1;}
.ctx-add:hover{border-color:var(--blue);color:var(--btext);background:var(--bbg);}
.ctx-on .ctx-add{opacity:1;background:var(--blue);color:#fff;border-color:var(--blue);}
.ctx-on{border-color:var(--blue) !important;background:rgba(26,58,143,0.015);}

/* ── Action Cards ── */
.acard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:0.55rem;overflow:hidden;transition:all 0.15s;animation:fadeUp 0.4s ease both;position:relative;}
.acard:hover{border-color:rgba(23,21,15,0.14);}
.acard-main{padding:0.9rem 1.1rem;display:flex;align-items:flex-start;gap:0.75rem;}
.acard-icon{width:26px;height:26px;border-radius:var(--rs);display:flex;align-items:center;justify-content:center;font-size:0.75rem;flex-shrink:0;margin-top:1px;}
.acard-body{flex:1;min-width:0;}
.acard-context{font-size:0.6rem;color:var(--ink3);margin-bottom:0.15rem;}
.acard-text{font-size:0.8rem;color:var(--ink2);line-height:1.65;}
.acard-text strong{color:var(--ink);font-weight:500;}
.acard-actions{display:flex;gap:0.35rem;margin-top:0.55rem;flex-wrap:wrap;}
.act{font-size:0.69rem;padding:0.28rem 0.72rem;border-radius:99px;border:1px solid var(--border);background:transparent;font-family:'Geist',sans-serif;color:var(--ink2);cursor:pointer;transition:all 0.12s;}
.act:hover{border-color:rgba(23,21,15,0.18);color:var(--ink);}
.act.p{background:var(--ink);color:#fff;border-color:transparent;}
.act.p:hover{opacity:0.85;}
.diff-strip{border-top:1px solid var(--border2);padding:0.55rem 1.1rem;background:#FAFAF8;}
.dl{font-size:0.7rem;font-family:'SF Mono','Menlo',monospace;line-height:1.85;padding:0.1rem 0.4rem;border-radius:4px;}
.dl.r{background:rgba(153,27,27,0.06);color:var(--rtext);text-decoration:line-through;text-decoration-color:rgba(153,27,27,0.35);}
.dl.a{background:rgba(42,96,73,0.07);color:var(--gtext);}
.draft-strip{border-top:1px solid var(--border2);padding:0.65rem 1.1rem;background:#FAFAF8;}
.draft-text{font-size:0.72rem;color:var(--ink2);line-height:1.75;font-style:italic;border-left:2.5px solid var(--ink3);padding-left:0.7rem;margin-bottom:0.5rem;}
.draft-meta{font-size:0.62rem;color:var(--ink3);}
.acard-expand{padding:0.4rem 1.1rem;border-top:1px solid var(--border2);display:flex;align-items:center;gap:0.4rem;font-size:0.67rem;color:var(--ink3);cursor:pointer;transition:all 0.12s;}
.acard-expand:hover{background:var(--bg);color:var(--ink2);}
.pava{width:12px;height:12px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Instrument Serif',serif;font-size:0.38rem;flex-shrink:0;}

/* ── Done states ── */
.acard.done{opacity:0;transform:translateY(-4px) scale(0.98);transition:all 0.35s ease;pointer-events:none;margin-bottom:0;padding:0;max-height:0;overflow:hidden;}
.done-toast{display:flex;align-items:center;gap:0.5rem;padding:0.55rem 0.9rem;background:var(--gbg);border:1px solid rgba(42,96,73,0.15);border-radius:var(--r);margin-bottom:0.55rem;font-size:0.72rem;color:var(--gtext);animation:fadeUp 0.35s ease both;}
.all-done{text-align:center;padding:2rem 1rem;animation:fadeUp 0.5s ease both;}
.all-done-icon{font-size:1.4rem;margin-bottom:0.5rem;}
.all-done-text{font-size:0.82rem;color:var(--ink2);line-height:1.7;}
.all-done-text strong{color:var(--ink);font-weight:500;}

/* ── Job Mini ── */
.job-mini{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:0.4rem;overflow:hidden;transition:all 0.15s;animation:fadeUp 0.4s ease both;position:relative;}
.job-mini:hover{border-color:rgba(23,21,15,0.14);}
.jm-row{padding:0.7rem 1rem;display:flex;align-items:center;gap:0.8rem;}
.jm-l{flex:1;min-width:0;}
.jm-name{font-size:0.8rem;font-weight:500;color:var(--ink);margin-bottom:2px;}
.jm-meta{font-size:0.66rem;color:var(--ink3);}
.jm-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:3px;}
.tag{font-size:0.6rem;padding:2px 7px;border-radius:99px;font-weight:500;}
.tg{background:var(--gbg);color:var(--gtext);}
.tb{background:var(--bbg);color:var(--btext);}
.ta{background:var(--abg);color:var(--atext);}
.jm-r{display:flex;align-items:center;gap:0.5rem;flex-shrink:0;}
.jm-pct{font-size:0.82rem;font-weight:500;color:var(--ink);}
.jm-acts{display:flex;gap:0.3rem;}
.jm-btn{font-size:0.66rem;padding:0.28rem 0.7rem;border-radius:var(--rs);border:none;cursor:pointer;font-family:'Geist',sans-serif;font-weight:500;transition:opacity 0.12s;}
.jm-yes{background:var(--ink);color:#fff;}
.jm-yes:hover{opacity:0.85;}
.jm-no{background:transparent;color:var(--ink3);border:1px solid var(--border);}
.jm-ai{padding:0.4rem 1rem;border-top:1px solid var(--border2);display:flex;align-items:center;gap:0.4rem;font-size:0.67rem;color:var(--ink2);cursor:pointer;transition:background 0.12s;}
.jm-ai:hover{background:var(--bg);}
.jm-cta{color:var(--btext);font-weight:500;}

/* ── FYI ── */
.fyi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:0.4rem;padding:0.7rem 1rem;display:flex;align-items:center;gap:0.7rem;transition:all 0.12s;animation:fadeUp 0.4s ease both;cursor:pointer;position:relative;}
.fyi:hover{border-color:rgba(23,21,15,0.14);}
.fyi-icon{font-size:0.75rem;flex-shrink:0;width:20px;text-align:center;}
.fyi-body{flex:1;min-width:0;}
.fyi-text{font-size:0.76rem;color:var(--ink2);line-height:1.55;}
.fyi-text strong{color:var(--ink);font-weight:500;}
.fyi-sub{font-size:0.64rem;color:var(--ink3);margin-top:1px;}
.fyi-arrow{font-size:0.65rem;color:var(--ink3);flex-shrink:0;}

/* ── Panel ── */
.panel{position:fixed;top:50px;right:0;bottom:0;width:var(--panel);background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translateX(100%);transition:transform 0.35s cubic-bezier(0.16,1,0.3,1);z-index:100;}
.panel.open{transform:translateX(0);}
.pv{display:none;flex-direction:column;flex:1;min-height:0;}
.pv.show{display:flex;}
.pv-head{padding:0.8rem 1rem;border-bottom:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.pv-title{font-size:0.8rem;font-weight:500;color:var(--ink);}
.pv-new{font-size:0.66rem;padding:0.25rem 0.65rem;border-radius:99px;border:1px solid var(--border);background:transparent;color:var(--ink2);cursor:pointer;font-family:'Geist',sans-serif;}
.pv-new:hover{border-color:rgba(23,21,15,0.2);color:var(--ink);}
.sess-scroll{flex:1;overflow-y:auto;padding:0.5rem;}
.sess-scroll::-webkit-scrollbar{width:3px;}
.sitem{padding:0.6rem 0.7rem;border-radius:var(--rs);cursor:pointer;transition:background 0.12s;border:1px solid transparent;margin-bottom:2px;position:relative;}
.sitem:hover{background:var(--bg);}
.sitem.cur{background:var(--bg);border-color:var(--border);}
.sitem-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px;}
.sitem-title{font-size:0.74rem;font-weight:500;color:var(--ink);}
.sitem-time{font-size:0.58rem;color:var(--ink3);}
.sitem-pre{font-size:0.66rem;color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:20px;}
.sitem-del{position:absolute;top:8px;right:6px;width:18px;height:18px;border-radius:50%;border:none;background:transparent;color:var(--ink3);font-size:0.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all 0.12s;font-family:'Geist',sans-serif;}
.sitem:hover .sitem-del{opacity:1;}
.sitem-del:hover{background:var(--rbg);color:var(--rtext);}
.list-empty{padding:2rem 1rem;text-align:center;font-size:0.72rem;color:var(--ink3);line-height:1.9;}

/* ── Chat ── */
.ph{padding:0.8rem 1rem;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:0.6rem;flex-shrink:0;}
.ph-back{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.7rem;color:var(--ink2);}
.ph-back:hover{background:var(--bg);color:var(--ink);}
.ph-info{flex:1;min-width:0;}
.ph-sup{font-size:0.58rem;color:var(--ink3);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:1px;}
.ph-title{font-size:0.78rem;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.msgs{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:0.7rem;}
.msgs::-webkit-scrollbar{width:3px;}
.m-ai{display:flex;gap:0.5rem;align-items:flex-start;animation:mIn 0.28s ease both;}
@keyframes mIn{from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:translateY(0);}}
.m-ava{width:22px;height:22px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Instrument Serif',serif;font-size:0.6rem;flex-shrink:0;margin-top:1px;}
.m-bub{background:var(--bg);border:1px solid var(--border);border-radius:3px 12px 12px 12px;padding:0.6rem 0.8rem;font-size:0.76rem;color:var(--ink2);line-height:1.7;max-width:90%;}
.m-bub strong{color:var(--ink);font-weight:500;}
.m-user{display:flex;justify-content:flex-end;animation:mIn 0.2s ease both;}
.m-user-bub{background:var(--ink);color:rgba(255,255,255,0.88);border-radius:12px 3px 12px 12px;padding:0.55rem 0.8rem;font-size:0.76rem;line-height:1.65;max-width:85%;}
.m-ctx-refs{display:flex;flex-wrap:wrap;gap:0.25rem;justify-content:flex-end;margin-bottom:0.25rem;animation:mIn 0.2s ease both;}
.m-ctx-pill{display:inline-flex;align-items:center;gap:0.2rem;padding:0.15rem 0.5rem;border-radius:99px;background:rgba(255,255,255,0.12);font-size:0.6rem;color:rgba(255,255,255,0.7);border:1px solid rgba(255,255,255,0.15);}
.typing{display:flex;gap:0.5rem;align-items:flex-start;}
.ty-bub{background:var(--bg);border:1px solid var(--border);border-radius:3px 12px 12px 12px;padding:0.55rem 0.8rem;display:flex;gap:4px;align-items:center;}
.ty-bub span{width:4px;height:4px;border-radius:50%;background:var(--ink3);animation:tb 1.2s infinite;}
.ty-bub span:nth-child(2){animation-delay:0.2s;}
.ty-bub span:nth-child(3){animation-delay:0.4s;}
@keyframes tb{0%,60%,100%{transform:translateY(0);}30%{transform:translateY(-4px);}}

/* ── Context tray + @ menu ── */
.chat-foot-wrap{border-top:1px solid var(--border2);flex-shrink:0;}
.ctx-tray{padding:0.45rem 0.75rem 0.1rem;display:none;flex-wrap:wrap;gap:0.25rem;}
.ctx-tray:not(:empty){display:flex;}
.ctx-pill{display:inline-flex;align-items:center;gap:0.25rem;padding:0.18rem 0.5rem;border-radius:99px;background:var(--bbg);border:1px solid rgba(26,58,143,0.15);font-size:0.61rem;color:var(--btext);font-weight:500;animation:mIn 0.2s ease both;white-space:nowrap;}
.ctx-pill-x{width:12px;height:12px;border-radius:50%;background:transparent;border:none;color:var(--btext);font-size:0.58rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0.6;padding:0;font-family:'Geist',sans-serif;}
.ctx-pill-x:hover{opacity:1;}
.chat-foot{padding:0.55rem 0.75rem;display:flex;gap:0.4rem;align-items:center;}
.cinput-wrap{flex:1;position:relative;}
.cinput{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:99px;padding:0.42rem 0.85rem;font-family:'Geist',sans-serif;font-size:0.75rem;color:var(--ink);outline:none;transition:border-color 0.15s;}
.cinput:focus{border-color:rgba(23,21,15,0.2);}
.cinput::placeholder{color:var(--ink3);}
.csend{width:24px;height:24px;border-radius:50%;background:var(--ink);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.65rem;flex-shrink:0;}
.at-menu{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--rs);box-shadow:0 4px 16px rgba(0,0,0,0.08);display:none;flex-direction:column;max-height:200px;overflow-y:auto;z-index:10;}
.at-menu.show{display:flex;}
.at-head{padding:0.35rem 0.7rem;font-size:0.58rem;font-weight:500;color:var(--ink3);letter-spacing:0.06em;text-transform:uppercase;border-bottom:1px solid var(--border2);}
.at-item{padding:0.45rem 0.7rem;font-size:0.72rem;color:var(--ink2);cursor:pointer;display:flex;align-items:center;gap:0.45rem;transition:background 0.1s;border-bottom:1px solid var(--border2);}
.at-item:last-child{border-bottom:none;}
.at-item:hover{background:var(--bg);color:var(--ink);}
.at-icon{font-size:0.65rem;width:16px;text-align:center;flex-shrink:0;}
.at-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ── Welcome / Onboarding ── */
.welcome{margin-bottom:2rem;animation:fadeUp 0.5s ease both;}
.welcome-greeting{font-family:'Instrument Serif',serif;font-size:1.6rem;color:var(--ink);margin-bottom:0.35rem;}
.welcome-sub{font-size:0.82rem;color:var(--ink2);line-height:1.7;}
.stepper{display:flex;align-items:center;gap:0;margin-bottom:1.5rem;animation:fadeUp 0.5s ease 0.1s both;}
.step-dot{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:0.68rem;font-weight:500;color:var(--ink3);transition:all 0.25s;flex-shrink:0;}
.step-dot.active{border-color:var(--ink);color:var(--ink);background:var(--surface);}
.step-dot.done{border-color:var(--green);background:var(--gbg);color:var(--gtext);}
.step-line{flex:1;height:1.5px;background:var(--border);transition:background 0.3s;}
.step-line.done{background:var(--green);}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;animation:fadeUp 0.4s ease 0.15s both;}
.card-body{padding:1.3rem 1.4rem;}
.card-title{font-size:0.88rem;font-weight:500;color:var(--ink);margin-bottom:0.15rem;}
.card-sub{font-size:0.72rem;color:var(--ink3);margin-bottom:1rem;}
.card-foot{padding:0.75rem 1.4rem;border-top:1px solid var(--border2);display:flex;align-items:center;justify-content:flex-end;gap:0.5rem;}

/* ── Upload ── */
.upload-zone{border:1.5px dashed var(--border);border-radius:var(--r);padding:1.8rem;display:flex;flex-direction:column;align-items:center;gap:0.5rem;cursor:pointer;transition:all 0.15s;background:var(--bg);position:relative;text-align:center;}
.upload-zone:hover{border-color:rgba(23,21,15,0.2);background:#EFEDE8;}
.upload-zone.drag{border-color:var(--blue);background:var(--bbg);}
.uz-icon{font-size:1.4rem;}
.uz-label{font-size:0.82rem;font-weight:500;color:var(--ink);}
.uz-sub{font-size:0.69rem;color:var(--ink3);}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}
.file-uploaded{background:var(--gbg);border:1px solid rgba(42,96,73,0.2);border-radius:var(--rs);padding:0.7rem 0.9rem;display:flex;align-items:center;gap:0.7rem;}
.fu-icon{font-size:1rem;flex-shrink:0;}
.fu-info{flex:1;}
.fu-name{font-size:0.78rem;font-weight:500;color:var(--green);}
.fu-meta{font-size:0.65rem;color:var(--gtext);opacity:0.8;}
.fu-change{font-size:0.65rem;color:var(--ink3);cursor:pointer;text-decoration:underline;text-underline-offset:2px;}

/* ── AI parsed profile ── */
.ai-parsed{margin-top:0.85rem;border:1px solid var(--border);border-radius:var(--rs);overflow:hidden;animation:fadeUp 0.35s ease both;}
.ap-head{padding:0.55rem 0.85rem;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:0.5rem;background:#FAFAF8;}
.ap-ava{width:16px;height:16px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Instrument Serif',serif;font-size:0.42rem;flex-shrink:0;}
.ap-label{font-size:0.68rem;color:var(--ink2);}
.ap-body{padding:0.75rem 0.85rem;display:flex;flex-direction:column;gap:0.5rem;}
.ap-row{display:flex;align-items:flex-start;gap:0.55rem;font-size:0.74rem;}
.ap-key{color:var(--ink3);font-size:0.65rem;min-width:55px;flex-shrink:0;margin-top:1px;}
.ap-val{color:var(--ink);line-height:1.5;}
.ap-tags{display:flex;flex-wrap:wrap;gap:3px;}
.ap-tag{font-size:0.6rem;padding:2px 7px;border-radius:99px;background:var(--bbg);color:var(--btext);font-weight:500;}
.ap-foot{padding:0.5rem 0.85rem;border-top:1px solid var(--border2);font-size:0.65rem;color:var(--ink3);}

/* ── Forms ── */
.form-group{margin-bottom:0.85rem;}
.form-label{font-size:0.72rem;font-weight:500;color:var(--ink2);margin-bottom:0.3rem;}
.form-select,.form-input{width:100%;padding:0.5rem 0.8rem;border:1px solid var(--border);border-radius:var(--rs);font-family:'Geist',sans-serif;font-size:0.8rem;color:var(--ink);background:var(--bg);outline:none;transition:border-color 0.12s;}
.form-select:focus,.form-input:focus{border-color:var(--ink);background:#fff;}
.form-hint{font-size:0.65rem;color:var(--ink3);margin-top:0.25rem;}
.form-row2{display:grid;grid-template-columns:1fr 1fr;gap:0.6rem;}
.pills{display:flex;flex-wrap:wrap;gap:0.4rem;}
.pill{padding:0.4rem 0.85rem;border-radius:99px;border:1px solid var(--border);font-size:0.75rem;color:var(--ink2);cursor:pointer;background:transparent;font-family:'Geist',sans-serif;transition:all 0.12s;}
.pill:hover{border-color:rgba(23,21,15,0.2);color:var(--ink);}
.pill.on{background:var(--ink);color:#fff;border-color:transparent;}
.ai-autofill{display:flex;align-items:center;gap:0.45rem;padding:0.55rem 0.75rem;background:var(--bbg);border:1px solid rgba(26,58,143,0.12);border-radius:var(--rs);margin-bottom:0.85rem;font-size:0.7rem;color:var(--btext);animation:fadeUp 0.3s ease both;}
.ai-autofill .af-dot{width:14px;height:14px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Instrument Serif',serif;font-size:0.38rem;flex-shrink:0;}

/* ── Buttons ── */
.btn-next{padding:0.48rem 1.2rem;border:none;border-radius:var(--rs);background:var(--ink);font-family:'Geist',sans-serif;font-size:0.76rem;color:#fff;cursor:pointer;font-weight:500;transition:opacity 0.12s;}
.btn-next:hover{opacity:0.85;}
.btn-next:disabled{opacity:0.25;pointer-events:none;}

/* ── Done card ── */
.done-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2rem 1.5rem;text-align:center;animation:fadeUp 0.5s ease both;}
.done-icon{font-size:1.6rem;margin-bottom:0.6rem;}
.done-title{font-family:'Instrument Serif',serif;font-size:1.2rem;color:var(--ink);margin-bottom:0.3rem;}
.done-sub{font-size:0.78rem;color:var(--ink2);line-height:1.7;margin-bottom:1rem;}
.done-log{display:flex;flex-direction:column;gap:0.3rem;text-align:left;padding:0.75rem;background:var(--bg);border-radius:var(--rs);margin-bottom:1rem;}
.done-log-row{display:flex;align-items:center;gap:0.45rem;font-size:0.7rem;color:var(--ink2);}
.done-log-row .dlr-check{color:var(--gtext);font-size:0.75rem;}
.done-cta{padding:0.5rem 1.4rem;border:none;border-radius:var(--rs);background:var(--ink);font-family:'Geist',sans-serif;font-size:0.78rem;color:#fff;cursor:pointer;font-weight:500;}
.done-cta:hover{opacity:0.85;}

/* ── Auth pages ── */
.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:2rem;}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2rem;width:100%;max-width:380px;animation:fadeUp 0.5s ease both;}
.auth-brand{font-family:'Instrument Serif',serif;font-size:1.8rem;color:var(--ink);text-align:center;margin-bottom:0.3rem;}
.auth-sub{font-size:0.78rem;color:var(--ink2);text-align:center;margin-bottom:1.5rem;}
.auth-form .form-group{margin-bottom:0.7rem;}
.auth-btn{width:100%;padding:0.55rem;border:none;border-radius:var(--rs);background:var(--ink);color:#fff;font-family:'Geist',sans-serif;font-size:0.82rem;font-weight:500;cursor:pointer;transition:opacity 0.12s;}
.auth-btn:hover{opacity:0.85;}
.auth-divider{display:flex;align-items:center;gap:0.75rem;margin:1rem 0;font-size:0.68rem;color:var(--ink3);}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.auth-google{width:100%;padding:0.5rem;border:1px solid var(--border);border-radius:var(--rs);background:var(--surface);color:var(--ink);font-family:'Geist',sans-serif;font-size:0.78rem;cursor:pointer;transition:border-color 0.12s;display:flex;align-items:center;justify-content:center;gap:0.5rem;}
.auth-google:hover{border-color:rgba(23,21,15,0.2);}
.auth-footer{text-align:center;margin-top:1rem;font-size:0.72rem;color:var(--ink3);}
.auth-footer a{color:var(--btext);text-decoration:underline;text-underline-offset:2px;}
.auth-error{background:var(--rbg);border:1px solid rgba(153,27,27,0.15);color:var(--rtext);padding:0.5rem 0.75rem;border-radius:var(--rs);font-size:0.72rem;margin-bottom:0.75rem;display:none;}

/* ── Empty state ── */
.empty-state{text-align:center;padding:3rem 1rem;animation:fadeUp 0.5s ease both;}
.empty-icon{font-size:2rem;margin-bottom:0.75rem;}
.empty-title{font-family:'Instrument Serif',serif;font-size:1.2rem;color:var(--ink);margin-bottom:0.3rem;}
.empty-sub{font-size:0.78rem;color:var(--ink2);line-height:1.7;}

/* ── Loading spinner ── */
.loading{display:flex;align-items:center;justify-content:center;padding:3rem;}
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--ink);border-radius:50%;animation:spin 0.6s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
