:root{
  --navy:#1f3864; --blue:#2e5496; --accent:#2e7df6; --bg:#f4f6fb; --card:#fff;
  --ink:#1c2433; --muted:#6b7690; --line:#e4e8f0;
  --new:#8893a8; --claimed:#2e7df6; --quoted:#e3a008; --booked:#1f9d55; --lost:#d64545;
  --shadow:0 1px 3px rgba(20,30,60,.08),0 1px 2px rgba(20,30,60,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink)}
.hidden{display:none !important}
button{font-family:inherit;cursor:pointer;border:none;border-radius:8px;font-size:14px}
input,select,textarea{font-family:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;width:100%;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}

/* brand */
.brand{font-weight:800;letter-spacing:.5px;color:var(--navy);font-size:26px}
.brand span{color:var(--accent);font-weight:600;margin-left:6px}
.brand.sm{font-size:18px}

/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eef2fb,#dde6f7)}
.login-card{background:#fff;padding:36px 32px;border-radius:16px;box-shadow:var(--shadow);width:340px;display:flex;flex-direction:column;gap:12px}
.login-sub{margin:0 0 6px;color:var(--muted);font-size:14px}
.login-card button{background:var(--accent);color:#fff;padding:12px;font-weight:600}
.err{color:var(--lost);font-size:13px;min-height:16px}

/* topbar */
.topbar{display:flex;align-items:center;gap:18px;background:#fff;padding:10px 18px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;flex-wrap:wrap}
.tabs{display:flex;gap:4px}
.tab{background:transparent;color:var(--muted);padding:8px 14px;font-weight:600;border-radius:8px}
.tab.active{background:#eef2fb;color:var(--navy)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.mine-toggle{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px;white-space:nowrap}
.mine-toggle input{width:auto}
button.primary{background:var(--accent);color:#fff;padding:9px 14px;font-weight:600}
button.ghost{background:transparent;color:var(--muted);padding:8px 10px}
.who{font-size:13px;color:var(--navy);font-weight:600}

main{padding:18px}

/* board */
.board{display:flex;gap:14px;align-items:flex-start;overflow-x:auto;padding-bottom:20px}
.col{background:#eef1f7;border-radius:12px;min-width:270px;width:270px;flex:0 0 auto;display:flex;flex-direction:column;max-height:calc(100vh - 130px)}
.col-head{padding:12px 14px;font-weight:700;font-size:13px;letter-spacing:.4px;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center;border-top:3px solid var(--new);border-radius:12px 12px 0 0;background:#fff}
.col[data-stage=new] .col-head{border-color:var(--new)}
.col[data-stage=claimed] .col-head{border-color:var(--claimed)}
.col[data-stage=quoted] .col-head{border-color:var(--quoted)}
.col[data-stage=booked] .col-head{border-color:var(--booked)}
.col[data-stage=lost] .col-head{border-color:var(--lost)}
.col-count{background:#eef1f7;color:var(--muted);border-radius:20px;padding:1px 9px;font-size:12px}
.col-body{padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:9px;min-height:60px}
.col-body.drag-over{background:#e1e8f7;outline:2px dashed var(--accent);outline-offset:-4px;border-radius:8px}

/* card */
.card{background:var(--card);border-radius:10px;box-shadow:var(--shadow);padding:11px 12px;cursor:grab;border-left:3px solid transparent}
.card:active{cursor:grabbing}
.card.mine{border-left-color:var(--accent)}
.card-top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.card-name{font-weight:700;font-size:14px}
.src{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#fff;background:var(--blue);border-radius:5px;padding:2px 6px;white-space:nowrap}
.card-phone{margin-top:4px;font-size:12px;font-weight:600;color:var(--blue)}
.card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:7px}
.tag{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:2px 7px;border-radius:5px;color:#fff;background:var(--blue)}
.tag.t-flight{background:#2e7df6}
.tag.t-vacation{background:#1f9d55}
.tag.t-cruise{background:#0ea5e9}
.tag.t-group{background:#7c3aed}
.tag.t-umrah{background:#0f766e}
.tag.t-ziyaraat{background:#b45309}
.tag.t-wedding{background:#db2777}
.tag-pick{display:flex;flex-wrap:wrap;gap:6px}
.tag-chip{background:#eef1f7;color:var(--muted);border:1px solid var(--line);padding:5px 11px;border-radius:16px;font-size:12px;font-weight:600}
.tag-chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.tag-chip:disabled{cursor:default;opacity:.7}
.card-meta{margin-top:6px;font-size:12px;color:var(--muted);line-height:1.5}
.search{width:220px;padding:8px 12px;font-size:13px}
@media(max-width:600px){.search{width:100%}}
.card-meta b{color:var(--ink);font-weight:600}
.card-foot{margin-top:9px;display:flex;justify-content:space-between;align-items:center;gap:6px}
.assignee{font-size:11px;color:var(--muted)}
.assignee.you{color:var(--accent);font-weight:700}
.claim-btn{background:var(--accent);color:#fff;padding:5px 12px;font-size:12px;font-weight:700}
.budget{font-weight:700;color:var(--booked);font-size:13px}

/* metrics */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}
.kpi{background:#fff;border-radius:12px;padding:16px;box-shadow:var(--shadow)}
.kpi .v{font-size:26px;font-weight:800;color:var(--navy)}
.kpi .l{font-size:12px;color:var(--muted);margin-top:4px}
.panel{background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:18px;margin-bottom:18px}
.panel h3{margin:0 0 12px;font-size:15px;color:var(--navy)}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.3px}
td.num,th.num{text-align:right}
.bar{height:6px;background:#eef1f7;border-radius:4px;overflow:hidden;margin-top:4px}
.bar>span{display:block;height:100%;background:var(--accent)}

/* admin */
.agent-row{display:flex;align-items:center;gap:10px;padding:10px;border-bottom:1px solid var(--line)}
.agent-row .nm{font-weight:600}
.pill{font-size:11px;padding:2px 8px;border-radius:20px;background:#eef1f7;color:var(--muted)}
.pill.admin{background:#e7f0ff;color:var(--accent)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-grid .full{grid-column:1/-1}

/* modal */
.modal-back{position:fixed;inset:0;background:rgba(20,28,48,.45);display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}
.modal{background:#fff;border-radius:14px;width:480px;max-width:100%;max-height:92vh;overflow-y:auto;padding:22px}
.modal h2{margin:0 0 4px;font-size:18px;color:var(--navy)}
.modal .sub{color:var(--muted);font-size:13px;margin:0 0 16px}
.row{display:flex;gap:10px;margin-top:10px}
.row>*{flex:1}
.modal label{font-size:12px;color:var(--muted);display:block;margin:12px 0 4px}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}
.drop{border:2px dashed var(--line);border-radius:10px;padding:20px;text-align:center;color:var(--muted);cursor:pointer}
.drop.has{border-color:var(--booked);color:var(--booked)}
.file-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.file-item{display:flex;align-items:center;gap:10px;background:#f7f9fd;border:1px solid var(--line);border-radius:8px;padding:6px 8px}
.file-thumb{width:38px;height:38px;object-fit:cover;border-radius:6px;cursor:zoom-in;border:1px solid var(--line)}
.file-name{flex:1;font-size:13px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-del{background:transparent;color:var(--muted);font-size:20px;line-height:1;padding:0 8px}
.file-del:hover{color:var(--lost)}
.img-prev{position:fixed;inset:0;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;z-index:100;cursor:zoom-out}
.img-prev img{max-width:92%;max-height:92%;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.5)}
.warn{background:#fff7e6;border:1px solid #ffe1a8;color:#9a6700;padding:8px 10px;border-radius:8px;font-size:13px;margin-top:10px}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid #cfd8ea;border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
.shot{max-width:100%;border-radius:8px;margin-top:10px;border:1px solid var(--line)}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:11px 18px;border-radius:10px;font-size:14px;z-index:80;box-shadow:var(--shadow)}

@media(max-width:600px){
  .topbar-right{width:100%}
  .modal{width:100%}
  .form-grid{grid-template-columns:1fr}
}
