/* Desverso Client Portal — layout (uses the site's design tokens from ../assets/css/style.css) */

.portal-loading{position:fixed;inset:0;display:grid;place-items:center;background:var(--bg);z-index:50}
.spinner{width:42px;height:42px;border-radius:50%;border:3px solid var(--line-2);border-top-color:var(--gold);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Auth (login/signup) ---------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;overflow:hidden}
.auth-wrap .blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.25}
.auth-wrap .b1{width:480px;height:480px;background:radial-gradient(circle,#FF8A1F,transparent 65%);top:-160px;right:-120px}
.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:38px;position:relative;z-index:1}
.auth-card .logo{justify-content:center;margin-bottom:8px}
.auth-card h1{font-size:1.5rem;text-align:center;margin-bottom:6px}
.auth-card .sub{text-align:center;color:var(--muted);font-size:.92rem;margin-bottom:26px}
.auth-tabs{display:flex;gap:6px;background:var(--bg-2);border:1px solid var(--line);border-radius:100px;padding:5px;margin-bottom:22px}
.auth-tabs button{flex:1;padding:10px;border:none;background:transparent;color:var(--muted);font-family:var(--font-head);font-weight:600;border-radius:100px;cursor:pointer;transition:.25s}
.auth-tabs button.active{background:var(--grad-gold);color:#1a1205}
.auth-err{background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.3);color:#ff9a8a;font-size:.88rem;padding:11px 14px;border-radius:10px;margin-bottom:16px}
.auth-ok{background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.3);color:#7fe7c0;font-size:.88rem;padding:11px 14px;border-radius:10px;margin-bottom:16px}

/* ---------- App shell ---------- */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--bg-2);border-right:1px solid var(--line);padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side .logo{padding:6px 8px 22px;margin-bottom:8px;border-bottom:1px solid var(--line)}
.side .logo .logo-mark{height:32px}
.side nav{display:flex;flex-direction:column;gap:3px;flex:1}
.side nav a{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:11px;color:var(--muted);font-family:var(--font-head);font-weight:500;font-size:.95rem;transition:.2s;cursor:pointer}
.side nav a svg{width:19px;height:19px}
.side nav a:hover{background:rgba(255,255,255,.04);color:#fff}
.side nav a.active{background:var(--grad-gold-soft);color:var(--gold);border:1px solid var(--line-2)}
.side .role-badge{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:700;padding:4px 10px;border:1px solid var(--line-2);border-radius:100px;display:inline-block;margin-top:4px}
.side .user{padding:14px 10px;border-top:1px solid var(--line);margin-top:8px}
.side .user b{display:block;font-family:var(--font-head);font-size:.9rem}
.side .user span{font-size:.78rem;color:var(--muted-2)}
.side .logout{margin-top:10px;width:100%;padding:9px;border-radius:10px;border:1px solid var(--line-2);background:transparent;color:var(--muted);font-family:var(--font-head);font-weight:600;cursor:pointer;font-size:.86rem}
.side .logout:hover{border-color:#ff6b6b;color:#ff6b6b}

.main{padding:34px 40px;max-width:1100px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.page-head h1{font-size:1.9rem}
.page-head p{color:var(--muted);margin-top:4px}

/* stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px;margin-bottom:30px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.stat .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--grad-gold-soft);border:1px solid var(--line-2);color:var(--gold);margin-bottom:14px}
.stat .ic svg{width:20px;height:20px}
.stat b{font-family:var(--font-head);font-size:2rem;display:block;line-height:1}
.stat span{color:var(--muted);font-size:.86rem}

/* generic card */
.pcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-bottom:20px}
.pcard h2,.pcard h3{font-family:var(--font-head)}
.pcard h3{font-size:1.15rem;margin-bottom:4px}
.pcard .meta{color:var(--muted-2);font-size:.84rem}

/* lists / tables */
.ptable{width:100%;border-collapse:collapse;font-size:.92rem}
.ptable th{text-align:left;font-family:var(--font-head);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-2);padding:11px 12px;border-bottom:1px solid var(--line)}
.ptable td{padding:14px 12px;border-bottom:1px solid var(--line);color:var(--text)}
.ptable tr:hover td{background:rgba(255,255,255,.02)}
.ptable .num{text-align:right;font-variant-numeric:tabular-nums}

.badge{font-size:.72rem;font-weight:700;font-family:var(--font-head);padding:4px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.03em}
.badge.green{background:rgba(52,211,153,.14);color:#34d399}
.badge.amber{background:rgba(255,176,46,.14);color:var(--gold)}
.badge.red{background:rgba(255,107,107,.14);color:#ff8a8a}
.badge.grey{background:rgba(255,255,255,.07);color:var(--muted)}

/* progress */
.bar{height:8px;border-radius:5px;background:var(--bg-3);overflow:hidden;margin-top:8px}
.bar > i{display:block;height:100%;background:var(--grad-gold);border-radius:5px}

/* project update timeline */
.timeline{position:relative;padding-left:24px;margin-top:14px}
.timeline::before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;padding-bottom:20px}
.tl-item::before{content:"";position:absolute;left:-22px;top:5px;width:11px;height:11px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px var(--bg-2)}
.tl-item b{font-family:var(--font-head);display:block}
.tl-item time{font-size:.78rem;color:var(--muted-2)}
.tl-item p{color:var(--muted);font-size:.92rem;margin-top:4px}

/* chat */
.chat{display:flex;flex-direction:column;height:60vh;min-height:380px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.chat__body{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:12px}
.bubble{max-width:74%;padding:12px 16px;border-radius:16px;font-size:.93rem;line-height:1.5}
.bubble time{display:block;font-size:.7rem;opacity:.6;margin-top:5px}
.bubble.them{align-self:flex-start;background:var(--bg-3);border:1px solid var(--line);border-bottom-left-radius:5px}
.bubble.me{align-self:flex-end;background:var(--grad-gold);color:#1a1205;border-bottom-right-radius:5px}
.chat__in{display:flex;gap:10px;padding:14px;border-top:1px solid var(--line)}
.chat__in input{flex:1}
.chat-attach{display:grid;place-items:center;width:44px;flex:none;border:1px solid var(--line-2);border-radius:10px;color:var(--muted);cursor:pointer;transition:.2s}
.chat-attach:hover{color:var(--gold);border-color:var(--gold)}
.chat-attach svg{width:18px;height:18px}
.att-staged{display:flex;align-items:center;gap:8px;padding:9px 14px;border-top:1px solid var(--line);font-size:.84rem;color:var(--muted)}
.att-staged svg{width:15px;height:15px;color:var(--gold)}
.att-staged button{background:none;border:none;color:#ff8a8a;cursor:pointer;font-size:.82rem;font-family:var(--font-head)}
.msg-att{display:inline-flex;align-items:center;gap:7px;margin-top:7px;padding:7px 11px;border-radius:9px;background:rgba(0,0,0,.2);cursor:pointer;font-size:.84rem}
.bubble.me .msg-att{background:rgba(0,0,0,.14)}
.msg-att svg{width:15px;height:15px;flex:none}
.msg-att span{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* file list */
.file-row{display:flex;align-items:center;gap:14px;padding:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:10px;transition:border-color .25s}
.file-row:hover{border-color:var(--line-2)}
.file-row .fic{width:40px;height:40px;border-radius:10px;background:var(--grad-gold-soft);border:1px solid var(--line-2);color:var(--gold);display:grid;place-items:center;flex:none}
.file-row b{font-family:var(--font-head);font-size:.95rem;display:block}
.file-row span{font-size:.8rem;color:var(--muted-2)}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(5,5,8,.7);backdrop-filter:blur(4px);z-index:100;display:grid;place-items:center;padding:24px}
.modal{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:30px;max-height:90vh;overflow-y:auto}
.modal h2{font-size:1.3rem;margin-bottom:18px}
.modal .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal .actions{display:flex;gap:12px;justify-content:flex-end;margin-top:22px}

.empty{text-align:center;color:var(--muted-2);padding:50px 20px}
.empty svg{width:42px;height:42px;margin-bottom:12px;opacity:.5}

@media(max-width:820px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;bottom:0;width:248px;transform:translateX(-100%);transition:transform .3s var(--ease);z-index:60}
  .side.open{transform:none}
  .main{padding:80px 20px 30px}
  .mobile-bar{display:flex!important}
}
.mobile-bar{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:rgba(10,10,12,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);align-items:center;justify-content:space-between;padding:0 16px;z-index:55}
.mobile-bar button{width:42px;height:42px;border-radius:10px;border:1px solid var(--line-2);background:transparent;color:#fff;font-size:1.3rem}
