:root{
  --navy:#4a5638;
  --navy-deep:#2d3621;
  --gold:#c9a961;
  --gold-dark:#9b7e3d;
  --gold-faint:#f0e4c8;
  --cream:#faf7f0;
  --paper:#fffdf8;
  --ink:#1c1f16;
  --ink-mute:#6b705c;
  --line:#e9e2cf;
  --success:#3d7a5c;
  --danger:#a13838;
  --warn:#b8852c;
  --shadow-sm:0 1px 2px rgba(74,86,56,.06),0 2px 8px rgba(74,86,56,.04);
  --shadow-md:0 4px 12px rgba(74,86,56,.08),0 12px 32px rgba(74,86,56,.06);
  --shadow-lg:0 12px 32px rgba(74,86,56,.12),0 24px 64px rgba(74,86,56,.08);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--cream);color:var(--ink);font-family:'Inter',system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.45;overscroll-behavior-y:none}
body{min-height:100vh;min-height:100dvh}
#root{max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;background:var(--cream);padding-bottom:calc(88px + env(safe-area-inset-bottom));position:relative}
button{font-family:inherit;font-size:inherit;cursor:pointer;border:0;background:none;color:inherit;padding:0;touch-action:manipulation}
input,textarea,select{font-family:inherit;font-size:16px;color:inherit}
a{color:inherit;text-decoration:none}

/* ---------- LAYOUT ---------- */
.screen{padding:0 20px;padding-top:calc(env(safe-area-inset-top) + 16px)}
.top{display:flex;align-items:center;justify-content:space-between;padding:14px 0 20px}
.top h1{font-family:'Playfair Display',serif;font-size:26px;font-weight:600;margin:0;color:var(--navy-deep);letter-spacing:-.5px}
.top-sub{font-size:13px;color:var(--ink-mute);margin-top:2px;font-weight:500}
.top-r{display:flex;gap:8px}

/* ---------- BUTTONS / ICONS ---------- */
.icon-btn{width:40px;height:40px;border-radius:12px;background:var(--paper);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);color:var(--navy-deep);transition:transform .15s}
.icon-btn:active{transform:scale(.94)}
.btn{padding:14px;border-radius:14px;font-weight:600;font-size:14px;text-align:center;display:flex;align-items:center;justify-content:center;gap:6px;transition:transform .15s}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.5}
.btn svg{width:16px;height:16px;stroke-width:2.2}
.btn-primary{background:var(--navy);color:var(--cream);box-shadow:0 4px 12px rgba(74,86,56,.25)}
.btn-gold{background:var(--gold);color:var(--navy-deep);box-shadow:0 4px 12px rgba(201,169,97,.3)}
.btn-ghost{background:var(--paper);color:var(--navy-deep);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.btn-danger{background:var(--danger);color:#fff}
.btn-block{width:100%}
.btn-sm{padding:10px 14px;font-size:13px;border-radius:10px}
.btn-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.btn-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:12px 0}
.link{font-size:13px;color:var(--gold-dark);font-weight:600;background:none;padding:0}

/* ---------- HERO ---------- */
.hero-cta{width:100%;padding:22px;border-radius:20px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-deep) 100%);color:var(--cream);display:flex;align-items:center;justify-content:space-between;box-shadow:0 8px 24px rgba(74,86,56,.25);position:relative;overflow:hidden;transition:transform .15s}
.hero-cta:active{transform:scale(.98)}
.hero-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 85% 30%,rgba(201,169,97,.25),transparent 55%);pointer-events:none}
.hero-cta-l{text-align:left;position:relative;z-index:1}
.hero-cta-t{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;letter-spacing:-.3px}
.hero-cta-s{font-size:13px;color:rgba(250,247,240,.75);margin-top:2px;font-weight:500}
.hero-cta-r{width:48px;height:48px;border-radius:50%;background:var(--gold);color:var(--navy-deep);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 6px rgba(201,169,97,.2);position:relative;z-index:1}

/* ---------- KPIS ---------- */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px}
.kpi{background:var(--paper);border-radius:16px;padding:14px;box-shadow:var(--shadow-sm)}
.kpi-l{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--ink-mute);font-weight:600}
.kpi-v{font-family:'Playfair Display',serif;font-size:26px;font-weight:600;color:var(--navy-deep);margin-top:4px;letter-spacing:-.5px}
.kpi-s{font-size:11px;color:var(--ink-mute);margin-top:1px}

