/* MyCA Connect — design system (from UI prototype v2)
   Mobile-first. Desktop enhancements at >=900px. No build step. */

:root{
  --ink:#16233B;
  --ink-soft:#3D4C68;
  --paper:#F6F7F9;
  --card:#FFFFFF;
  --line:#E4E8EF;
  --wa:#25D366;
  --wa-deep:#128C7E;
  --tick-blue:#34B7F1;
  --stamp:#D64541;
  --amber:#E8A33D;
  --muted:#7A879D;
  --radius:14px;
  --shadow:0 1px 2px rgba(22,35,59,.06),0 8px 24px rgba(22,35,59,.07);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;font-feature-settings:'tnum';font-size:15px;line-height:1.5}
.hindi{font-family:'Noto Sans Devanagari','Inter',sans-serif}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.lu{width:1em;height:1em;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-0.125em;flex-shrink:0}

/* ================= App shell ================= */
.shell{min-height:100vh;display:flex;flex-direction:column}
.topbar{background:var(--ink);color:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.brand{font-weight:800;font-size:17px;letter-spacing:-.02em}
.brand span{color:var(--wa)}
.topbar .who{font-size:12.5px;color:#B8C4DA;display:flex;align-items:center;gap:12px}
.topbar .logout-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#C9D2E3;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer}

.content{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:20px 16px 96px}

/* sidebar exists only on desktop */
.sidenav{display:none}

/* bottom nav — mobile only */
.bottomnav{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--line);display:flex;justify-content:space-around;padding:8px 0 max(8px, env(safe-area-inset-bottom));z-index:50}
.bottomnav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;font-weight:600;color:var(--muted);padding:4px 16px;border-radius:10px}
.bottomnav a.on{color:var(--ink)}
.bottomnav .lu{width:20px;height:20px;stroke-width:1.9}
.bottomnav .fab{background:var(--wa);color:#07301B;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:-20px;box-shadow:0 6px 16px rgba(37,211,102,.4)}
.bottomnav .fab .lu{width:22px;height:22px}

@media(min-width:900px){
  .shell{flex-direction:row}
  .topbar{display:none}
  .bottomnav{display:none}
  .sidenav{display:flex;flex-direction:column;width:216px;background:var(--ink);color:#fff;padding:22px 14px;flex-shrink:0;position:sticky;top:0;height:100vh}
  .sidenav .brand{padding:0 10px 22px}
  .nav-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:10px;font-size:13.5px;font-weight:500;color:#B8C4DA;margin-bottom:3px;transition:.15s}
  .nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
  .nav-item.on{background:rgba(37,211,102,.16);color:#fff;font-weight:600}
  .nav-item .lu{width:17px;height:17px;stroke-width:1.9}
  .sidenav .foot{margin-top:auto;font-size:12px;color:#8FA0BF;padding:0 10px}
  .sidenav .foot form{margin-top:8px}
  .sidenav .logout-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#C9D2E3;padding:7px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;width:100%}
  .content{padding:30px 32px 60px}
}

/* ================= Common bits ================= */
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.page-head h1{font-size:21px;font-weight:800;letter-spacing:-.02em}
.page-head .sub{font-size:13px;color:var(--muted);margin-top:3px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:11px;padding:12px 18px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s;text-align:center}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:#22345A}
.btn-wa{background:var(--wa);color:#07301B;font-weight:700}
.btn-wa:hover{background:#1FC15A}
.btn-ghost{background:var(--card);border:1px solid var(--line);color:var(--ink-soft)}
.btn-danger-ghost{background:none;border:1px solid #F3CFCC;color:var(--stamp)}
.btn-sm{padding:8px 13px;font-size:12.5px;border-radius:9px}
.btn-block{width:100%}
.btn .lu{width:16px;height:16px}
.wa-glyph{width:16px;height:16px;flex-shrink:0}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:16px}

.flash{background:#E7F7EE;border:1px solid #BBEAD0;color:#0E7A4A;border-radius:11px;padding:11px 14px;font-size:13.5px;font-weight:600;margin-bottom:16px}
.flash-err{background:#FDECEA;border-color:#F3CFCC;color:var(--stamp)}

.field{margin-bottom:16px}
.field label{display:block;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.input{width:100%;border:1px solid var(--line);border-radius:11px;padding:12px 14px;font-size:15px;font-family:inherit;background:var(--card);color:var(--ink)}
.input:focus{outline:2px solid var(--ink);outline-offset:-1px}
select.input{appearance:none}
.err{color:var(--stamp);font-size:12.5px;margin-top:5px;font-weight:500}

/* ================= Status & progress ================= */
.status-tag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:99px;white-space:nowrap}
.st-wait{background:#FFF6E8;color:#A66B0C}
.st-part{background:#EAF3FD;color:#1D6FB8}
.st-done{background:#E7F7EE;color:#0E7A4A}
.st-over{background:#FDECEA;color:var(--stamp)}

.pbar{height:8px;background:#EAEEF4;border-radius:99px;overflow:hidden}
.pfill{height:100%;background:linear-gradient(90deg,var(--wa-deep),var(--wa));border-radius:99px;transition:width .5s cubic-bezier(.2,.8,.2,1)}
.mini-bar{width:74px;height:6px;background:#EAEEF4;border-radius:99px;overflow:hidden}
.mini-fill{height:100%;background:var(--wa-deep);border-radius:99px}
.mini-fill.full{background:var(--wa)}

.ticks{display:inline-flex;align-items:flex-end;letter-spacing:-6px;font-weight:700;line-height:1}
.ticks .t{font-size:15px}
.t-grey{color:#A9B4C7}
.t-blue{color:var(--tick-blue)}

/* ================= Stats ================= */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:13px 14px}
.stat .num{font-size:23px;font-weight:800;letter-spacing:-.03em}
.stat .lbl{font-size:11.5px;color:var(--muted);font-weight:500;margin-top:1px}
.stat.hot{background:#FDF3F2;border-color:#F3CFCC}
.stat.hot .num{color:var(--stamp)}
.stat.ok .num{color:var(--wa-deep)}
@media(min-width:900px){.stat{padding:16px}.stat .num{font-size:26px}}

/* ================= Filter chips ================= */
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.chip{font-size:12px;font-weight:600;padding:6px 13px;border-radius:99px;border:1px solid var(--line);background:var(--card);color:var(--ink-soft)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ================= Request cards (dashboard) ================= */
.req-card{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:10px;box-shadow:var(--shadow);transition:.15s}
.req-card:hover{border-color:#C6CEDD}
.req-top{display:flex;align-items:center;gap:11px}
.avatar{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,#2C4A7C,#16233B);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.avatar.round{border-radius:50%}
.req-top .cn{font-weight:700;font-size:15px}
.req-top .cp{font-size:12px;color:var(--muted);margin-top:1px}
.req-top .right{margin-left:auto;text-align:right}
.req-foot{display:flex;align-items:center;gap:10px;margin-top:11px;flex-wrap:wrap}
.req-foot .prog{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--ink-soft)}
.req-foot .spacer{flex:1}
@media(min-width:900px){
  .req-card{display:flex;align-items:center;gap:16px;padding:14px 18px}
  .req-top{flex:1}
  .req-foot{margin-top:0}
}

.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty .big{font-size:16px;font-weight:700;color:var(--ink-soft);margin-bottom:6px}

/* ================= Client list ================= */
.client-row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:13px 14px;margin-bottom:9px;box-shadow:var(--shadow)}
.client-row .info{flex:1;min-width:0}
.client-row .cn{font-weight:700;font-size:14.5px}
.client-row .cp{font-size:12px;color:var(--muted)}
.add-form{display:grid;grid-template-columns:1fr;gap:10px}
@media(min-width:700px){.add-form{grid-template-columns:1.2fr 1fr auto}}

/* ================= Create request ================= */
.tmpl-chips{display:flex;flex-wrap:wrap;gap:8px}
.tmpl{border:1.5px solid var(--line);background:var(--card);border-radius:99px;padding:9px 16px;font-size:13px;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:.15s}
.tmpl:hover{border-color:var(--ink-soft)}
.tmpl.on{border-color:var(--ink);background:var(--ink);color:#fff}
.check-list{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card)}
.check-item{display:flex;align-items:center;gap:9px;padding:10px 12px;border-bottom:1px solid var(--line)}
.check-item input[type=text]{border:none;font-size:13.5px;font-family:inherit;flex:1;min-width:0;background:none;color:var(--ink)}
.check-item input[type=text]:focus{outline:none}
.check-item input.hint-input{color:var(--muted);font-size:12.5px;flex:0.8}
.check-item .rm{color:var(--muted);cursor:pointer;background:none;border:none;display:flex;padding:4px}
.check-item .rm .lu{width:14px;height:14px}
.add-doc{padding:11px 14px;font-size:13px;font-weight:600;color:var(--wa-deep);cursor:pointer;background:#F7FCF9;display:flex;align-items:center;gap:7px;border:none;width:100%}
.add-doc .lu{width:14px;height:14px}

/* ================= Request detail / WhatsApp preview ================= */
.wa-preview{background:#EFEAE2;border-radius:var(--radius);padding:18px}
.wa-bubble{background:#DCF8C6;border-radius:12px;border-top-left-radius:3px;padding:13px 15px;font-size:13.5px;line-height:1.65;box-shadow:0 1px 1px rgba(0,0,0,.08);max-width:360px;white-space:pre-wrap;word-break:break-word}
.copybar{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.linkbox{flex:1;min-width:200px;border:1px dashed var(--line);background:var(--card);border-radius:10px;padding:10px 12px;font-size:12.5px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.item-block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:13px 14px;margin-bottom:9px}
.item-block .head{display:flex;align-items:center;gap:10px}
.item-block .head .nm{font-weight:600;font-size:14px;flex:1}
.filechip{display:flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:12.5px;margin-top:8px}
.filechip .lu{width:14px;height:14px;color:var(--muted)}
.filechip .fname{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;min-width:0}
.filechip .fsize{color:var(--muted);font-size:11px;white-space:nowrap}
.filechip a{color:var(--wa-deep);font-weight:600;font-size:12px;white-space:nowrap}
.filechip .del{color:var(--stamp);background:none;border:none;cursor:pointer;font-size:12px;font-weight:600}

/* ================= Public upload page (client) ================= */
.up-wrap{max-width:480px;margin:0 auto;padding-bottom:120px}
@media(min-width:900px){.up-wrap{max-width:520px;padding-top:24px}}
.ca-header{background:var(--card);padding:18px 18px 16px;border-bottom:1px solid var(--line)}
@media(min-width:900px){.ca-header{border:1px solid var(--line);border-radius:var(--radius) var(--radius) 0 0}}
.ca-id{display:flex;gap:12px;align-items:center}
.ca-id .name{font-weight:700;font-size:16px}
.ca-id .cred{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px;margin-top:2px;flex-wrap:wrap}
.badge-verified{display:inline-flex;align-items:center;gap:3px;background:#E7F7EE;color:#0E7A4A;font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:99px}
.req-title{margin-top:14px}
.req-title .eyebrow{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.req-title h1{font-size:20px;font-weight:800;letter-spacing:-.02em;margin-top:3px}
.req-title .hindi-sub{font-size:13px;color:var(--ink-soft);margin-top:3px}

.progress-wrap{background:var(--card);margin:14px 14px 0;border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}
.progress-top{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;font-weight:600}
.progress-top .frac{font-size:15px;font-weight:800}
.progress-wrap .pbar{margin-top:9px}
.due{font-size:12px;color:var(--muted);margin-top:8px;display:flex;align-items:center;gap:6px}

.doclist{margin:16px 14px 0}
.doclist .list-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.doc{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:10px;box-shadow:var(--shadow)}
.doc-row{display:flex;align-items:center;gap:12px}
.doc-icon{width:40px;height:40px;border-radius:10px;background:#EEF2F8;color:var(--ink-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.doc-icon .lu{width:20px;height:20px;stroke-width:1.8}
.doc-info{flex:1;min-width:0}
.doc-info .dname{font-weight:600;font-size:14.5px}
.doc-info .dhint{font-size:12px;color:var(--muted);margin-top:1px}
.doc-status{font-size:11px;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:4px;flex-shrink:0}
.btn-upload{margin-top:12px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--ink);color:#fff;border:none;border-radius:11px;padding:13px;font-size:14.5px;font-weight:600;cursor:pointer;transition:.15s}
.btn-upload:active{transform:scale(.98)}
.btn-upload:disabled{opacity:.6}
.btn-upload .lu{width:17px;height:17px}
.doc.done{border-color:#BBEAD0;background:#F4FBF7}
.doc.done .doc-icon{background:#DDF5E8;color:#0E7A4A}
.add-more{margin-top:8px;background:none;border:none;color:var(--wa-deep);font-size:12.5px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:5px}

.trust{margin:18px 16px 0;text-align:center;font-size:11.5px;color:var(--muted);line-height:1.6}
.trust .lu{width:13px;height:13px;vertical-align:-2px}

.done-banner{margin:16px 14px 0;background:#E7F7EE;border:1px solid #BBEAD0;border-radius:var(--radius);padding:16px;text-align:center;color:#0E7A4A;font-weight:700;font-size:14.5px}

/* too-big modal */
.modal-mask{position:fixed;inset:0;background:rgba(22,35,59,.55);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-mask.show{display:flex}
.modal{background:var(--card);border-radius:16px;padding:22px 20px;max-width:360px;width:100%;text-align:center}
.modal h3{font-size:16px;font-weight:800;margin-bottom:8px}
.modal p{font-size:13.5px;color:var(--ink-soft);margin-bottom:16px;line-height:1.6}
.modal .btn{width:100%;margin-bottom:8px}

/* auth pages */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:28px 24px;width:100%;max-width:400px}
.auth-card .brand{color:var(--ink);font-size:20px;text-align:center;display:block;margin-bottom:4px}
.auth-card .tag{text-align:center;font-size:13px;color:var(--muted);margin-bottom:22px}
.auth-alt{text-align:center;font-size:13px;color:var(--muted);margin-top:16px}
.auth-alt a{color:var(--wa-deep);font-weight:600}
