/* ============================================================
   EduTrust.lk — Student Dashboard (Inter UI)
   ============================================================ */
.dash-body{background:var(--light);font-family:var(--font-body)}
.dash{display:grid;grid-template-columns:256px 1fr;min-height:100vh}

/* sidebar */
.side{background:var(--navy);color:#cbd5e1;display:flex;flex-direction:column;padding:20px 16px;position:sticky;top:0;height:100vh}
.side .brand{margin:4px 6px 22px}
.side .brand .brand-name{color:#fff;font-size:19px}
.side .brand-tag{color:#64748b}
.side .sgroup{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#64748b;margin:18px 10px 8px;font-weight:600}
.snav{display:flex;flex-direction:column;gap:3px}
.snav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;font-size:14.5px;color:#cbd5e1;font-weight:500}
.snav a svg{width:19px;height:19px;opacity:.85}
.snav a:hover{background:rgba(255,255,255,.06);color:#fff}
.snav a.active{background:var(--teal);color:#fff}
.snav a.active svg{opacity:1}
.side-foot{margin-top:auto;background:rgba(255,255,255,.05);border-radius:14px;padding:14px}
.side-foot b{color:#fff;font-size:14px;font-family:var(--font-display)}
.side-foot p{font-size:12px;color:#94a3b8;margin:4px 0 10px}

/* main */
.dmain{padding:24px 30px 60px;min-width:0}
.dtop{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:26px}
.dsearch{flex:1;max-width:420px;position:relative}
.dsearch input{width:100%;border:1px solid var(--line);background:#fff;border-radius:10px;padding:11px 14px 11px 40px;font-family:inherit;font-size:14px}
.dsearch svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--slate-400)}
.dtop-right{display:flex;align-items:center;gap:14px}
.icon-pill{width:42px;height:42px;border-radius:11px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--slate);position:relative}
.icon-pill svg{width:19px;height:19px}
.icon-pill .badge{position:absolute;top:-5px;right:-5px;background:var(--orange);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 4px}
.duser{display:flex;align-items:center;gap:10px}
.duser .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#34d399,#0ea5e9)}
.duser b{font-family:var(--font-display);font-size:14px;display:block}
.duser span{font-size:12px;color:var(--slate)}

.welcome{font-family:var(--font-display);font-size:26px;font-weight:700;margin-bottom:4px}
.welcome .wave{color:var(--orange)}
.welcome-sub{color:var(--slate);margin-bottom:24px}

.dstats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px}
.dstat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm)}
.dstat .row{display:flex;align-items:center;justify-content:space-between}
.dstat .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff}
.dstat .ic svg{width:21px;height:21px}
.dstat .n{font-family:var(--font-display);font-size:30px;font-weight:700;line-height:1}
.dstat .l{font-size:13px;color:var(--slate)}
.dstat .delta{font-size:12px;font-weight:600}
.delta.up{color:#16a34a}

.dgrid{display:grid;grid-template-columns:1.7fr 1fr;gap:22px}
.dcard{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm)}
.dcard-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.dcard-h h3{font-size:16px}
.dcard-h a{font-size:13px;color:var(--teal);font-weight:600}

.approw{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--light)}
.approw:last-child{border-bottom:none}
.approw .uni{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;flex:none}
.approw .info{flex:1;min-width:0}
.approw .info b{font-family:var(--font-display);font-size:14.5px;display:block}
.approw .info span{font-size:12.5px;color:var(--slate)}
.tag{font-size:12px;font-weight:600;padding:5px 11px;border-radius:999px;white-space:nowrap}
.tag.submitted{background:#dbeafe;color:#1d4ed8}
.tag.review{background:#fef3c7;color:#b45309}
.tag.offer{background:#dcfce7;color:#16a34a}
.tag.docs{background:#fee2e2;color:#dc2626}

.tasklist{padding:8px 0}
.task{display:flex;align-items:flex-start;gap:12px;padding:12px 20px}
.task .cb{flex:none;width:20px;height:20px;border-radius:6px;border:2px solid var(--line);margin-top:2px;display:grid;place-items:center}
.task.done .cb{background:var(--teal);border-color:var(--teal);color:#fff}
.task.done .cb svg{width:12px;height:12px}
.task.done b{text-decoration:line-through;color:var(--slate-400)}
.task b{font-family:var(--font-display);font-size:14px;display:block}
.task span{font-size:12px;color:var(--slate)}

.progress-card{padding:20px}
.pbar{height:9px;border-radius:99px;background:var(--light);overflow:hidden;margin:12px 0 6px}
.pbar i{display:block;height:100%;background:linear-gradient(90deg,var(--teal),#2dd4bf);border-radius:99px}

.timeline-d{padding:6px 20px 18px}
.tl-item{display:flex;gap:14px;padding:10px 0}
.tl-item .dotcol{display:flex;flex-direction:column;align-items:center}
.tl-item .d{width:12px;height:12px;border-radius:50%;background:var(--teal);margin-top:4px}
.tl-item .line{flex:1;width:2px;background:var(--line);margin-top:3px}
.tl-item:last-child .line{display:none}
.tl-item b{font-family:var(--font-display);font-size:13.5px;display:block}
.tl-item span{font-size:12px;color:var(--slate)}

@media (max-width:1024px){.dstats{grid-template-columns:1fr 1fr}.dgrid{grid-template-columns:1fr}}
@media (max-width:820px){.dash{grid-template-columns:1fr}.side{display:none}}
@media (max-width:520px){.dstats{grid-template-columns:1fr}.dtop .dsearch{display:none}}

/* compact mock used inside homepage laptop */
.mock{font-family:var(--font-body);background:var(--light);font-size:9px;color:var(--navy);display:grid;grid-template-columns:64px 1fr;height:100%}
.mock .ms{background:var(--navy);padding:10px 8px;color:#cbd5e1}
.mock .ms .mb{color:#fff;font-family:var(--font-display);font-weight:700;font-size:10px;margin-bottom:12px}
.mock .ms .mi{height:7px;border-radius:3px;background:rgba(255,255,255,.12);margin-bottom:8px}
.mock .ms .mi.on{background:var(--teal)}
.mock .mm{padding:11px}
.mock .mh{font-family:var(--font-display);font-weight:700;font-size:11px;margin-bottom:9px}
.mock .mr{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}
.mock .mt{background:#fff;border:1px solid var(--line);border-radius:6px;padding:7px 6px}
.mock .mt .tn{font-family:var(--font-display);font-weight:700;font-size:13px;line-height:1}
.mock .mt .tl{color:var(--slate);font-size:7px;margin-top:2px}
.mock .mlist{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px}
.mock .ml{display:flex;align-items:center;gap:7px;padding:6px 0;border-bottom:1px solid var(--light)}
.mock .ml:last-child{border-bottom:none}
.mock .ml .mu{width:18px;height:18px;border-radius:5px;flex:none}
.mock .ml .mtx{flex:1}
.mock .ml .mtx i{display:block;height:5px;border-radius:3px;background:#e2e8f0;margin-bottom:3px;font-style:normal}
.mock .pill{font-size:7px;padding:2px 6px;border-radius:99px;font-weight:700}

/* phone mock */
.pmock{font-family:var(--font-body);background:var(--light);height:100%;padding:9px;font-size:8px}
.pmock .ph{font-family:var(--font-display);font-weight:700;font-size:11px;color:#fff;background:var(--teal);margin:-9px -9px 8px;padding:12px 10px;border-radius:0 0 12px 12px}
.pmock .pc{background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px;margin-bottom:7px}
.pmock .pc .pn{font-family:var(--font-display);font-weight:700;font-size:14px}
.pmock .pl{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.pmock .pl .pu{width:16px;height:16px;border-radius:5px;flex:none}
.pmock .pl i{display:block;height:4px;border-radius:2px;background:#e2e8f0;font-style:normal}