/* ---------- SECTION HEADER ---------- */
.section-h{display:flex;align-items:baseline;justify-content:space-between;margin:28px 0 12px}
.section-h h2{font-family:'Playfair Display',serif;font-size:18px;font-weight:600;margin:0;color:var(--navy-deep);letter-spacing:-.2px}
.section-h .meta{font-size:12px;color:var(--ink-mute);font-weight:500}

/* ---------- CARD (job/client/etc) ---------- */
.card{background:var(--paper);border-radius:16px;padding:16px;box-shadow:var(--shadow-sm);margin-bottom:10px;display:block;width:100%;text-align:left;transition:transform .15s}
.card:active{transform:scale(.99)}
.card.no-padding{padding:0}
.card-row{display:flex;align-items:center;gap:12px}
.card-body{flex:1;min-width:0}
.card-t{font-weight:600;color:var(--navy-deep);font-size:15px;letter-spacing:-.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-s{font-size:13px;color:var(--ink-mute);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-r{text-align:right;flex-shrink:0}
.card-amt{font-family:'Playfair Display',serif;font-weight:600;color:var(--navy-deep);font-size:16px}

/* job-card with embedded action footer */
.jcard{background:var(--paper);border-radius:16px;box-shadow:var(--shadow-sm);margin-bottom:10px;overflow:hidden}
.jcard-body{padding:16px;display:block;width:100%;text-align:left}
.jcard-body:active{background:var(--cream)}
.jcard-meta{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.jcard-acts{border-top:1px solid var(--line);padding:8px;display:flex;gap:6px;background:linear-gradient(180deg,rgba(240,228,200,.18),transparent)}
.jcard-acts > *{flex:1;min-width:0}
.j-act{padding:10px 6px;border-radius:10px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;color:var(--navy-deep);transition:background .15s}
.j-act svg{width:14px;height:14px;stroke-width:2.2;flex-shrink:0}
.j-act:active{background:rgba(74,86,56,.08)}
.j-act.primary{background:var(--navy);color:var(--cream)}
.j-act.primary:active{background:var(--navy-deep)}
.j-act.gold{background:var(--gold);color:var(--navy-deep)}
.j-act.danger{color:var(--danger)}

/* ---------- AVATAR ---------- */
.avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--gold-faint),var(--gold));color:var(--navy-deep);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;flex-shrink:0;font-family:'Playfair Display',serif}
.avatar.lg{width:72px;height:72px;font-size:24px}
.avatar.sm{width:32px;height:32px;font-size:12px}

