:root{
  --ink:#1c1a17;--muted:#6f6a62;--faint:#9b958b;--line:#e4dfd6;--line2:#d2ccc0;
  --paper:#ffffff;--surface:#faf8f3;--page:#f2eee6;--ember:#d8541f;--ember-dk:#a23c12;
  --blue:#185fa5;--blue-bg:#e6f1fb;--green:#3b6d11;--green-bg:#eaf3de;
  --amber:#854f0b;--amber-bg:#faeeda;--red:#a32d2d;--red-bg:#fceaea;--purple:#3c3489;--purple-bg:#eeedfe;
  --radius:9px;--radius-lg:13px;--font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);font-size:13px;color:var(--ink);background:var(--page);-webkit-font-smoothing:antialiased}
button{cursor:pointer;font-family:inherit;font-size:12px;border:1px solid var(--line2);background:var(--paper);color:var(--ink);border-radius:7px;padding:6px 11px;transition:all .13s;display:inline-flex;align-items:center;gap:5px}
button:hover{background:var(--surface);border-color:var(--faint)}
button.active{background:var(--ink);color:#fff;border-color:var(--ink);font-weight:500}
button:active{transform:scale(.98)}
input,select,textarea{font-family:inherit;font-size:12px;border:1px solid var(--line2);background:var(--paper);color:var(--ink);border-radius:7px;padding:7px 9px;width:100%;outline:none;transition:border-color .13s}
input:focus,select:focus,textarea:focus{border-color:var(--blue)}
textarea{resize:vertical;min-height:54px}
.btp{background:var(--ember);color:#fff;border-color:var(--ember)}.btp:hover{background:var(--ember-dk);border-color:var(--ember-dk)}
.bdn{background:var(--red-bg);color:var(--red);border-color:#e9b8b8}.bdn:hover{background:#f7dada}

.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}
.topbar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--paper);border-bottom:1px solid var(--line);flex-wrap:wrap;flex-shrink:0;z-index:20}
.brand{font-size:16px;font-weight:600;display:flex;align-items:center;gap:7px;margin-right:6px;letter-spacing:-.02em}
.brand i{color:var(--ember);font-size:21px}.brand small{font-weight:400;color:var(--faint);font-size:11px}
.vtabs{display:flex;gap:3px;background:var(--surface);padding:3px;border-radius:9px}
.vtab{border:none;background:transparent;padding:6px 11px;border-radius:6px;color:var(--muted);font-weight:500}
.vtab:hover{background:var(--paper);color:var(--ink)}
.vtab.active{background:var(--paper);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.06)}
.calsub{display:flex;gap:2px;background:var(--surface);padding:3px;border-radius:8px}
.calsub button{border:none;background:transparent;padding:5px 9px;font-size:11px;color:var(--muted);border-radius:5px}
.calsub button.active{background:var(--paper);color:var(--ink);font-weight:500}
.nb{display:flex;gap:4px;align-items:center}
.dl{font-size:12px;color:var(--ink);min-width:128px;text-align:center;font-weight:500}
.spacer{margin-left:auto}

