/* app.css — win-back app chrome on top of willow.css tokens */
.container { max-width: 1280px; margin: 0 auto; padding: 0 24px 64px; }

/* ---- top nav ---- */
#nav { position: sticky; top: 0; z-index: 20; background: var(--surface);
       border-bottom: 1px solid var(--border-default); }
.navwrap { max-width: 1280px; margin: 0 auto; padding: 10px 24px; display: flex; align-items: center; gap: 18px; }
.brand { display: flex; align-items: center; gap: 8px; font: 700 15px/1 var(--font-display); color: var(--text-default); text-decoration: none; }
.brand:hover { text-decoration: none; }
.navlinks { display: flex; gap: 4px; }
.navlink { padding: 7px 12px; border-radius: var(--radius-pill); font: 600 13px/1 var(--font-body);
           color: var(--text-01); text-decoration: none; }
.navlink:hover { background: var(--bg-01); color: var(--text-default); text-decoration: none; }
.navlink.on { background: var(--primary-10); color: var(--primary-100); }
.navuser { margin-left: auto; display: flex; align-items: center; gap: 12px; }
.navwho { font: 600 13px/1 var(--font-body); color: var(--text-01); }
.navlogout { background: transparent; border: 1px solid var(--border-default); color: var(--text-01);
             border-radius: var(--radius-pill); padding: 6px 12px; font: 600 12px/1 var(--font-body); cursor: pointer; }
.navlogout:hover { background: var(--bg-01); color: var(--text-default); }

/* ---- page header ---- */
.pagehead { display: flex; align-items: flex-end; gap: 16px; margin: 28px 0 8px; flex-wrap: wrap; }
.pagehead h1 { font: 700 28px/1.05 var(--font-display); letter-spacing: -0.5px; }
.pagehead .sub { color: var(--text-01); font-size: 14px; }
.grid-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin: 18px 0; }

/* ---- toolbar ---- */
.toolbar { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin: 14px 0; position: sticky; top: 53px; z-index: 10;
           background: var(--bg-default); padding: 8px 0; }
.toolbar .lbl { font: 600 11px/1 var(--font-body); letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-02); }
#search { height: 36px; padding: 0 14px; border: 1px solid var(--border-default); border-radius: var(--radius-pill);
          background: var(--surface); color: var(--text-default); font: 400 13px var(--font-body); min-width: 240px; }