/* ---------- PILLS / STATUS ---------- */
.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}
.pill::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor}
.pill.lead{background:#eef1e5;color:#5a6b3e}
.pill.visit_scheduled{background:#e7ecd7;color:#4a5638}
.pill.quoted{background:#fbf1d6;color:#8b6a22}
.pill.won{background:#dce9df;color:#2d5a42}
.pill.scheduled{background:#dde6c9;color:#4a5638}
.pill.in_progress{background:#cfe0d4;color:#2d5a42}
.pill.done{background:#d4e5d9;color:#1f4a35}
.pill.invoiced{background:#fbf1d6;color:#8b6a22}
.pill.paid{background:linear-gradient(135deg,#d4e5d9,#bcd6c2);color:#1f4a35;font-weight:700}
.pill.closed{background:#e8d8d8;color:#7a2626}

/* ---------- BOTTOM NAV ---------- */
.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:rgba(255,253,248,.88);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);padding:8px 6px;padding-bottom:calc(8px + env(safe-area-inset-bottom));z-index:50}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 0;color:var(--ink-mute);font-size:10px;font-weight:600;letter-spacing:.3px;transition:color .15s;background:none}
.nav-btn.active{color:var(--navy-deep)}
.nav-btn.active svg{stroke-width:2.4}
.nav-btn svg{width:22px;height:22px;stroke-width:2}

/* ---------- SEARCH / FILTERS ---------- */
.search{width:100%;padding:12px 16px 12px 44px;border-radius:14px;border:1px solid var(--line);background:var(--paper);box-shadow:var(--shadow-sm);font-size:15px;outline:none;-webkit-appearance:none}
.search:focus{border-color:var(--gold)}
.search-wrap{position:relative;margin-bottom:14px}
.search-wrap svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--ink-mute);width:18px;height:18px;pointer-events:none}
.segmented{display:flex;background:var(--paper);border-radius:14px;padding:4px;box-shadow:var(--shadow-sm);margin-bottom:14px;overflow-x:auto;scrollbar-width:none}
.segmented::-webkit-scrollbar{display:none}
.seg-btn{flex:1;padding:8px 12px;border-radius:10px;font-size:12px;font-weight:600;color:var(--ink-mute);transition:all .15s;white-space:nowrap;background:none}
.seg-btn.active{background:var(--navy);color:var(--cream)}

/* ---------- QUICK ACTIONS (Call/Msg/Nav) ---------- */
.qa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:16px 0}
.qa-btn{padding:18px 8px;border-radius:16px;color:#fff;display:flex;flex-direction:column;align-items:center;gap:6px;font-size:13px;font-weight:600;box-shadow:var(--shadow-md);transition:transform .15s}
.qa-btn:active{transform:scale(.96)}
.qa-btn svg{width:22px;height:22px;stroke-width:2.2}
.qa-call{background:linear-gradient(135deg,var(--navy),var(--navy-deep))}
.qa-msg{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--navy-deep)}
.qa-nav{background:linear-gradient(135deg,#2a2a2a,#000)}
.qa-btn.disabled{opacity:.3;pointer-events:none}

/* ---------- LINE ROWS (info display) ---------- */
.line-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.line-row:last-child{border:0}
.line-ico{width:36px;height:36px;border-radius:10px;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--navy);flex-shrink:0}
.line-ico svg{width:18px;height:18px;stroke-width:2}
.line-l{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-mute);font-weight:600}
.line-v{font-size:15px;color:var(--ink);font-weight:500;margin-top:1px;word-break:break-word}
.line-body{flex:1;min-width:0}

/* ---------- JOB DETAIL KPIs ---------- */
.jobkpi{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:14px 0}
.jk{background:var(--paper);border-radius:14px;padding:12px;box-shadow:var(--shadow-sm)}
.jk-l{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-mute);font-weight:600}
.jk-v{font-family:'Playfair Display',serif;font-size:20px;font-weight:600;color:var(--navy-deep);margin-top:2px;letter-spacing:-.3px}
.jk-v.neg{color:var(--danger)}
.jk-v.pos{color:var(--success)}

/* progress bar for paid amount */
.paybar{height:6px;background:var(--cream);border-radius:100px;margin-top:8px;overflow:hidden}
.paybar-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-dark));border-radius:100px}
.paybar.full .paybar-fill{background:linear-gradient(90deg,#5fa37e,var(--success))}

/* ---------- SUB TABS ---------- */
.sub-tabs{display:flex;background:var(--paper);border-radius:14px;padding:4px;box-shadow:var(--shadow-sm);margin:14px 0;overflow-x:auto;scrollbar-width:none}
.sub-tabs::-webkit-scrollbar{display:none}
.sub-tab{flex:1;padding:8px 10px;border-radius:10px;font-size:12px;font-weight:600;color:var(--ink-mute);white-space:nowrap;background:none}
.sub-tab.active{background:var(--cream);color:var(--navy-deep)}

/* ---------- MODAL (bottom sheet) ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(28,31,22,.5);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:100;animation:fadeIn .2s}
.modal{background:var(--paper);border-radius:24px 24px 0 0;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s cubic-bezier(.2,.9,.3,1.1);padding:0 0 max(24px,env(safe-area-inset-bottom)) 0}
.modal-handle{width:40px;height:5px;background:var(--line);border-radius:100px;margin:10px auto 0}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px 8px}
.modal-header h2{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;margin:0;color:var(--navy-deep);letter-spacing:-.3px}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--ink-mute)}
.modal-body{padding:8px 22px 22px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}

/* ---------- FORMS ---------- */
.f-group{margin-bottom:14px}
.f-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-mute);font-weight:600;margin-bottom:6px}
.f-input,.f-textarea,.f-select{width:100%;padding:13px 14px;border-radius:12px;border:1px solid var(--line);background:var(--paper);outline:none;font-size:16px;color:var(--ink);font-family:inherit}
.f-input:focus,.f-textarea:focus,.f-select:focus{border-color:var(--gold)}
.f-textarea{min-height:80px;resize:vertical}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.f-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.f-help{font-size:12px;color:var(--ink-mute);margin-top:6px;line-height:1.4}
.f-err{font-size:12px;color:var(--danger);margin-top:6px;font-weight:500}
.f-ok{font-size:13px;color:var(--success);margin-top:6px;font-weight:500;padding:10px 12px;background:rgba(61,122,92,.08);border-radius:10px}
.f-bad{font-size:13px;color:var(--danger);margin-top:6px;font-weight:500;padding:10px 12px;background:rgba(161,56,56,.08);border-radius:10px;line-height:1.5}

/* ---------- WIZARD ---------- */
.wiz-steps{display:flex;gap:6px;margin-bottom:18px}
.wiz-step{flex:1;height:4px;background:var(--line);border-radius:2px}
.wiz-step.done{background:var(--gold)}
.wiz-step.active{background:var(--navy)}
.wiz-pick{width:100%;padding:18px;border-radius:16px;background:var(--paper);box-shadow:var(--shadow-sm);text-align:left;display:flex;align-items:center;gap:14px;margin-bottom:10px;transition:transform .15s,box-shadow .15s}
.wiz-pick:active{transform:scale(.99);box-shadow:var(--shadow-md)}
.wiz-pick-ico{width:48px;height:48px;border-radius:14px;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--navy);flex-shrink:0}
.wiz-pick-ico.gold{background:var(--gold-faint);color:var(--gold-dark)}
.wiz-pick-body{flex:1;min-width:0}
.wiz-pick-t{font-family:'Playfair Display',serif;font-size:17px;font-weight:600;color:var(--navy-deep);letter-spacing:-.2px}
.wiz-pick-s{font-size:13px;color:var(--ink-mute);margin-top:2px}