.bwrap{display:flex;flex:1;overflow:hidden;min-height:0}
.lsb{width:184px;flex-shrink:0;border-right:1px solid var(--line);background:var(--paper);display:flex;flex-direction:column;overflow-y:auto}
.sbsec{padding:11px 13px;border-bottom:1px solid var(--line)}
.sbsec h3{font-size:9.5px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.sbsec h3 a{font-size:9.5px;color:var(--blue);cursor:pointer;font-weight:600;text-transform:none;letter-spacing:0}
.vtog{display:flex;align-items:center;gap:7px;padding:4px 5px;font-size:12px;border-radius:7px;cursor:pointer;transition:background .1s}
.vtog:hover{background:var(--surface)}
.vtog.off{opacity:.4}
.vtog .eye{font-size:14px;color:var(--faint);margin-left:auto}
.vtog .tc{font-size:10px;color:var(--faint);font-weight:500;min-width:14px;text-align:right}
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0;color:#fff}
.sdot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.trow{display:flex;align-items:center;gap:7px;padding:3px 0;font-size:12px}.tc2{margin-left:auto;font-size:10px;color:var(--faint)}

.qpanel{width:215px;flex-shrink:0;border-right:1px solid var(--line);background:var(--surface);display:flex;flex-direction:column;overflow:hidden}
.qtabs{display:flex;border-bottom:1px solid var(--line);background:var(--paper)}
.qt{flex:1;padding:9px 3px;font-size:10px;text-align:center;cursor:pointer;border:none;border-radius:0;background:transparent;color:var(--muted);border-bottom:2px solid transparent;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:3px}
.qtabs .qt.active{color:var(--ink);border-bottom-color:var(--ember);background:transparent}
.qt:hover{background:var(--surface)}
.qt .cnt{font-size:8px;padding:1px 6px;border-radius:20px;background:var(--ember);color:#fff;font-weight:600;line-height:1.5}
.qbody{flex:1;overflow-y:auto;padding:9px}
.qbody.drop-active{background:var(--blue-bg);outline:2px dashed var(--blue);outline-offset:-6px}
.qempty{text-align:center;padding:22px 8px;font-size:10.5px;color:var(--faint);line-height:1.6}
.qempty i{font-size:24px;color:var(--line2);display:block;margin-bottom:6px}
.qcard{border-radius:var(--radius);border:1px solid var(--line);background:var(--paper);padding:8px 10px;margin-bottom:7px;cursor:pointer;transition:all .13s}
.qcard:hover{border-color:var(--faint);box-shadow:0 2px 5px rgba(0,0,0,.06)}
.qcard .nm{font-weight:600;font-size:11.5px;line-height:1.3}
.qcard.unschb{border-left:3px solid var(--faint)}.qcard.reschb{border-left:3px solid var(--amber)}.qcard.planb{border-left:3px solid var(--purple)}
.bdg{font-size:8.5px;padding:2px 6px;border-radius:20px;white-space:nowrap;font-weight:600}
.jm{font-size:10px;color:var(--muted);line-height:1.6;display:flex;align-items:center;gap:3px}.jm i{font-size:11px;color:var(--faint)}
.fg{background:#fbeaf0;color:#72243e}.fw{background:var(--amber-bg);color:var(--amber)}.fp{background:var(--green-bg);color:var(--green)}.fe{background:var(--purple-bg);color:var(--purple)}.fsr{background:#e1f5ee;color:#085041}
.ss{background:var(--blue-bg);color:var(--blue)}.sd{background:#eee;color:#555}.sw{background:var(--red-bg);color:var(--red)}
.pb{background:var(--green-bg);color:var(--green)}.pp{background:var(--blue-bg);color:var(--blue)}.pe{background:var(--purple-bg);color:var(--purple)}
.do{background:var(--red-bg);color:var(--red)}.dsoon{background:var(--amber-bg);color:var(--amber)}.dok{background:var(--green-bg);color:var(--green)}
.sbdg{display:inline-flex;align-items:center;gap:3px;font-size:8.5px;padding:2px 7px;border-radius:20px;font-weight:600;white-space:nowrap;flex-shrink:0}

.main{flex:1;overflow:auto;min-width:0;background:var(--page)}
.hint{font-size:10.5px;color:var(--faint);display:flex;align-items:center;gap:5px;padding:6px 13px;background:var(--surface);border-bottom:1px solid var(--line)}

/* Time grid (day + week) */
.tghead{display:flex;position:sticky;top:0;z-index:6;background:var(--paper);border-bottom:1px solid var(--line)}
.tg-gut{width:58px;flex-shrink:0;border-right:1px solid var(--line)}
.tg-col-h{flex:1;min-width:104px;padding:7px 5px;text-align:center;border-right:1px solid var(--line)}
.tg-col-h:last-child{border-right:none}
.tg-col-h.today{background:rgba(216,84,31,.05)}
.tg-col-h .avlg{margin:0 auto 3px}
.tg-col-h .nm{font-size:11px;font-weight:600}.tg-col-h .sub{font-size:9px;color:var(--faint)}
.tgbody{display:flex;position:relative}
.gutter{width:58px;flex-shrink:0;position:relative;border-right:1px solid var(--line)}
.ghour{position:absolute;right:6px;font-size:9.5px;color:var(--faint);font-weight:500;transform:translateY(-6px)}
.tcol{flex:1;min-width:104px;position:relative;border-right:1px solid var(--line)}
.tcol:last-child{border-right:none}
.jblock{position:absolute;border-radius:6px;border:1px solid var(--line);border-left:3px solid;background:var(--paper);padding:3px 6px;font-size:10px;overflow:hidden;cursor:grab;box-shadow:0 1px 2px rgba(0,0,0,.05);user-select:none}
.jblock:hover{box-shadow:0 2px 7px rgba(0,0,0,.14);z-index:3}
.jblock .bnm{font-weight:600;font-size:10px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jblock .btime{font-size:9px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.jblock .bmeta{font-size:9px;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jblock .avs{display:flex;gap:2px;margin-top:2px}
.jblock .cb{color:var(--red);font-weight:700;font-size:8px}
.rh{position:absolute;left:0;right:0;height:8px;cursor:ns-resize;z-index:2}.rh.top{top:-1px}.rh.bot{bottom:-1px}
.emptycal{padding:30px;text-align:center;color:var(--faint);font-size:12px}

/* Month */
.calwrap{min-width:480px}
.chrow{display:grid;position:sticky;top:0;z-index:5;background:var(--paper);border-bottom:1px solid var(--line)}
.chc{padding:8px 6px;text-align:center;font-size:10px;font-weight:600;color:var(--muted);border-right:1px solid var(--line)}
.chc:last-child{border-right:none}.chc.today{color:var(--ember)}
.crow{display:grid}
.ccell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:84px;padding:5px;transition:background .1s}
.ccell:last-child{border-right:none}.ccell.today{background:rgba(24,95,165,.04)}.ccell.drop-hover{background:var(--blue-bg)}.ccell.offmonth{background:var(--surface);opacity:.55}
.cdn{font-size:10px;color:var(--faint);font-weight:600;margin-bottom:3px}.ccell.today .cdn{color:var(--ember)}
.cmini{border-radius:5px;padding:2px 5px;margin-bottom:2px;font-size:9.5px;border-left:3px solid;background:var(--paper);border:1px solid var(--line);cursor:grab;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.pw{padding:14px;display:flex;flex-direction:column;gap:10px}.pw h2{font-size:15px;font-weight:600}
.pf{display:flex;gap:5px;flex-wrap:wrap}.pf button{font-size:11px;padding:5px 10px;border-radius:20px}
.pg{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:8px}
.pcard{border-radius:var(--radius);border:1px solid var(--line);background:var(--paper);padding:10px 12px;cursor:pointer;border-left:3px solid;transition:all .13s}
.pcard:hover{box-shadow:0 2px 6px rgba(0,0,0,.07);border-color:var(--faint)}.pcard .nm{font-weight:600;font-size:12px}

.rw{padding:14px;display:flex;flex-direction:column;gap:12px}
.rhdr{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.rhdr h2{font-size:15px;font-weight:600;display:flex;align-items:center;gap:6px}
.startrow{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:9px 12px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.startrow .lbl{font-size:11px;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:5px}
.shops{display:flex;gap:4px}.shops button{font-size:10px;padding:4px 8px}
.cg{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:10px}
.ccard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.chead{padding:10px 12px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px;background:var(--surface)}
.cbody{padding:9px 11px;display:flex;flex-direction:column;gap:5px}
.cjob{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:7px;border:1px solid var(--line);cursor:pointer}.cjob:hover{border-color:var(--faint)}
.cnum{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;flex-shrink:0;color:#fff;background:var(--blue)}
.cfoot{padding:9px 11px;border-top:1px solid var(--line);display:flex;gap:6px;flex-wrap:wrap}
.sbox{padding:9px 11px;font-size:11px;color:var(--ink);border-left:3px solid var(--blue);background:var(--blue-bg);border-radius:0 7px 7px 0;line-height:1.5}.sbox i{color:var(--blue)}
.sbox b{font-weight:600}

.perfw{padding:16px;display:flex;flex-direction:column;gap:16px;max-width:1180px}
.perfw h2{font-size:16px;font-weight:600}.perf-sub{font-size:12px;color:var(--muted);margin-top:2px}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.kpi{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:13px 15px}
.kpi .lbl{font-size:10.5px;color:var(--muted);font-weight:500;display:flex;align-items:center;gap:5px}
.kpi .val{font-size:25px;font-weight:600;letter-spacing:-.02em;margin-top:4px}.kpi .sub{font-size:10px;color:var(--faint);margin-top:1px}
.inccard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px 16px}
.inccard h3{font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px;margin-bottom:4px}
.inccard .desc{font-size:11px;color:var(--muted);margin-bottom:12px}
.incblock{margin-bottom:14px}
.incblock h4{font-size:11px;font-weight:600;color:var(--ink);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.incgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:11px}
.incf label{display:block;font-size:10px;color:var(--muted);font-weight:500;margin-bottom:3px}
.bandtbl{font-size:11px;color:var(--muted);background:var(--surface);border-radius:8px;padding:9px 11px;line-height:1.7}
.ptable{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.ptable .pthead{padding:11px 14px;border-bottom:1px solid var(--line);font-size:13px;font-weight:600;background:var(--surface);display:flex;align-items:center;gap:7px}
table{width:100%;border-collapse:collapse}
th{font-size:9.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--faint);font-weight:600;text-align:left;padding:9px 11px;border-bottom:1px solid var(--line)}
th.num,td.num{text-align:right}
td{padding:10px 11px;border-bottom:1px solid var(--line);font-size:12px}
tr:last-child td{border-bottom:none}
.tcell{display:flex;align-items:center;gap:8px}
.bonus{font-weight:600;color:var(--green)}
.ratepill{font-size:9px;padding:2px 6px;border-radius:20px;font-weight:600}
.r0{background:#eee;color:#777}.r15{background:var(--amber-bg);color:var(--amber)}.r20{background:var(--green-bg);color:var(--green)}
.tierchip{font-size:9px;padding:2px 6px;border-radius:20px;font-weight:600;margin-right:3px;display:inline-block}
.tier1{background:var(--green-bg);color:var(--green)}.tier2{background:var(--amber-bg);color:var(--amber)}.tier3{background:var(--purple-bg);color:var(--purple)}

.mwrap{max-width:390px;margin:0 auto;padding:14px;display:flex;flex-direction:column;gap:9px}
.mhdr{background:var(--paper);border-radius:var(--radius-lg);border:1px solid var(--line);padding:12px 14px;display:flex;align-items:center;gap:11px}
.mtsel{display:flex;gap:5px;flex-wrap:wrap}.mtsel button{font-size:11px;padding:5px 11px;border-radius:20px}
.mjob{background:var(--paper);border-radius:var(--radius-lg);border:1px solid var(--line);overflow:hidden;border-left:3px solid}
.mjh{padding:11px 13px;border-bottom:1px solid var(--line)}.mjb{padding:11px 13px}
.mjf{padding:9px 13px;border-top:1px solid var(--line);display:flex;gap:5px;flex-wrap:wrap}.mjf button{font-size:11px;padding:6px 10px}

.mbg{position:fixed;inset:0;background:rgba(28,26,23,.45);display:flex;align-items:flex-start;justify-content:center;z-index:100;padding:24px;overflow-y:auto}
.mdl{background:var(--paper);border-radius:var(--radius-lg);width:100%;max-width:560px;display:flex;flex-direction:column;box-shadow:0 20px 50px rgba(0,0,0,.25);margin:auto}
.mdlh{padding:15px 18px 12px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.mdlh h2{font-size:15px;font-weight:600}.mdlh button{border:none;background:transparent;padding:5px;border-radius:6px;color:var(--muted)}.mdlh button:hover{background:var(--surface)}
.mdlb{padding:15px 18px;max-height:66vh;overflow-y:auto}
.mdlf{padding:12px 18px;border-top:1px solid var(--line);display:flex;gap:7px;justify-content:flex-end}
.fr{margin-bottom:11px}.fr label{display:block;font-size:10.5px;color:var(--muted);margin-bottom:4px;font-weight:500}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.chkrow{display:flex;align-items:center;gap:8px;padding:8px 11px;background:var(--surface);border-radius:8px;margin-bottom:8px}
.chkrow input{width:auto}.chkrow label{margin:0;font-size:11.5px;color:var(--ink);font-weight:500}
.infoline{font-size:11px;color:var(--muted);background:var(--surface);border-radius:8px;padding:8px 10px;margin-bottom:11px;line-height:1.5}
.elig{font-size:11px;border-radius:8px;padding:8px 10px;margin-bottom:11px;line-height:1.5}
.elig.ok{background:var(--green-bg);color:var(--green)}.elig.no{background:var(--amber-bg);color:var(--amber)}
.chips{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;padding:3px 6px 3px 4px;border-radius:20px;border:1px solid var(--line2);background:var(--paper)}
.chip i{cursor:pointer;color:var(--faint);font-size:13px}.chip i:hover{color:var(--red)}
.addsel{width:auto;padding:4px 7px;font-size:11px;border-radius:20px;border-style:dashed}
.warn{font-size:10.5px;color:var(--amber);margin-top:6px;display:flex;align-items:center;gap:4px}
.crewrow{display:flex;align-items:flex-start;gap:9px;padding:11px 0;border-bottom:1px solid var(--line)}.crewrow:last-child{border-bottom:none}
.swatches{display:flex;gap:4px}
.sw{width:18px;height:18px;border-radius:50%;cursor:pointer;border:2px solid transparent}.sw.on{border-color:var(--ink)}
.skillrow{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px}
.skbtn{font-size:10px;padding:3px 9px;border-radius:20px;cursor:pointer;border:1px solid var(--line2);background:var(--paper);color:var(--muted)}
.skbtn.on{background:var(--green-bg);color:var(--green);border-color:#bcd89a}
.ac-wrap{position:relative}
.ac-list{position:absolute;top:calc(100% + 2px);left:0;right:0;background:var(--paper);border:1px solid var(--line2);border-radius:8px;z-index:60;max-height:190px;overflow:auto;display:none;box-shadow:0 8px 22px rgba(0,0,0,.14)}
.ac-item{padding:8px 10px;cursor:pointer;font-size:12px;border-bottom:1px solid var(--line)}
.ac-item:last-child{border-bottom:none}.ac-item:hover{background:var(--blue-bg)}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:10px 18px;border-radius:24px;font-size:12px;z-index:200;box-shadow:0 6px 20px rgba(0,0,0,.3);animation:tin .25s}
@keyframes tin{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}
@media(max-width:760px){.lsb,.qpanel{display:none}}

/* ---- login screen ---- */
.loginwrap{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--page);z-index:300;padding:20px}
.logincard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px 26px 22px;width:100%;max-width:340px;box-shadow:0 12px 40px rgba(0,0,0,.10)}
.logincard .brand{font-size:18px;font-weight:600;display:flex;align-items:center;gap:7px;margin-bottom:14px}
.logincard .brand i{color:var(--ember);font-size:22px}
.logincard .brand small{font-weight:400;color:var(--faint);font-size:11px}
.logincard h2{font-size:16px;font-weight:600;margin-bottom:2px}
.logincard .loginsub{font-size:11.5px;color:var(--muted);margin-bottom:8px;line-height:1.5}
.logincard label{display:block;font-size:10.5px;color:var(--muted);font-weight:500;margin:10px 0 4px}
.logincard .btp{width:100%;justify-content:center;margin-top:16px;padding:9px}
.loginerr{color:var(--red);font-size:11px;margin-top:10px;min-height:14px;line-height:1.4}
.logincard .logo{max-height:34px;width:auto}

/* ---- logo ---- */
.logo{max-height:24px;width:auto;vertical-align:middle}
.logo-sm{max-height:30px}
.topbar .brand .logo{margin-right:4px}

/* ---- routing suggestion dismiss ---- */
.sbox-dismiss{display:flex;align-items:flex-start;gap:6px}
.sbox-dismiss>span{flex:1}
.sugg-x{border:none;background:transparent;color:var(--faint);padding:2px 4px;border-radius:6px;flex-shrink:0}
.sugg-x:hover{background:rgba(0,0,0,.06);color:var(--red)}

/* ---- tech / mobile-first view ---- */
.techmain{background:var(--page)}
.th{background:var(--paper);border-bottom:1px solid var(--line);padding:12px 14px 10px;position:sticky;top:0;z-index:10}
.th-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.th-id{display:flex;align-items:center;gap:11px;min-width:0}
.th-name{font-size:17px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.th-date{font-size:12px;color:var(--muted)}
.th-stat{font-size:11.5px;color:var(--faint);margin-top:8px}
.th-out{border:1px solid var(--line2);background:var(--paper);border-radius:8px;padding:8px 10px;flex-shrink:0}
.th-toggle{display:flex;gap:5px;margin-top:10px;background:var(--surface);padding:3px;border-radius:9px}
.th-toggle button{flex:1;justify-content:center;border:none;background:transparent;padding:8px;border-radius:6px;color:var(--muted);font-weight:500;font-size:12px}
.th-toggle button.active{background:var(--paper);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.07)}
.th.th-embed{position:static;border:none;background:transparent;padding:0 0 4px}

.twrap{max-width:560px;margin:0 auto;padding:12px;display:flex;flex-direction:column;gap:11px}
.tjc{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--ink);border-radius:var(--radius-lg);padding:13px 14px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.tjc-done{opacity:.72}
.tjc-h{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.tjc-time{font-size:12px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:5px}
.tjc-name{font-size:16px;font-weight:600;line-height:1.25;margin-bottom:5px}
.tjc-meta{font-size:12px;color:var(--muted);line-height:1.7;display:flex;align-items:center;gap:6px}
.tjc-meta i{color:var(--faint)}
.tjc-meta a{color:var(--blue);text-decoration:none}
.tj-with{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:8px;font-size:11.5px;color:var(--muted)}
.tj-with>span{color:var(--faint);font-weight:500}
.tj-mate{display:inline-flex;align-items:center;gap:4px;background:var(--surface);border-radius:20px;padding:3px 9px 3px 3px;font-weight:500;color:var(--ink)}
.tjc-lbl{display:block;font-size:10.5px;color:var(--muted);font-weight:500;margin:11px 0 4px}
.tjc-ta{width:100%;font-size:13px}
.tjc-check{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink);margin-top:11px;padding:9px 11px;background:var(--surface);border-radius:9px;font-weight:500}
.tjc-check input{width:auto;transform:scale(1.15)}
.tjc-actions{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.tjc-actions button{padding:9px 12px;font-size:12.5px}
.tjc-actions .btp{flex:1;justify-content:center;min-width:130px}
.bdone{background:var(--green-bg);color:var(--green);border-color:#bcd89a;font-weight:600}

.tcal{padding:0}
.tcal-nav{display:flex;align-items:center;gap:6px;justify-content:center;padding:10px;background:var(--paper);border-bottom:1px solid var(--line)}
.tcal-nav span{font-size:13px;font-weight:600;min-width:150px;text-align:center}

@media(max-width:620px){
  .tjc-actions .btp{flex:1 1 100%}
  .twrap{padding:10px}
}

/* ---- white calendar / app surface ---- */
.main{background:#fff}
.techmain{background:#fff}
.tghead,.tgbody,.gutter,.calwrap,.ccell{background:#fff}
.ccell.offmonth{background:var(--surface)}

/* ---- route per-tech start selector ---- */
.cstart{display:flex;align-items:center;gap:8px;padding:8px 11px;border-bottom:1px solid var(--line);background:var(--surface);font-size:11px}
.cstart .lbl{color:var(--muted);font-weight:600;display:flex;align-items:center;gap:5px;white-space:nowrap}
.cstart select{flex:1;font-size:11px;padding:5px 7px;min-width:0}

/* ---- admin add-user form ---- */
.adduser{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;padding:12px 14px}
.adduser .af{display:flex;flex-direction:column;flex:1;min-width:130px}
.albl{font-size:10px;color:var(--muted);font-weight:500;margin-bottom:4px}
.rolepill{display:inline-block;font-size:11px;font-weight:600;color:var(--purple);background:var(--purple-bg);padding:3px 10px;border-radius:20px}

/* ---- customer link / job history ---- */
.custlink{color:var(--blue);cursor:pointer;font-weight:500}
.custlink:hover{text-decoration:underline}

/* ---- tech color picker ---- */
.colorrow{display:flex;align-items:center;gap:8px}
.cpick{width:34px;height:26px;padding:0;border:1px solid var(--line2);border-radius:6px;cursor:pointer;background:none;flex-shrink:0}

/* ---- returning-customer indicator ---- */
.retc{font-size:11.5px;color:var(--green);background:var(--green-bg);border-radius:8px;padding:7px 10px;display:flex;align-items:center;gap:6px;font-weight:500}

/* ---- recurring job controls ---- */
.recrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:11px}
.reclbl{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--ink)}
.reclbl input{width:auto}
.recdone{font-size:10.5px;color:var(--green);font-weight:600;display:inline-flex;align-items:center;gap:3px}

/* ---- weather strip ---- */
.wx{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--ink);padding:8px 14px;background:var(--surface);border-bottom:1px solid var(--line)}
.wx i{color:var(--muted)}
.wx-main{display:flex;align-items:center;gap:6px}
.wx-main i{font-size:16px;color:var(--blue)}
.wx-t{font-weight:600}
.wx-p{color:var(--muted);display:inline-flex;align-items:center;gap:4px}
.wx-muted{color:var(--faint)}
.wx-bad{background:var(--amber-bg)}
.wx-warn{display:inline-flex;align-items:center;gap:5px;color:var(--amber);font-weight:600;margin-left:auto}
.wx-bad .wx-main i{color:var(--amber)}

/* ---- heading spacing audit (prevent title/subtitle overlap) ---- */
.perfw h2,.pw h2,.rhdr h2{margin-bottom:2px;line-height:1.25}
.perfw>div>h2{margin-bottom:0}

/* ---- hourly weather on the calendar grid ---- */
.wxbg{position:absolute;inset:0;pointer-events:none;z-index:0}
.wxh{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:center;color:rgba(28,26,23,.16);font-size:11px}
.wxh-rain{background:rgba(24,95,165,.07)}
.wxh-snow{background:rgba(24,95,165,.11)}
.wxh-sun{background:rgba(245,200,60,.10)}
.wxh-cloud{background:rgba(120,120,120,.06)}
.wx{cursor:pointer}
.wx-more{margin-left:6px;color:var(--faint)}

/* ---- collapsible queue sections ---- */
.qbody-acc{flex:1;overflow-y:auto}
.qsec{border-bottom:1px solid var(--line)}
.qsec-h{display:flex;align-items:center;gap:7px;padding:10px 11px;cursor:pointer;background:var(--paper);font-size:11px;font-weight:600;color:var(--ink);user-select:none;position:sticky;top:0;z-index:1}
.qsec-h:hover{background:var(--surface)}
.qsec-h .qsec-t{flex:1}
.qsec-h .cnt{font-size:8.5px;padding:1px 6px;border-radius:20px;background:var(--ember);color:#fff;font-weight:600}
.qsec-b{padding:9px}
.qsec-b.drop-active{background:var(--blue-bg);outline:2px dashed var(--blue);outline-offset:-6px}

/* ---- service-plan card button row ---- */
.qcard-btns{display:flex;gap:6px;margin-top:8px}
.qcard-btns button{flex:1;justify-content:center;padding:6px 8px;font-size:11px}

/* ---- animated weather effects (override the static tints) ---- */
.wxbg{overflow:hidden}
.wxh{overflow:hidden}
.wxh-rain{background-image:repeating-linear-gradient(115deg,rgba(24,95,165,.16) 0 1px,transparent 1px 9px);background-size:auto 16px;animation:wxrain .55s linear infinite}
@keyframes wxrain{from{background-position:0 0}to{background-position:-7px 16px}}
.wxh-snow{background-image:radial-gradient(rgba(70,110,165,.35) 1.4px,transparent 1.7px);background-size:15px 15px;animation:wxsnow 3.2s linear infinite}
@keyframes wxsnow{from{background-position:0 0}to{background-position:7px 15px}}
.wxh-wind{background-image:repeating-linear-gradient(90deg,rgba(120,120,120,.16) 0 16px,transparent 16px 44px);background-size:60px auto;animation:wxwind 1.1s linear infinite}
@keyframes wxwind{from{background-position:0 0}to{background-position:60px 0}}
.wxh-sun{background:radial-gradient(circle at 50% 30%,rgba(245,200,60,.20),rgba(245,200,60,0) 70%);animation:wxsun 3.5s ease-in-out infinite}
@keyframes wxsun{0%,100%{opacity:.45}50%{opacity:1}}
.wxh-cloud{background:rgba(120,120,120,.05)}
.wx-loc{display:inline-flex;align-items:center;gap:4px;color:var(--muted);font-weight:500}
.dljump{font-size:11px;padding:4px 6px;border-radius:7px;width:auto}
@media(prefers-reduced-motion:reduce){.wxh-rain,.wxh-snow,.wxh-wind,.wxh-sun{animation:none}}

/* ---- job change history timeline ---- */
.histwrap{margin-top:14px}
.histlbl{display:flex;align-items:center;gap:6px;font-size:10.5px;color:var(--muted);font-weight:600;margin-bottom:6px}
.histlog{max-height:160px;overflow-y:auto;border:1px solid var(--line);border-radius:8px;background:var(--surface)}
.hrow{display:flex;align-items:baseline;gap:8px;padding:5px 9px;border-bottom:1px solid var(--line);font-size:11px}
.hrow:last-child{border-bottom:none}
.ht{color:var(--faint);white-space:nowrap;font-size:10px;min-width:74px}
.hw{flex:1;color:var(--ink)}
.hby{color:var(--faint);font-size:10px;white-space:nowrap}

/* ---- responsive nav + collapsible panels ---- */
html,body{overflow-x:hidden}
.vtabs{flex-wrap:wrap}
.botnav{display:none}
.panel-bar{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-bottom:1px solid var(--line);background:var(--surface)}
.panel-bar-t{font-size:9.5px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.06em}
.panel-collapse,.panel-reopen{border:1px solid var(--line2);background:var(--paper);border-radius:6px;padding:3px 6px;cursor:pointer;color:var(--muted)}
.panel-collapse:hover,.panel-reopen:hover{background:var(--surface);color:var(--ink)}
.lsbmini,.qpmini{width:26px;flex-shrink:0;border-right:1px solid var(--line);background:var(--paper);display:flex;justify-content:center;padding-top:8px}
@media(max-width:820px){
 .topbar .vtabs{display:none}
 .botnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--paper);border-top:1px solid var(--line);box-shadow:0 -2px 10px rgba(0,0,0,.07)}
 .botnav button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;border:none;background:transparent;padding:9px 4px;color:var(--muted);font-size:11px;font-weight:500;border-radius:0}
 .botnav button i{font-size:22px}
 .botnav button.active{color:var(--ember)}
 .botnav button:active{transform:none}
 .bwrap,.main,.techmain,.twrap{padding-bottom:62px}
}

/* ---- Google Calendar integration indicators ---- */
.gcal-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#34a853;margin-left:6px;vertical-align:middle}
.gcal-dot[title]{cursor:default}
.gconn{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:13px;padding:4px 10px;border-radius:14px}
.gconn.on{background:rgba(52,168,83,.14);color:#1e7e34}
.gconn.off{background:rgba(120,120,120,.14);color:#777}
.gconn::before{content:"";width:8px;height:8px;border-radius:50%}
.gconn.on::before{background:#34a853}
.gconn.off::before{background:#bbb}
