/* GLV Onboarding Portal */
:root{
  --navy:#13405e; --green:#1f8a5b; --red:#d6453f; --amber:#c98a00;
  --ink:#1f2733; --muted:#6b7685; --line:#e4e8ee; --bg:#f4f6f9; --card:#fff;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.45}
a{color:var(--navy)}
.topbar{background:var(--navy);color:#fff;padding:0 20px;display:flex;align-items:center;gap:18px;height:56px}
.topbar .brand{font-weight:700;font-size:16px;margin-right:auto;color:#fff;text-decoration:none}
.topbar a.navlink{color:#cfe0ee;text-decoration:none;font-size:14px}
.topbar a.navlink:hover{color:#fff}
.topbar .who{color:#9fc0d8;font-size:13px}
.wrap{max-width:none;margin:26px auto;padding:0 28px}
.wrap.narrow{max-width:560px}
.wrap.wide{max-width:none}
h1{font-size:24px;color:var(--navy);margin:0 0 6px}
h2{font-size:17px;color:var(--navy);margin:26px 0 10px}
.sub{color:var(--muted);margin:0 0 18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px;
  box-shadow:0 1px 3px rgba(20,30,50,.06)}
.flash{background:#e7f6ee;border:1px solid #b6e3cb;color:#155f3e;padding:11px 14px;border-radius:9px;margin-bottom:16px}
.btn{display:inline-block;background:var(--green);color:#fff;border:0;border-radius:8px;padding:10px 16px;
  font-size:14px;font-weight:600;cursor:pointer;text-decoration:none}
.btn:hover{filter:brightness(1.05)}
.btn.secondary{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.navy{background:var(--navy)}
.btn.small{padding:6px 12px;font-size:13px}
.btn.danger{background:var(--red)}
.btn.amber{background:var(--amber)}
label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin:12px 0 5px}
input[type=text],input[type=email],input[type=tel],input[type=password],textarea,select{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit;color:var(--ink);background:#fff}
textarea{min-height:70px;resize:vertical}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row > div{flex:1;min-width:200px}
.muted{color:var(--muted)}
.small{font-size:13px}

/* dashboard */
.stats{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 18px;min-width:120px}
.stat .n{font-size:26px;font-weight:700;color:var(--navy)}
.stat .l{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
table.grid{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
table.grid th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);
  padding:11px 14px;border-bottom:1px solid var(--line);background:#fbfcfe}
table.grid td{padding:12px 14px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
table.grid tr:last-child td{border-bottom:0}
table.grid tr:hover td{background:#fbfcff}
.pbar{height:8px;background:#eef1f5;border-radius:99px;overflow:hidden;min-width:90px}
.pbar > span{display:block;height:100%;background:var(--green)}
.badge{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;
  padding:3px 9px;border-radius:99px}
.badge.active{background:#e3f3ec;color:#155f3e}
.badge.complete{background:#e3ecf6;color:#1a4a78}
.badge.hold,.badge.on_hold{background:#fbeecf;color:#8a5e00}
.badge.pending{background:#eef1f5;color:#6b7685}
.badge.archived{background:#eee;color:#777}

/* property board */
.phead{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:8px}
.ownerbox{background:#fbfcfe;border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin:14px 0;font-size:14px}
.ownerbox b{color:var(--navy)}
.step{background:var(--card);border:1px solid var(--line);border-left:5px solid #ccc;border-radius:10px;
  padding:13px 15px;margin-bottom:10px}
.step.s-active{border-left-color:var(--green);box-shadow:0 2px 10px rgba(31,138,91,.12)}
.step.s-complete{border-left-color:#1a4a78;opacity:.78}
.step.s-on_hold{border-left-color:var(--amber);background:#fffdf6}
.step.s-pending{border-left-color:#cdd4de}
.step .top{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}
.step .num{background:#ccc;color:#fff;font-weight:700;font-size:12px;border-radius:6px;
  min-width:26px;height:22px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px}
.step.s-active .num{background:var(--green)}
.step.s-complete .num{background:#1a4a78}
.step.s-on_hold .num{background:var(--amber)}
.step .owner{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--muted)}
.step .phase{font-size:11px;color:var(--muted);background:#eef1f5;border-radius:99px;padding:2px 9px;margin-left:auto}
.step .title{font-size:14.5px;margin:0 0 6px;font-weight:500}
.step .meta{font-size:12.5px;color:var(--muted)}
.step .note{font-size:12px;color:#9a6a00;background:#fff6e0;border:1px solid #ffe6a8;border-radius:6px;
  padding:4px 8px;display:inline-block;margin-top:6px}
.step .holdreason{font-size:13px;color:#8a5e00;background:#fbeecf;border-radius:6px;padding:6px 10px;margin-top:8px}
.actions{margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}
.checkline{display:flex;align-items:center;gap:8px;margin:8px 0;font-size:14px}
.checkline input{width:auto}
details.hold{margin-top:8px}
details.hold summary{cursor:pointer;color:var(--amber);font-size:13px;font-weight:600}
.actrow{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:8px}
.scrolltarget{scroll-margin-top:70px}
.highlight{outline:3px solid #b6e3cb;outline-offset:2px}
.footnote{color:var(--muted);font-size:12px;margin-top:30px;text-align:center}
.tag-osm{font-size:10px;font-weight:700;color:#7a4fd0;border:1px solid #d9cdf2;border-radius:99px;padding:1px 7px}

/* owner legend */
.legend{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.legend .chip{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:#fff;border-radius:999px;
  padding:5px 11px 5px 8px;font-size:13px;cursor:pointer;user-select:none}
.legend .chip.dim{opacity:.34}
.legend .dot{width:11px;height:11px;border-radius:50%}
.legend .ct{color:var(--muted)}

/* view tabs */
.viewtabs{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 6px}
.viewtabs button{font:inherit;font-size:13px;font-weight:600;color:var(--ink);background:#fff;border:1px solid var(--line);
  border-radius:8px;padding:8px 14px;cursor:pointer}
.viewtabs button.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.viewhint{font-size:12px;color:var(--muted);margin:2px 0 12px}

/* action panel */
.actionpanel{margin:6px 0 22px}
.actionpanel .step{border-left-width:6px}

/* sequential square grid */
.board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px}
.sqcard{position:relative;aspect-ratio:1/1;background:#fff;border:1px solid var(--line);border-top:5px solid #ccc;
  border-radius:12px;padding:12px;display:flex;flex-direction:column;cursor:pointer;overflow:hidden;
  box-shadow:0 1px 3px rgba(20,30,50,.06)}
.sqcard:hover{box-shadow:0 4px 14px rgba(20,30,50,.12)}
.sqcard.dim{opacity:.28}
.sqcard .num{align-self:flex-start;color:#fff;font-weight:700;font-size:12px;border-radius:6px;min-width:24px;height:21px;
  padding:0 7px;display:inline-flex;align-items:center;justify-content:center;background:#ccc}
.sqcard .t{font-size:13px;line-height:1.3;margin:8px 0 auto;font-weight:500;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.sqcard .o{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);margin-top:6px}
.sqcard .st{position:absolute;top:10px;right:10px;font-size:10px;font-weight:700;text-transform:uppercase;padding:2px 7px;border-radius:99px}
.st.active{background:#e3f3ec;color:#155f3e}.st.complete{background:#e3ecf6;color:#1a4a78}
.st.on_hold{background:#fbeecf;color:#8a5e00}.st.pending{background:#eef1f5;color:#6b7685}
.sqcard.actionable{outline:2px solid #1f8a5b;outline-offset:-2px}

/* kanban */
.kan-cols{display:flex;gap:12px;overflow-x:auto;padding-bottom:10px;align-items:flex-start}
.kan-col{flex:0 0 240px;background:#eef1f5;border:1px solid var(--line);border-radius:12px}
.kan-col h4{margin:0;padding:10px 13px;font-size:13px;border-bottom:1px solid var(--line)}
.kan-col h4 span{color:var(--muted);font-weight:500}
.kan-body{display:flex;flex-direction:column;gap:9px;padding:11px}
.kan-card{background:#fff;border:1px solid var(--line);border-left:5px solid #ccc;border-radius:9px;padding:10px 11px;cursor:pointer}
.kan-card .num{font-weight:700;font-size:11px;color:#fff;background:#ccc;border-radius:5px;padding:1px 6px;margin-right:6px}
.kan-card .t{font-size:12.5px;margin:6px 0 0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.kan-card .o{font-size:10.5px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);margin-top:5px}

/* gantt */
.gantt{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px}
.gantt-row{display:flex;align-items:center;height:30px;gap:10px}
.gantt-lab{flex:0 0 230px;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gantt-lab .num{font-weight:700;color:var(--muted);margin-right:6px}
.gantt-track{position:relative;flex:1;height:100%;min-width:480px}
.gantt-bar{position:absolute;top:6px;height:18px;border-radius:5px;opacity:.92}
.gantt-bar.proj{opacity:.4;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.5)0,rgba(255,255,255,.5)4px,transparent 4px,transparent 8px)}
.gantt-today{position:absolute;top:0;bottom:0;width:2px;background:#d6453f;z-index:3}
.gantt-axis{display:flex;font-size:11px;color:var(--muted);margin:4px 0 0 240px;justify-content:space-between}

/* pert */
.pert{display:flex;flex-wrap:wrap;gap:6px 0;align-items:center;border:1px solid var(--line);border-radius:12px;background:#fff;padding:16px}
.pert-node{border:2px solid #ccc;border-radius:9px;background:#fff;padding:7px 10px;min-width:74px;text-align:center}
.pert-node .num{font-weight:700;font-size:13px}
.pert-node .o{font-size:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--muted);margin-top:2px;
  max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pert-arrow{color:var(--muted);margin:0 6px;font-size:15px}
.pert-legendnote{font-size:12px;color:var(--muted);margin-top:10px}