/* selected client preview */
.sel-prev{padding:12px;background:var(--cream);border-radius:12px;margin-top:8px}

/* same-as-client tag */
.tag-sync{font-size:10px;font-weight:700;color:var(--success);letter-spacing:.6px;text-transform:uppercase;display:inline-flex;align-items:center;gap:4px}
.tag-sync::before{content:'●'}

/* ---------- LINE ITEMS ---------- */
.li-row{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:8px;display:flex;flex-direction:column;gap:8px}
.li-name-row{display:flex;gap:8px;align-items:center}
.li-name-row .f-input{flex:1}
.li-dims-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1.4fr;gap:6px}
.li-dim-label{display:block;font-size:10px;color:var(--ink-mute);font-weight:600;text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}
.li-dim-input{font-size:13px;padding:9px 10px;text-align:center}
.li-dim-input:not([type="number"])::placeholder{color:var(--ink-mute);opacity:.5}
/* Finance mini KPI cards */
.kpi-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kpi-mini{padding:12px}
.kpi-mini .kpi-l{font-size:11px;letter-spacing:.5px}
.kpi-mini .kpi-v{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;color:var(--navy-deep);margin-top:2px}
/* Photo grid (estimate attachments) */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-bottom:10px}
.photo-thumb{position:relative;aspect-ratio:1/1;border-radius:10px;overflow:hidden;background:var(--cream);border:1px solid var(--line)}
.photo-link{display:block;width:100%;height:100%;position:relative}
.photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.photo-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--ink-mute);background:var(--cream);z-index:0}
.photo-thumb img{position:relative;z-index:1}
.photo-del{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(20,20,20,.7);color:#fff;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;z-index:2}
.photo-del:hover{background:var(--danger)}
.photo-actions{display:flex;gap:8px}
.photo-actions .btn{padding:11px;font-size:13px;display:flex;align-items:center;justify-content:center;gap:6px}
.li-total{background:var(--cream);border-radius:12px;padding:14px;margin-top:10px;display:flex;justify-content:space-between;align-items:center}
.li-total-l{font-size:13px;color:var(--ink-mute);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.li-total-v{font-family:'Playfair Display',serif;font-size:24px;font-weight:600;color:var(--navy-deep)}
.li-del{width:36px;height:36px;border-radius:10px;background:rgba(161,56,56,.08);color:var(--danger);display:flex;align-items:center;justify-content:center}
.li-add{width:100%;padding:10px;border-radius:10px;background:var(--cream);color:var(--navy-deep);font-weight:600;font-size:13px;border:1px dashed var(--gold-dark)}

/* ---------- MONTH BARS ---------- */
.m-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.m-row:last-child{border:0}
.m-lbl{font-size:12px;font-weight:600;color:var(--ink-mute);width:60px;flex-shrink:0;letter-spacing:.3px}
.m-bar{flex:1;height:8px;background:var(--cream);border-radius:100px;overflow:hidden;position:relative}
.m-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-dark));border-radius:100px;transition:width .4s}
.m-amt{font-family:'Playfair Display',serif;font-size:14px;font-weight:600;color:var(--navy-deep);width:80px;text-align:right;flex-shrink:0}