.chip.is-active { background: var(--primary-100); border-color: var(--primary-100); color: #fff; }

/* ---- accordion row ---- */
.acc { background: var(--surface); border: 1px solid var(--border-default); border-radius: var(--radius-lg);
       margin-bottom: 8px; overflow: hidden; transition: box-shadow var(--dur-fast) var(--ease); }
.acc.open { box-shadow: var(--shadow-s); }
.acc.is-done { opacity: 0.62; }
.acc-sum { display: grid; grid-template-columns: 46px 1fr auto; gap: 12px; align-items: center;
           padding: 12px 14px; cursor: pointer; }
.acc-sum:hover { background: var(--surface-hover); }
.score { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 30px;
         border-radius: var(--radius-pill); font: 700 14px/1 var(--font-body); }
.score.s-hi { background: var(--primary-100); color: #fff; }
.score.s-mid { background: var(--highlight-subtle); color: var(--highlight-default); }
.score.s-lo { background: var(--bg-01); color: var(--text-01); }
.sum-main { min-width: 0; }
.sum-co { font: 600 15px/1.2 var(--font-body); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sum-meta { color: var(--text-01); font-size: 12.5px; margin-top: 3px; display: flex; gap: 10px; flex-wrap: wrap; }
.sum-right { display: flex; align-items: center; gap: 8px; white-space: nowrap; }
.fu-flag { font-size: 16px; }
.chev { width: 18px; height: 18px; color: var(--text-02); transition: transform var(--dur-fast) var(--ease); }
.acc.open .chev { transform: rotate(180deg); }

.acc-body { display: none; padding: 4px 16px 18px; border-top: 1px solid var(--border-default); }
.acc.open .acc-body { display: block; }
.detail-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 20px; margin-top: 14px; }
@media (max-width: 760px) { .detail-grid { grid-template-columns: 1fr; } }
.quote { font-style: italic; color: var(--text-default); background: var(--grey-01);
         border-radius: var(--radius-md); padding: 10px 12px; font-size: 13.5px; }
.src { color: var(--text-02); font-size: 11px; margin-top: 4px; }
.kv { display: flex; gap: 8px; font-size: 13px; margin: 5px 0; }
.kv .k { color: var(--text-02); min-width: 92px; }
.links { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.ext { display: inline-flex; align-items: center; gap: 6px; padding: 7px 12px; border-radius: var(--radius-pill);
       border: 1px solid var(--border-default); font: 600 12px/1 var(--font-body); color: var(--text-default); text-decoration: none; }
.ext:hover { background: var(--bg-01); text-decoration: none; }
.ext.hs { color: #ff5c35; } .ext.cb { color: var(--primary-100); }

/* ---- follow-up panel ---- */
.fu-panel { background: var(--grey-01); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: 14px; }
.fu-panel h4 { font: 700 12px/1 var(--font-body); letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-01); margin: 0 0 12px; }
.fu-row { display: flex; align-items: center; gap: 10px; margin: 9px 0; }
.fu-row label.t { min-width: 96px; font-size: 12.5px; color: var(--text-02); }
.fu-check { display: flex; align-items: center; gap: 8px; font: 600 13px/1 var(--font-body); cursor: pointer; }
.fu-check input { width: 17px; height: 17px; accent-color: var(--primary-100); }
.fu-panel select, .fu-panel input[type=date], .fu-panel textarea {
  font: 400 13px var(--font-body); color: var(--text-default); background: var(--surface);
  border: 1px solid var(--border-default); border-radius: var(--radius-md); padding: 7px 10px; width: 100%; }
.fu-panel textarea { resize: vertical; min-height: 52px; }
.fu-meta { font-size: 11px; color: var(--text-02); margin-top: 8px; min-height: 14px; }
.saved { color: var(--success-default); }

/* ---- follow-ups + owners pages ---- */
.owner-group { margin: 22px 0; }
.owner-group > h2 { font: 700 18px/1 var(--font-display); margin: 0 0 10px; display: flex; align-items: baseline; gap: 10px; }
.owner-group .count { font: 500 13px/1 var(--font-body); color: var(--text-01); }
.fucard { background: var(--surface); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: 14px; margin-bottom: 8px; }
.fucard .top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.fucard .co { font: 600 14px/1 var(--font-body); }
.fucard .note { color: var(--text-01); font-size: 13px; margin-top: 8px; }
.dl { font: 600 12px/1 var(--font-body); color: var(--text-01); }
.dl.overdue { color: var(--error-default); } .dl.soon { color: var(--highlight-default); }
.done-pill { font: 600 10px/1 var(--font-body); text-transform: uppercase; letter-spacing: 0.05em;
             background: rgba(0,152,65,0.12); color: var(--success-default); padding: 3px 7px; border-radius: var(--radius-pill); }
.owners-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; margin-top: 18px; }
.ocard { background: var(--surface); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: 18px; }
.ocard h3 { font: 700 17px/1 var(--font-display); margin: 0 0 12px; }
.ostat { display: flex; justify-content: space-between; align-items: baseline; padding: 6px 0; border-bottom: 1px solid var(--border-default); }
.ostat:last-child { border-bottom: 0; }
.ostat .v { font: 700 16px/1 var(--font-body); }
.ostat .v.warn { color: var(--error-default); }
.progress { height: 8px; border-radius: var(--radius-pill); background: var(--bg-01); overflow: hidden; margin: 12px 0 4px; }
.progress > span { display: block; height: 100%; background: var(--success-default); }
.empty { color: var(--text-01); padding: 40px; text-align: center; }
.jump { font-size: 12px; }

/* ---- overview charts ---- */
.charts { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 18px; }
@media (max-width: 820px) { .charts { grid-template-columns: 1fr; } }
.charts .card-elevated { padding: 18px 20px; }
.charts h3 { font: 700 16px/1 var(--font-display); margin: 0 0 14px; }
.chart-box { position: relative; height: 300px; }   /* fixed height: Chart.js canvas needs a sized parent */
.charts .wide { grid-column: 1 / -1; }
.charts .wide .chart-box { height: 200px; }
.insight { color: var(--text-01); font-size: 12.5px; margin-top: 12px; }
