/* Rapport Immigration — Client Portal styles */

.auth-shell{
  min-height:calc(100vh - 120px);
  display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;
}
.auth-side{
  position:relative;color:#fff;padding:clamp(2.5rem,5vw,4rem);
  display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;
}
.auth-side::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:url("../img/harbor-aerial.jpg") center/cover;
}
.auth-side::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(155deg,rgba(14,37,64,.88) 0%,rgba(14,37,64,.78) 60%,rgba(200,20,27,.55) 100%);
}
.auth-side .logo-link img{height:54px;filter:none}
.auth-side h2{color:#fff;font-size:clamp(1.9rem,3.3vw,2.6rem);margin-top:1.5rem}
.auth-side p.lead{color:#dbe2ec;font-size:1.05rem;margin-top:.9rem;max-width:30em}
.auth-side ul{margin-top:1.6rem;display:flex;flex-direction:column;gap:.7rem}
.auth-side li{display:flex;gap:.7rem;align-items:flex-start;font-size:.95rem;color:#dbe2ec}
.auth-side li svg{width:22px;height:22px;flex:none;fill:var(--gold)}
.auth-side .auth-foot{font-size:.82rem;color:#9aa8bc}

.auth-form-wrap{
  background:#fff;padding:clamp(2rem,4vw,3.5rem);
  display:flex;flex-direction:column;justify-content:center;
}
.auth-card{max-width:420px;width:100%;margin:0 auto}
.auth-tabs{display:flex;gap:.3rem;background:var(--soft);padding:.3rem;border-radius:999px;
  margin-bottom:1.6rem}
.auth-tab{flex:1;padding:.65rem 1rem;border-radius:999px;font-weight:600;font-size:.92rem;
  color:var(--ink-soft);transition:all .2s var(--ease)}
.auth-tab.active{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.auth-pane{display:none}
.auth-pane.active{display:block;animation:fade .3s var(--ease)}
.auth-card h1{font-size:1.7rem;margin-bottom:.35rem}
.auth-card .sub{color:var(--ink-soft);margin-bottom:1.4rem;font-size:.97rem}
.auth-msg{padding:.85rem 1rem;border-radius:11px;font-size:.9rem;margin-bottom:1rem;display:none}
.auth-msg.show{display:block}
.auth-msg.error{background:rgba(237,28,36,.1);color:var(--red-deep)}
.auth-msg.success{background:#E7F4EC;color:#1F7C45}
.auth-msg.info{background:#EAF1F7;color:#1F4E7C}
.auth-forgot{display:block;text-align:right;font-size:.85rem;color:var(--red-deep);
  font-weight:600;margin-top:-.4rem;margin-bottom:1rem}
.auth-fineprint{font-size:.78rem;color:var(--ink-mute);margin-top:1rem;line-height:1.6;text-align:center}
.auth-fineprint a{color:var(--red-deep);font-weight:600}
.auth-back{display:inline-flex;align-items:center;gap:.3rem;margin-top:1.4rem;
  font-size:.85rem;color:var(--ink-mute);font-weight:500}
.auth-back:hover{color:var(--ink)}

/* ----- Dashboard ----- */
.portal-shell{min-height:100vh;background:var(--soft);display:flex;flex-direction:column}
.portal-bar{background:#fff;border-bottom:1px solid var(--line-soft);position:sticky;top:0;z-index:30}
.portal-bar-inner{display:flex;align-items:center;justify-content:space-between;
  padding:1rem 24px;max-width:1180px;margin:0 auto;gap:1rem}
.portal-bar .brand img{height:46px}
.portal-user{display:flex;align-items:center;gap:.8rem}
.portal-avatar{width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:.9rem;flex:none}
.portal-user-name{font-weight:600;font-size:.93rem;color:var(--ink)}
.portal-user-email{display:block;font-size:.78rem;color:var(--ink-mute)}
.portal-signout{padding:.5rem .9rem;font-size:.84rem;font-weight:600;
  color:var(--ink-soft);border:1.5px solid var(--line);border-radius:999px;transition:all .2s}
.portal-signout:hover{border-color:var(--red);color:var(--red)}

.portal-main{max-width:1180px;margin:0 auto;width:100%;padding:clamp(1.6rem,3vw,2.6rem) 24px 4rem;
  display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}

.portal-card{background:#fff;border:1px solid var(--line-soft);border-radius:18px;
  padding:1.6rem;box-shadow:var(--shadow-sm)}
.portal-card h2{font-size:1.35rem;margin-bottom:.3rem}
.portal-card>.lead{color:var(--ink-soft);font-size:.95rem;margin-bottom:1.3rem}

.welcome-card{background:linear-gradient(135deg,#0E2540,#1B3A5C);color:#fff;border:0;position:relative;overflow:hidden}
.welcome-card::before{content:"";position:absolute;right:-30px;top:-30px;width:220px;height:220px;
  border-radius:50%;background:radial-gradient(circle,rgba(234,163,60,.22),transparent 70%)}
.welcome-card h2{color:#fff;font-size:1.6rem}
.welcome-card p{color:#cdd6e3;margin-top:.5rem;max-width:42em}

.upload-zone{
  border:2px dashed var(--line);border-radius:14px;padding:1.6rem 1.2rem;text-align:center;
  background:var(--soft);transition:all .2s var(--ease);cursor:pointer;
}
.upload-zone.drag{border-color:var(--red);background:rgba(237,28,36,.05)}
.upload-zone svg{width:38px;height:38px;fill:var(--red);margin-bottom:.6rem}
.upload-zone strong{display:block;font-size:1rem}
.upload-zone span{display:block;font-size:.83rem;color:var(--ink-mute);margin-top:.3rem}
.upload-zone input[type=file]{display:none}

.upload-meta{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:1rem 0}
.upload-progress{height:6px;background:var(--soft-2);border-radius:99px;overflow:hidden;
  margin:.8rem 0;display:none}
.upload-progress.show{display:block}
.upload-progress-bar{height:100%;width:0;background:var(--red);transition:width .25s}

.doc-list{margin-top:1rem;display:flex;flex-direction:column;gap:.6rem}
.doc-item{
  display:grid;grid-template-columns:42px 1fr auto;gap:.9rem;align-items:center;
  padding:.85rem 1rem;border:1px solid var(--line-soft);border-radius:12px;background:#fff;
  transition:border-color .2s,box-shadow .2s;
}
.doc-item:hover{border-color:var(--line);box-shadow:var(--shadow-sm)}
.doc-ic{width:42px;height:42px;border-radius:10px;background:var(--tint);
  display:grid;place-items:center;flex:none}
.doc-ic svg{width:22px;height:22px;fill:var(--ink)}
.doc-name{font-weight:600;font-size:.95rem;color:var(--ink);word-break:break-word}
.doc-meta{font-size:.78rem;color:var(--ink-mute);margin-top:.15rem}
.doc-actions{display:flex;gap:.45rem}
.doc-btn{
  padding:.4rem .8rem;font-size:.82rem;font-weight:600;border-radius:8px;
  border:1.5px solid var(--line);color:var(--ink-soft);transition:all .15s;
}
.doc-btn:hover{border-color:var(--ink);color:var(--ink)}
.doc-btn.danger:hover{border-color:var(--red);color:var(--red)}

.doc-empty{text-align:center;padding:2rem 1rem;color:var(--ink-mute);font-size:.95rem}
.doc-empty svg{width:42px;height:42px;fill:var(--line);margin-bottom:.6rem}

.side-card h3{font-size:1rem;margin-bottom:.7rem}
.side-card ul{display:flex;flex-direction:column;gap:.5rem}
.side-card li{font-size:.88rem;color:var(--ink-soft);position:relative;padding-left:1rem;
  overflow-wrap:anywhere;word-break:break-word}
.side-card li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;
  border-radius:50%;background:var(--red)}
.side-card li a{overflow-wrap:anywhere;word-break:break-word}
.side-card .ctas{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}

@media(max-width:900px){
  .auth-shell{grid-template-columns:1fr}
  .auth-side{min-height:240px;padding:2rem}
  .auth-side ul,.auth-side .auth-foot{display:none}
  .portal-main{grid-template-columns:1fr}
}

/* ---------- Minimal centered sign-in ---------- */
body.auth-page{
  min-height:100vh;
  background:
    linear-gradient(135deg, rgba(14,37,64,.55) 0%, rgba(14,37,64,.35) 45%, rgba(200,20,27,.30) 100%),
    url("../img/harbor-aerial.jpg") center/cover no-repeat;
  background-attachment:scroll, fixed;
}
.auth-card-solo{position:relative;z-index:1;backdrop-filter:saturate(110%)}
.auth-center{
  min-height:100vh;display:grid;place-items:center;padding:2rem 1.25rem;
}
.auth-card-solo{
  width:100%;max-width:440px;background:#fff;
  border:1px solid var(--line-soft);border-radius:22px;
  padding:clamp(1.8rem,4vw,2.6rem);
  box-shadow:0 30px 70px -28px rgba(14,37,64,.32),0 2px 8px rgba(14,37,64,.04);
}
.auth-brand{display:flex;justify-content:center;margin-bottom:1.6rem}
.auth-brand img{height:54px;width:auto}
.auth-card-solo .auth-tabs{margin-bottom:1.5rem}
.auth-card-solo .auth-back{display:block;text-align:center;margin-top:1.4rem;
  font-size:.85rem;color:var(--ink-mute);font-weight:500}
.auth-card-solo .auth-back:hover{color:var(--ink)}

@media(max-width:480px){
  .auth-card-solo{padding:1.6rem 1.25rem;border-radius:16px}
  .auth-brand img{height:46px}
}

/* ---------- Welcome card progress summary ---------- */
.progress-summary{margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.14)}
.ps-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.45rem}
.ps-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:#9fb0c5;font-weight:600}
.ps-value{font-family:var(--serif);font-size:1.5rem;color:#fff;font-weight:600;line-height:1}
.ps-bar{height:6px;background:rgba(255,255,255,.12);border-radius:99px;overflow:hidden}
.ps-bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--red));
  border-radius:99px;transition:width .5s var(--ease)}

/* ---------- Card head ---------- */
.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.2rem}
.card-head h2{margin-bottom:.25rem}
.card-head .lead{margin-bottom:0}

/* ---------- Checklist (IRCC-style document categories) ---------- */
.checklist{display:flex;flex-direction:column;gap:.55rem}
.check-row{
  display:grid;grid-template-columns:46px 1fr auto;gap:.95rem;align-items:center;
  padding:.95rem 1.05rem;border:1px solid var(--line-soft);border-radius:13px;
  background:#fff;transition:border-color .2s,box-shadow .2s,transform .15s;
}
.check-row:hover{border-color:var(--line);box-shadow:var(--shadow-sm)}
.check-ic{width:42px;height:42px;border-radius:11px;background:var(--tint);
  display:grid;place-items:center;flex:none}
.check-ic svg{width:22px;height:22px;fill:none;stroke:var(--ink);stroke-width:1.8;
  stroke-linecap:round;stroke-linejoin:round}
.check-row[data-cat] strong{display:block;font-size:.98rem;color:var(--ink);font-weight:600;line-height:1.2}
.check-body span{display:block;font-size:.83rem;color:var(--ink-mute);margin-top:.2rem;line-height:1.45}
.check-side{display:flex;align-items:center;gap:.6rem;flex:none}

.status-badge{
  display:inline-flex;align-items:center;font-size:.76rem;font-weight:600;
  padding:.32rem .65rem;border-radius:99px;letter-spacing:.01em;white-space:nowrap;
}
.status-badge.muted{background:var(--soft-2);color:var(--ink-mute)}
.status-badge.ok{background:#E7F4EC;color:#1F7C45}
.status-badge.ok::before{content:"";width:6px;height:6px;border-radius:50%;background:#1F7C45;margin-right:.4rem}

.check-btn{
  display:inline-flex;align-items:center;cursor:pointer;
  padding:.55rem 1rem;font-size:.86rem;font-weight:600;color:#fff;
  background:var(--red);border-radius:99px;
  box-shadow:0 8px 16px -8px rgba(237,28,36,.55);
  transition:background .2s,transform .15s;
}
.check-btn:hover{background:var(--red-deep);transform:translateY(-1px)}
.check-btn input{display:none}

/* ---------- Grouped doc list (Shared with us) ---------- */
.doc-group{margin-top:1.4rem}
.doc-group:first-child{margin-top:.4rem}
.dg-head{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:.4rem 0 .8rem;border-bottom:1px solid var(--line-soft);margin-bottom:.7rem;
}
.dg-head strong{font-family:var(--serif);font-size:1.05rem;color:var(--ink);font-weight:600}
.dg-head span{font-size:.78rem;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* ---------- Responsive ---------- */
@media(max-width:560px){
  .check-row{grid-template-columns:38px 1fr;grid-template-rows:auto auto;gap:.5rem .85rem;padding:.85rem .9rem}
  .check-ic{width:38px;height:38px;grid-row:1/3}
  .check-side{grid-column:2;justify-content:flex-end;margin-top:.4rem}
  .check-body{grid-column:2}
  .doc-item{grid-template-columns:38px 1fr;grid-template-rows:auto auto;gap:.4rem .9rem}
  .doc-ic{grid-row:1/3}
  .doc-actions{grid-column:2;justify-content:flex-start}
}

/* Storage meter in welcome card */
.ps-storage{margin-top:.5rem;font-size:.76rem;color:#9fb0c5;font-weight:500}

/* ============ Admin dashboard ============ */
.admin-pill{background:var(--ink);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:.28rem .6rem;border-radius:999px}
.admin-main{max-width:1180px;margin:0 auto;width:100%;padding:clamp(1.4rem,3vw,2.4rem) 24px 4rem}

.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.6rem}
.admin-stat{background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:1.2rem 1.3rem;
  box-shadow:var(--shadow-sm)}
.as-num{display:block;font-family:var(--serif);font-size:2rem;font-weight:700;color:var(--ink);line-height:1}
.as-label{display:block;margin-top:.3rem;font-size:.82rem;color:var(--ink-mute);font-weight:500}

.admin-tabs{display:flex;gap:.3rem;background:var(--soft);padding:.32rem;border-radius:999px;
  margin-bottom:1.4rem;overflow-x:auto;-webkit-overflow-scrolling:touch}
.admin-tab{flex:1;min-width:max-content;padding:.6rem 1.1rem;border-radius:999px;font-weight:600;
  font-size:.9rem;color:var(--ink-soft);white-space:nowrap;transition:all .2s var(--ease)}
.admin-tab.active{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.admin-pane{display:none}
.admin-pane.active{display:block;animation:fade .3s var(--ease)}

.admin-card{background:#fff;border:1px solid var(--line-soft);border-radius:16px;padding:1.6rem;
  box-shadow:var(--shadow-sm)}
.admin-card-head{display:flex;align-items:baseline;gap:.8rem;margin-bottom:.4rem}
.admin-card-head h2{font-size:1.3rem}
.admin-count{font-size:.82rem;color:var(--ink-mute);font-weight:600}
.admin-hint{font-size:.88rem;color:var(--ink-soft);margin-bottom:1.1rem}

.table-wrap{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}
.admin-table th{text-align:left;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-mute);font-weight:700;padding:.6rem .7rem;border-bottom:2px solid var(--line-soft)}
.admin-table td{padding:.75rem .7rem;border-bottom:1px solid var(--line-soft);color:var(--ink-soft);vertical-align:top}
.admin-table td strong{color:var(--ink)}
.admin-table a{color:var(--red-deep);font-weight:500}
.t-loading,.t-empty{color:var(--ink-mute);font-size:.92rem;padding:1.2rem .4rem;text-align:center}

.inq-row{border:1px solid var(--line-soft);border-radius:12px;padding:1rem 1.1rem;margin-bottom:.7rem}
.inq-top{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem}
.inq-top strong{color:var(--ink)}
.inq-top span{font-size:.78rem;color:var(--ink-mute)}
.inq-meta{font-size:.85rem;color:var(--ink-soft);margin-top:.25rem}
.inq-meta a{color:var(--red-deep);font-weight:500}
.inq-tag{background:var(--tint);color:var(--ink);padding:.12rem .5rem;border-radius:99px;font-size:.76rem;font-weight:600}
.inq-msg{margin-top:.6rem;font-size:.9rem;color:var(--ink-soft);background:var(--soft);padding:.7rem .85rem;border-radius:9px}

.rev-row{border:1px solid var(--line-soft);border-radius:12px;padding:1rem 1.1rem;margin-bottom:.7rem}
.rev-top{display:flex;align-items:center;gap:.7rem;margin-bottom:.5rem}
.rev-stars{color:#F4B400;letter-spacing:1px}
.rev-date{font-size:.76rem;color:var(--ink-mute);margin-left:auto}
.rev-quote{font-size:.94rem;color:var(--ink-soft);margin-bottom:.5rem}
.rev-meta{font-size:.82rem;color:var(--ink-mute);margin-bottom:.7rem}
.rev-meta a{color:var(--red-deep)}
.rev-actions{display:flex;gap:.5rem}
.status-badge.pending{background:#FFF4E0;color:#9A6A00}
.status-badge.pending::before{content:"";width:6px;height:6px;border-radius:50%;background:#E0A33C;margin-right:.4rem}

.admin-gate{position:fixed;inset:0;display:grid;place-items:center;padding:2rem;
  background:radial-gradient(circle at 50% 30%,#FBF8F2,#EFF4F8)}
.admin-gate-card{background:#fff;border:1px solid var(--line-soft);border-radius:18px;
  padding:2.2rem;max-width:420px;text-align:center;box-shadow:var(--shadow)}
.admin-gate-card h2{font-size:1.4rem;margin-bottom:.4rem}
.admin-gate-card p{color:var(--ink-soft);font-size:.95rem}
.admin-gate-card .cta-actions,.admin-gate-card #gateActions{display:flex;gap:.6rem;justify-content:center}

@media(max-width:760px){
  .admin-stats{grid-template-columns:repeat(2,1fr)}
}

/* ---------- Pending-approval state (client dashboard) ---------- */
.pending-state{text-align:center;padding:1.4rem .5rem}
.pending-ic{width:64px;height:64px;border-radius:50%;background:rgba(224,163,60,.16);
  display:grid;place-items:center;margin:0 auto 1.1rem}
.pending-ic svg{width:32px;height:32px;fill:var(--gold)}
.pending-state h2{font-size:1.4rem;margin-bottom:.6rem}
.pending-state p{color:var(--ink-soft);max-width:42ch;margin:0 auto .6rem}
.pending-contact a{color:var(--red-deep);font-weight:600}

/* ---------- Admin: approval status + action ---------- */
.appr-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.74rem;font-weight:700;
  padding:.25rem .6rem;border-radius:999px;white-space:nowrap}
.appr-badge.yes{background:#E7F4EC;color:#1F7C45}
.appr-badge.no{background:#FBEBD0;color:#9A6A12}
.appr-btn{padding:.4rem .85rem;font-size:.8rem;font-weight:700;border-radius:8px;
  background:var(--red);color:#fff;transition:background .2s,transform .15s}
.appr-btn:hover{background:var(--red-deep);transform:translateY(-1px)}
.appr-btn[disabled]{opacity:.5;cursor:default;transform:none}