/* ---------- TOAST / LOADER ---------- */
.toast{position:fixed;bottom:calc(100px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);background:var(--navy-deep);color:var(--cream);padding:12px 20px;border-radius:100px;font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);z-index:200;animation:toastIn .2s;max-width:88%;text-align:center}
.toast.err{background:var(--danger)}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%,0)}}
.loader{width:22px;height:22px;border:2.5px solid rgba(74,86,56,.15);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-full{display:flex;align-items:center;justify-content:center;padding:80px 0;color:var(--ink-mute)}

/* ---------- EMPTY STATES ---------- */
.empty{text-align:center;padding:40px 20px;color:var(--ink-mute);font-size:14px}
.empty-t{font-family:'Playfair Display',serif;font-size:18px;color:var(--navy-deep);margin-bottom:4px}

/* ---------- CALENDAR ---------- */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin:0 0 14px;padding:0 4px}
.cal-month{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;color:var(--navy-deep);letter-spacing:-.3px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;background:var(--paper);border-radius:16px;padding:12px;box-shadow:var(--shadow-sm)}
.cal-dow{text-align:center;font-size:10px;font-weight:700;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.6px;padding:6px 0}
.cal-day{aspect-ratio:1;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-direction:column;font-size:13px;color:var(--ink);position:relative;background:none;font-weight:500}
.cal-day.muted{color:var(--line)}
.cal-day.today{background:var(--cream);font-weight:700}
.cal-day.has-event::after{content:'';position:absolute;bottom:6px;width:5px;height:5px;border-radius:50%;background:var(--gold)}
.cal-day.selected{background:var(--navy);color:var(--cream);font-weight:700}
.cal-day.selected.has-event::after{background:var(--gold-faint)}

/* ---------- SETTINGS ---------- */
.setup-steps{background:var(--cream);border-radius:14px;padding:14px 16px;margin:10px 0 16px}
.setup-step{display:flex;gap:10px;padding:6px 0;font-size:13px;line-height:1.5}
.setup-num{width:22px;height:22px;border-radius:50%;background:var(--navy);color:var(--cream);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px}
.setup-step b{color:var(--navy-deep)}

/* ---------- UTIL ---------- */
.sp-sm{height:8px}.sp-md{height:16px}.sp-lg{height:28px}
.mono{font-family:'JetBrains Mono',monospace;font-size:12px;word-break:break-all}
.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:100px;background:var(--cream);font-size:11px;font-weight:600;color:var(--ink-mute)}
.chip.gold{background:var(--gold-faint);color:var(--gold-dark)}
.divider{height:1px;background:var(--line);margin:14px 0}

/* doc number badge */
.doc-num{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);font-weight:500;letter-spacing:.5px}

/* status flow bar (visualization on JobDetail) */
.flow{display:flex;gap:2px;background:var(--cream);border-radius:100px;padding:3px;margin:10px 0}
.flow-step{flex:1;height:6px;border-radius:100px;background:var(--line)}
.flow-step.done{background:var(--gold)}
.flow-step.active{background:var(--navy)}

/* ---------- OFFLINE BANNER & DISABLED STATES ---------- */
.offline-banner{
  position:sticky;top:0;z-index:200;
  background:#fff4d1;border-bottom:1px solid #e6c66e;
  color:#7a5a00;font-size:13px;font-weight:600;
  padding:10px 16px;
  display:flex;align-items:center;gap:10px;
  text-align:center;justify-content:center;
}
.offline-dot{
  width:8px;height:8px;border-radius:50%;background:#d49500;flex-shrink:0;
  animation:offline-pulse 1.6s ease-in-out infinite;
}
@keyframes offline-pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(1.3)}
}
/* When app is offline, mute primary save buttons (visual only — actual block is in apiWith) */
.app-offline .btn-primary{
  background:var(--ink-mute) !important;
  opacity:.5;
  cursor:not-allowed;
}
.app-offline .btn-primary:hover,
.app-offline .btn-primary:active{
  transform:none !important;
}
