/* Big Air — Angelo's Day */
:root{
  --air:#0e7490; --air-d:#0b5563; --air-l:#e0f2f7;
  --clay:#ea7a3c; --clay-d:#c25e26;
  --ink:#13343b; --muted:#5b7780; --line:#dce8eb;
  --bg:#f4f8f9; --card:#ffffff; --ok:#1f9d6b; --ok-bg:#e6f6ef;
  --warn:#d9822b; --bad:#d14343; --bad-bg:#fbe9e9;
  --shadow:0 1px 3px rgba(16,60,70,.08),0 4px 14px rgba(16,60,70,.06);
  --r:14px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--ink); -webkit-text-size-adjust:100%;
  line-height:1.45;
}
button{font-family:inherit;cursor:pointer}
[hidden]{display:none !important}

/* ── Login ── */
.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:linear-gradient(160deg,#0e7490,#0b5563);}
.login-card{background:var(--card);border-radius:20px;padding:34px 28px;width:100%;max-width:360px;
  box-shadow:0 18px 50px rgba(0,0,0,.25);text-align:center;display:flex;flex-direction:column;gap:12px}
.brand-mark{font-size:42px;line-height:1}
.login-card h1{margin:2px 0 0;font-size:26px;letter-spacing:-.5px}
.login-card .sub{margin:0;color:var(--muted);font-size:14px}
.login-card input{margin-top:10px;padding:14px 16px;font-size:18px;border:1.5px solid var(--line);
  border-radius:12px;text-align:center;letter-spacing:3px;width:100%}
.login-card input:focus{outline:none;border-color:var(--air)}
.login-card button{padding:14px;font-size:16px;font-weight:650;color:#fff;background:var(--air);
  border:none;border-radius:12px}
.login-card button:active{background:var(--air-d)}
.login-err{color:var(--bad);font-size:14px;margin:2px 0 0;font-weight:600}
.login-hint{color:var(--muted);font-size:12px;margin:6px 0 0;line-height:1.4}

/* ── Top bar ── */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;background:var(--air);color:#fff;box-shadow:var(--shadow)}
.topbar-l{display:flex;align-items:baseline;gap:8px;min-width:0}
.logo{font-weight:800;font-size:17px;white-space:nowrap}
.app-name{font-size:13px;opacity:.85;white-space:nowrap}
.topbar-r{display:flex;align-items:center;gap:8px}
.badge{background:rgba(255,255,255,.18);padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600}
.badge.admin{background:var(--clay)}
.ghost-btn{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff;border-radius:8px;
  padding:5px 10px;font-size:13px}

/* ── Date bar ── */
.datebar{position:sticky;top:46px;z-index:20;background:var(--card);border-bottom:1px solid var(--line);
  padding:10px 14px;display:flex;flex-direction:column;gap:8px}
.date-nav{display:flex;align-items:center;justify-content:center;gap:6px}
.nav-arrow{font-size:22px;line-height:1;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);
  background:var(--card);color:var(--air)}
.nav-arrow:active{background:var(--air-l)}
.date-label{flex:1;max-width:260px;text-align:center;font-weight:700;font-size:16px;border:none;
  background:transparent;color:var(--ink);padding:8px}
.date-label.is-today{color:var(--air)}
.date-actions{display:flex;gap:8px;justify-content:center}
.chip-btn{border:1px solid var(--line);background:var(--card);border-radius:999px;padding:6px 14px;
  font-size:13px;font-weight:600;color:var(--air)}
.chip-btn:active{background:var(--air-l)}
.progress{display:flex;align-items:center;gap:10px}
.progress-bar{flex:1;height:9px;background:#e7eef0;border-radius:999px;overflow:hidden}
.progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--air),var(--ok));
  transition:width .3s ease}
.progress-text{font-size:13px;font-weight:700;color:var(--muted);min-width:74px;text-align:right}

/* ── Calendar ── */
.calendar{background:var(--card);border-bottom:1px solid var(--line);padding:12px 14px}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.cal-head button{border:1px solid var(--line);background:var(--card);border-radius:8px;width:34px;height:34px;
  font-size:18px;color:var(--air)}
.cal-title{font-weight:700}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal-dow{text-align:center;font-size:11px;color:var(--muted);font-weight:700;padding:2px 0}
.cal-cell{aspect-ratio:1;border-radius:9px;border:1px solid var(--line);display:flex;flex-direction:column;
  align-items:center;justify-content:center;font-size:13px;font-weight:600;position:relative;background:#fafdfd}
.cal-cell.empty{border:none;background:transparent}
.cal-cell.clickable{cursor:pointer}
.cal-cell.today{outline:2px solid var(--air);outline-offset:-2px}
.cal-cell.sel{box-shadow:0 0 0 2px var(--clay) inset}
.cal-cell .pct{font-size:9px;font-weight:700;color:var(--muted)}
.cal-cell.l0{background:#fafdfd}
.cal-cell.l1{background:#dff3ea}
.cal-cell.l2{background:#aee5cc}
.cal-cell.l3{background:#69cfa1}
.cal-cell.l4{background:#2bb47e;color:#fff}
.cal-cell.l4 .pct{color:#eafff6}

/* ── Main ── */
.main{max-width:980px;margin:0 auto;padding:18px 18px 70px}
.admin-banner{background:#fff4ea;border:1px solid #f4d6b8;color:var(--clay-d);border-radius:12px;
  padding:10px 12px;font-size:13px;font-weight:600;margin-bottom:12px}

/* always-on */
.alwayson{background:#fff8ef;border:1px solid #f3dcb8;border-radius:var(--r);margin-bottom:14px;overflow:hidden}
.alwayson summary{list-style:none;cursor:pointer;padding:12px 14px;font-weight:700;color:var(--clay-d);
  display:flex;align-items:center;gap:8px}
.alwayson summary::-webkit-details-marker{display:none}
.alwayson .ao-body{padding:0 14px 12px}
.ao-item{display:flex;gap:10px;padding:8px 0;border-top:1px dashed #f0ddc0}
.ao-item .ao-ic{font-size:18px}
.ao-item b{display:block;font-size:14px}
.ao-item span{font-size:13px;color:var(--muted)}

/* sections */
.section{background:var(--card);border:1px solid var(--line);border-radius:var(--r);margin-bottom:14px;
  overflow:hidden;box-shadow:var(--shadow)}
.section.big{border-color:#bfe3ea}
.section-head{display:flex;align-items:center;gap:10px;padding:13px 14px;cursor:pointer;user-select:none}
.section-head .s-ic{font-size:20px}
.section-head .s-title{font-weight:750;font-size:16px;flex:1}
.section-head .s-count{font-size:12px;font-weight:700;color:var(--muted);background:#eef5f6;
  border-radius:999px;padding:3px 9px}
.section-head .s-count.done{background:var(--ok-bg);color:var(--ok)}
.section-head .caret{color:var(--muted);transition:transform .2s}
.section.collapsed .caret{transform:rotate(-90deg)}
.section.collapsed .section-body{display:none}
.section-blurb{font-size:13px;color:var(--muted);padding:0 14px 8px;margin-top:-4px}
.section-body{padding:4px 0 6px}

/* task row */
.task{display:flex;gap:11px;padding:11px 14px;border-top:1px solid #eef4f5;align-items:flex-start}
.task:first-child{border-top:none}
.task.inactive{opacity:.55}
.check{position:relative;flex:0 0 auto;margin-top:1px}
.check input{position:absolute;opacity:0;width:26px;height:26px;margin:0;cursor:pointer}
.check .box{display:block;width:26px;height:26px;border:2px solid var(--line);border-radius:8px;
  background:#fff;transition:.15s}
.check input:checked+.box{background:var(--ok);border-color:var(--ok)}
.check input:checked+.box::after{content:"✓";color:#fff;font-weight:800;font-size:16px;
  position:absolute;left:6px;top:1px}
.check input:disabled+.box{background:#f0f4f5}
.task-body{flex:1;min-width:0}
.task-title{font-size:15px;font-weight:600;line-height:1.35}
.task.done .task-title{color:var(--muted)}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:5px}
.tag{font-size:11px;font-weight:700;border-radius:999px;padding:2px 8px}
.tag.freq-daily{background:#eef5f6;color:var(--muted)}
.tag.freq-mwf{background:#e8effb;color:#3a63b8}
.tag.goal{background:var(--ok-bg);color:var(--ok)}
.tag.inactive{background:#f0e6da;color:#9a7a4f}
.task-tools{display:flex;gap:14px;margin-top:7px;flex-wrap:wrap}
.linkbtn{background:none;border:none;color:var(--air);font-size:13px;font-weight:650;padding:0;
  display:inline-flex;align-items:center;gap:4px}
.linkbtn.guide{color:var(--clay-d)}
.task-detail{margin-top:9px;font-size:13.5px;color:#33555c;background:#f7fbfc;border:1px solid #e6eff1;
  border-radius:10px;padding:11px 12px}
.task-detail p{margin:0 0 6px}
.note{margin-top:8px;width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 11px;
  font-size:14px;resize:vertical;min-height:38px;font-family:inherit}
.note:focus{outline:none;border-color:var(--air)}
.note.saved{border-color:var(--ok)}

/* special: clock + eod */
.clockrow{align-items:center}
.clock-ctl{margin-top:6px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.clock-btn{background:var(--air);color:#fff;border:none;border-radius:10px;padding:9px 16px;font-weight:700;font-size:14px}
.clock-btn.set{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok)}
.clock-time{font-weight:700;color:var(--ok)}
.clear-x{background:none;border:none;color:var(--muted);font-size:13px;text-decoration:underline}

/* guide panels */
.guide{margin-top:9px;border:1px solid #ecd9c4;background:#fffaf3;border-radius:10px;padding:0;overflow:hidden}
.guide-h{font-weight:750;color:var(--clay-d);padding:10px 12px;font-size:13.5px;background:#fdf2e4}
.guide-b{padding:6px 12px 12px}
.g-list{margin:0;padding-left:18px;font-size:13px}
.g-list li{margin:5px 0}
.photo-grp{margin-top:8px}
.photo-grp>.pg-title{font-size:12px;font-weight:800;color:var(--air-d);text-transform:uppercase;
  letter-spacing:.4px;margin:8px 0 4px}
.photo-item{border-top:1px dashed #ecd9c4;padding:7px 0}
.photo-item .pi-h{font-size:13.5px;font-weight:650}
.photo-item .pi-h .n{display:inline-block;min-width:20px;color:var(--clay-d);font-weight:800}
.photo-item .pi-d{font-size:12.5px;color:#4a5d62;margin-top:3px;display:none}
.photo-item.open .pi-d{display:block}
.pi-d .lbl{font-weight:700;color:var(--ink)}
.pi-d .red{color:var(--bad)}
.rule{border-top:1px dashed #ecd9c4;padding:8px 0}
.rule b{color:var(--clay-d)}
.copybox{position:relative;background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px;
  font-size:12.5px;white-space:pre-wrap;margin-top:6px;font-family:ui-monospace,Menlo,Consolas,monospace}
.copybox .copy{position:absolute;top:6px;right:6px}
.mini-copy{background:var(--air-l);color:var(--air-d);border:none;border-radius:6px;padding:4px 9px;
  font-size:12px;font-weight:700}
.sitelist a{color:var(--air);word-break:break-word}

/* ── QA tracker ── */
.qa{margin:6px 12px 12px;border:1.5px solid #bfe3ea;border-radius:12px;background:#f3fafb;overflow:hidden}
.qa-head{display:flex;align-items:center;justify-content:space-between;padding:11px 13px;
  font-weight:750;color:var(--air-d)}
.qa-list{display:flex;flex-direction:column}
.jobcard{border-top:1px solid #d6ebef;background:#fff}
.jc-head{display:flex;align-items:center;gap:9px;padding:10px 12px;cursor:pointer;flex-wrap:wrap}
.jc-title{font-weight:700;font-size:14px;flex:1;min-width:120px}
.jc-title .who{color:var(--muted);font-weight:500}
.jc-chips{display:flex;gap:5px;flex-wrap:wrap}
.jchip{font-size:11px;font-weight:700;border-radius:999px;padding:2px 8px;background:#eef5f6;color:var(--muted)}
.jchip.ok{background:var(--ok-bg);color:var(--ok)}
.jchip.miss{background:var(--bad-bg);color:var(--bad)}
.jc-body{padding:4px 12px 14px;border-top:1px dashed #d6ebef;display:none}
.jobcard.open .jc-body{display:block}
.field{margin-top:10px}
.field label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:4px}
.field input[type=text],.field select,.field textarea{width:100%;border:1px solid var(--line);
  border-radius:9px;padding:9px 11px;font-size:14px;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--air)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.photogrid{display:grid;grid-template-columns:1fr;gap:4px;margin-top:6px}
.pg-sec{font-size:11px;font-weight:800;color:var(--air-d);text-transform:uppercase;margin:8px 0 2px;letter-spacing:.3px}
.pcheck{display:flex;align-items:flex-start;gap:8px;padding:5px 7px;border-radius:8px;font-size:13px;background:#fff;border:1px solid #eef4f5}
.pcheck input{width:20px;height:20px;margin:1px 0 0;flex:0 0 auto;accent-color:var(--ok)}
.pcheck.checked{background:var(--ok-bg);border-color:#bfe6d4}
.pcheck .pl{flex:1}
.pcheck .pn{font-weight:800;color:var(--clay-d);margin-right:4px}
.upsells{margin-top:8px;border:1px solid #ecd9c4;border-radius:9px;overflow:hidden}
.up-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-top:1px dashed #ecd9c4;font-size:13px;background:#fffaf3}
.up-row:first-child{border-top:none}
.up-row .up-t{flex:1}
.up-row .up-t b{display:block}
.up-row .up-t span{font-size:11.5px;color:var(--muted)}
.toggle{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--muted)}
.toggle input{width:18px;height:18px;accent-color:var(--clay)}
.up-row.flagged{background:var(--bad-bg)}
.up-row.flagged .up-t b{color:var(--bad)}
.checkline{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px}
.checkline label{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600}
.checkline input{width:20px;height:20px;accent-color:var(--ok)}
.jc-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;align-items:center}
.btn{border:none;border-radius:9px;padding:9px 14px;font-weight:700;font-size:13.5px}
.btn.primary{background:var(--air);color:#fff}
.btn.soft{background:var(--air-l);color:var(--air-d)}
.btn.clay{background:var(--clay);color:#fff}
.btn.danger{background:var(--bad-bg);color:var(--bad)}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--muted)}
.add-job{border:1.5px dashed var(--air);background:#fff;color:var(--air-d);
  border-radius:10px;padding:11px;font-weight:750;font-size:14px}
.qa-actions{display:flex;gap:9px;margin:11px 13px;flex-wrap:wrap}
.qa-actions .add-job{margin:0}
.qa-actions .add-job.primary{flex:1;min-width:240px;border-style:solid;background:var(--air);color:#fff;border-color:var(--air)}
.qa-actions .add-job.ghost{flex:0 0 auto;border-color:var(--line);color:var(--muted)}
@media(hover:hover){.qa-actions .add-job.primary:hover{background:var(--air-d)}}

/* HCP picker modal */
.modal-back{position:fixed;inset:0;background:rgba(10,40,48,.55);z-index:60;display:flex;align-items:flex-start;
  justify-content:center;padding:32px 16px;overflow:auto}
.modal{background:#fff;border-radius:16px;max-width:700px;width:100%;box-shadow:0 22px 60px rgba(0,0,0,.32);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;background:var(--air);color:#fff}
.modal-head h3{margin:0;font-size:17px}
.modal-head .x{background:rgba(255,255,255,.2);border:none;color:#fff;width:32px;height:32px;border-radius:8px;font-size:16px}
.modal-sub{padding:10px 18px;font-size:13px;color:var(--muted);border-bottom:1px solid var(--line);background:#f7fbfc}
.modal-list{max-height:58vh;overflow:auto}
.hcp-day{position:sticky;top:0;z-index:1;background:#e7f0f2;color:var(--air-d);font-weight:800;font-size:12px;
  text-transform:uppercase;letter-spacing:.4px;padding:7px 18px;border-bottom:1px solid #d2e3e7;
  display:flex;justify-content:space-between;align-items:center}
.hcp-day .hcp-day-n{font-weight:700;color:var(--muted);font-size:11px;text-transform:none;letter-spacing:0}
.hrow{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid #eef4f5;flex-wrap:wrap}
.hrow:last-child{border-bottom:none}
.hrow.added{background:var(--ok-bg)}
.hrow.canceled{opacity:.5}
.hrow .h-main{flex:1;min-width:170px}
.hrow .h-cust{font-weight:700;font-size:14.5px}
.hrow .h-meta{font-size:12.5px;color:var(--muted);margin-top:2px}
.hrow .h-chips{display:flex;gap:5px;flex-wrap:wrap;margin-top:5px}
.modal-foot{padding:13px 18px;border-top:1px solid var(--line);display:flex;justify-content:space-between;
  align-items:center;gap:10px;flex-wrap:wrap}
.modal-empty{padding:30px 18px;text-align:center;color:var(--muted);font-size:14px}
.loading-spin{padding:34px;text-align:center;color:var(--muted);font-size:14px}
.hcp-info{background:#eef5f6;border:1px solid #d9e8eb;border-radius:8px;padding:8px 11px;font-size:12.5px;
  color:var(--air-d);margin-top:10px;display:flex;align-items:center;gap:6px}
.jchip.hcp{background:#e8f7ef;color:var(--ok)}

/* eod summary */
.eod-box{margin:6px 14px 12px}
.eod-box textarea{width:100%;min-height:88px}

/* tech history */
.thpanel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);margin-bottom:14px;
  box-shadow:var(--shadow);overflow:hidden}
.thpanel .th-head{padding:13px 14px;font-weight:750;display:flex;align-items:center;gap:9px;cursor:pointer}
.thpanel .th-head .s-ic{font-size:20px}
.thbody{padding:4px 14px 12px}
.thtech{border-top:1px solid #eef4f5;padding:10px 0}
.thtech .tt-name{font-weight:750;font-size:15px}
.thtech .tt-stats{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.thtech .ts{font-size:11.5px;font-weight:700;border-radius:999px;padding:3px 9px;background:#eef5f6;color:var(--muted)}
.thtech .ts.bad{background:var(--bad-bg);color:var(--bad)}
.thtech .ts.ok{background:var(--ok-bg);color:var(--ok)}
.empty-note{color:var(--muted);font-size:13px;padding:8px 2px}

/* toast */
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:10px 18px;border-radius:999px;font-size:13px;font-weight:650;z-index:50;box-shadow:0 6px 20px rgba(0,0,0,.25)}
.toast.ok{background:var(--ok)}
.toast.err{background:var(--bad)}

@media(min-width:560px){
  .photogrid{grid-template-columns:1fr 1fr}
  .app-name{font-size:14px}
}

/* ── Desktop (Angelo works from a desktop) ── */
@media(min-width:900px){
  .topbar{padding:12px 26px}
  .datebar{padding:12px 26px}
  .logo{font-size:19px}
  .app-name{font-size:15px}
  .photogrid{grid-template-columns:1fr 1fr 1fr}
  .calendar{padding:16px 26px}
  .cal-grid{gap:7px;max-width:720px;margin:0 auto}
  .cal-cell{font-size:15px}
  .cal-cell .pct{font-size:11px}
  .section-head{padding:15px 18px}
  .task{padding:13px 18px}
  .task-title{font-size:15.5px}
  .main{padding-bottom:90px}
}

/* hover affordances (desktop has a mouse) */
@media(hover:hover){
  .section-head:hover{background:#f7fbfc}
  .nav-arrow:hover,.chip-btn:hover{background:var(--air-l)}
  .cal-cell.clickable:hover{filter:brightness(.96);box-shadow:0 0 0 2px var(--air) inset}
  .linkbtn:hover{text-decoration:underline}
  .btn:hover{filter:brightness(.95)}
  .add-job:hover{background:var(--air-l)}
  .jc-head:hover{background:#f7fbfc}
  .photo-item:hover .pi-h{color:var(--clay-d)}
  .ghost-btn:hover{background:rgba(255,255,255,.15)}
  .mini-copy:hover{filter:brightness(.95)}
}
