/* CareerLift - premium SaaS dashboard stylesheet */
/* =========================================================
   CareerLift — assets/css/style.css (inlined for preview)
   ========================================================= */
:root{
  --indigo:        #1D8ECB;   /* BinC blue (primary) */
  --indigo-deep:   #1573A6;
  --indigo-soft:   #E2F0F9;
  --coral:         #F5A623;   /* Try US amber (action accent) */
  --coral-soft:    #FDECCB;
  --green:         #23B389;   /* Try US teal */
  --green-soft:    #DEF5EE;
  --amber:         #F5A623;
  --amber-soft:    #FDECCB;
  --rose:          #EF4D6A;
  --rose-soft:     #FCE3E8;
  --ink:           #16314A;
  --ink-soft:      #5C6B7A;
  --line:          #E5EDF3;
  --bg:            #F2F7FB;
  --card:          #FFFFFF;

  --r-sm: 14px;
  --r:    20px;
  --r-lg: 28px;

  --shadow-sm: 0 2px 10px rgba(20,70,120,.06);
  --shadow:    0 14px 40px -18px rgba(20,90,150,.30);
  --shadow-lg: 0 30px 70px -30px rgba(20,90,150,.45);

  --sidebar-w: 264px;
  --rail-w: 340px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family:'Plus Jakarta Sans', sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1100px 700px at -5% -10%, #E2F0F9 0%, transparent 55%),
    radial-gradient(900px 600px at 105% 0%, #FDECCB 0%, transparent 50%),
    radial-gradient(900px 800px at 100% 110%, #DEF5EE 0%, transparent 55%),
    var(--bg);
  background-attachment: fixed;
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.01em;
}
h1,h2,h3,h4,h5,h6,.display-font{
  font-family:'Bricolage Grotesque', sans-serif;
  letter-spacing:-.02em;
  margin:0;
}
a{ text-decoration:none; }
.text-soft{ color:var(--ink-soft); }
.fw-900{ font-weight:800; }

/* ---------- App grid shell ---------- */
.app{
  display:grid;
  grid-template-columns: var(--sidebar-w) minmax(0,1fr) var(--rail-w);
  gap:22px;
  max-width:none;
  width:100%;
  margin:0;
  padding:22px 28px;
  align-items:start;
}
.col-main{ min-width:0; }

/* ---------- Sidebar ---------- */
.sidebar{
  position:sticky; top:22px;
  background:var(--card);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow);
  padding:22px 16px;
  height:calc(100vh - 44px);
  display:flex; flex-direction:column;
}
.brand{
  display:flex; align-items:center; gap:12px;
  padding:6px 10px 18px;
}
.brand-mark{
  width:42px; height:42px; border-radius:13px;
  background:linear-gradient(135deg,var(--indigo),#5AB0E0);
  display:grid; place-items:center; color:#fff; font-size:20px;
  box-shadow:0 10px 22px -8px rgba(20,90,150,.7);
}
.brand-name{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:1.3rem; line-height:1; }
.brand-name span{ color:var(--indigo); }
.brand-sub{ font-size:.66rem; letter-spacing:.02em; text-transform:none; color:var(--ink-soft); line-height:1.3; }

.nav-label{ font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:#A7A2C0; padding:14px 12px 8px; }
.nav-menu{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:4px; overflow-y:auto; }
.nav-menu::-webkit-scrollbar{ width:0; }
.nav-item{
  display:flex; align-items:center; gap:13px;
  padding:11px 13px; border-radius:14px;
  color:var(--ink-soft); font-weight:600; font-size:.92rem;
  cursor:pointer; transition:all .22s cubic-bezier(.4,0,.2,1);
  position:relative; border:none; background:none; width:100%; text-align:left;
}
.nav-item i{ font-size:1.15rem; transition:transform .22s; }
.nav-item:hover{ background:var(--indigo-soft); color:var(--indigo-deep); }
.nav-item:hover i{ transform:translateX(2px); }
.nav-item.active{
  background:linear-gradient(135deg,var(--indigo),#5AB0E0);
  color:#fff; box-shadow:0 12px 24px -12px rgba(20,90,150,.85);
}
.nav-item.active::before{
  content:""; position:absolute; left:-16px; top:50%; transform:translateY(-50%);
  width:5px; height:22px; border-radius:6px; background:var(--coral);
}
.nav-foot{ margin-top:auto; padding-top:12px; }
.logout{ color:var(--rose); }
.logout:hover{ background:var(--rose-soft); color:var(--rose); }

/* ---------- Topbar ---------- */
.topbar{
  display:flex; align-items:center; gap:16px; margin-bottom:22px;
}
.menu-toggle{
  display:none; border:none; background:var(--card); width:46px; height:46px;
  border-radius:14px; box-shadow:var(--shadow-sm); color:var(--ink); font-size:1.3rem;
}
.searchbar{
  flex:1; display:flex; align-items:center; gap:10px;
  background:var(--card); border-radius:16px; padding:12px 18px;
  box-shadow:var(--shadow-sm); color:var(--ink-soft);
}
.searchbar input{ border:none; outline:none; background:none; flex:1; font-family:inherit; font-size:.95rem; color:var(--ink); }
.icon-btn{
  width:46px; height:46px; flex:0 0 auto; border:none; border-radius:14px;
  background:var(--card); box-shadow:var(--shadow-sm); color:var(--ink);
  font-size:1.15rem; position:relative; transition:.2s;
}
.icon-btn:hover{ transform:translateY(-2px); color:var(--indigo); }
.dot{ position:absolute; top:11px; right:12px; width:8px; height:8px; border-radius:50%; background:var(--coral); border:2px solid #fff; }

/* ---------- Cards ---------- */
.card-x{
  background:var(--card); border-radius:var(--r);
  box-shadow:var(--shadow-sm); border:1px solid rgba(236,233,245,.7);
  padding:22px; transition:transform .25s, box-shadow .25s;
}
.card-x.hov:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.section-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.section-head h5{ font-size:1.12rem; font-weight:700; }
.link-more{ font-size:.82rem; font-weight:700; color:var(--indigo); display:inline-flex; align-items:center; gap:4px; }
.link-more:hover{ color:var(--coral); }

/* ---------- Hero / welcome ---------- */
.hero{
  position:relative; overflow:hidden;
  border-radius:var(--r-lg);
  background:
    radial-gradient(420px 260px at 88% -20%, rgba(255,255,255,.22), transparent 60%),
    linear-gradient(125deg,#1D8ECB 0%, #1F9FD0 45%, #23B389 100%);
  color:#fff; padding:34px 36px;
  box-shadow:var(--shadow);
}
.hero::after{
  content:""; position:absolute; right:-40px; bottom:-70px;
  width:240px; height:240px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,138,101,.85), rgba(255,138,101,0) 70%);
}
.hero::before{
  content:""; position:absolute; left:-60px; top:-60px;
  width:180px; height:180px; border-radius:50%;
  border:30px solid rgba(255,255,255,.08);
}
.hero-tag{
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(255,255,255,.16); backdrop-filter:blur(6px);
  padding:6px 14px; border-radius:50px; font-size:.76rem; font-weight:700; letter-spacing:.04em;
  margin-bottom:14px;
}
.hero h2{ font-size:2.05rem; line-height:1.08; max-width:560px; }
.hero p{ max-width:520px; margin:12px 0 22px; color:rgba(255,255,255,.86); font-size:.98rem; }
.btn-coral{
  background:var(--coral); color:#fff; border:none; font-weight:700;
  padding:13px 26px; border-radius:14px; box-shadow:0 14px 28px -12px rgba(35,179,137,.9);
  transition:.22s; display:inline-flex; align-items:center; gap:9px;
}
.btn-coral:hover{ transform:translateY(-3px); background:#E0940F; color:#fff; }
.btn-ghost-w{
  background:rgba(255,255,255,.14); color:#fff; border:1px solid rgba(255,255,255,.3);
  font-weight:700; padding:13px 22px; border-radius:14px; transition:.2s;
}
.btn-ghost-w:hover{ background:rgba(255,255,255,.26); color:#fff; }

/* ---------- Stat / KPI ---------- */
.kpi{ display:flex; align-items:center; gap:14px; }
.kpi-ic{ width:50px; height:50px; flex:0 0 auto; border-radius:15px; display:grid; place-items:center; font-size:1.4rem; }
.kpi-val{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:1.7rem; line-height:1; }
.kpi-lab{ font-size:.8rem; color:var(--ink-soft); font-weight:600; margin-top:3px; }
.trend{ font-size:.72rem; font-weight:700; padding:3px 8px; border-radius:30px; }
.trend.up{ color:var(--green); background:var(--green-soft); }
.trend.down{ color:var(--rose); background:var(--rose-soft); }

.tint-indigo{ background:var(--indigo-soft); color:var(--indigo); }
.tint-coral{ background:var(--coral-soft); color:var(--coral); }
.tint-green{ background:var(--green-soft); color:var(--green); }
.tint-amber{ background:var(--amber-soft); color:#D99A1E; }
.tint-rose{ background:var(--rose-soft); color:var(--rose); }

/* ---------- Tracking card ---------- */
.track-card{
  background:linear-gradient(135deg,#FFFFFF,#FBFAFF);
  border:1px solid var(--line);
}
.track-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.track-cell .lab{ font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-soft); font-weight:700; }
.track-cell .val{ font-weight:700; margin-top:5px; font-size:.98rem; }
.idpill{ font-family:'Bricolage Grotesque'; font-weight:700; background:var(--indigo); color:#fff; padding:4px 12px; border-radius:9px; display:inline-block; font-size:.92rem; }

/* ---------- Badges ---------- */
.badge-x{ font-size:.74rem; font-weight:700; padding:5px 12px; border-radius:30px; display:inline-flex; align-items:center; gap:6px; }
.badge-x i{ font-size:.6rem; }
.b-progress{ background:var(--amber-soft); color:#C98A12; }
.b-review{ background:var(--indigo-soft); color:var(--indigo-deep); }
.b-shortlist{ background:var(--coral-soft); color:var(--coral); }
.b-selected{ background:var(--green-soft); color:var(--green); }
.b-rejected{ background:var(--rose-soft); color:var(--rose); }

/* ---------- Category cards ---------- */
.cat-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.cat{
  background:var(--card); border:1px solid var(--line); border-radius:var(--r-sm);
  padding:18px 14px; text-align:center; cursor:pointer; transition:.25s;
}
.cat:hover{ transform:translateY(-5px); box-shadow:var(--shadow); border-color:transparent; }
.cat-ic{ width:52px; height:52px; margin:0 auto 11px; border-radius:16px; display:grid; place-items:center; font-size:1.5rem; }
.cat-name{ font-weight:700; font-size:.86rem; }
.cat-meta{ font-size:.72rem; color:var(--ink-soft); margin-top:2px; }

/* ---------- AI insight cards ---------- */
.insight-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.insight{
  border-radius:var(--r); padding:20px; color:#fff; position:relative; overflow:hidden;
  min-height:140px; display:flex; flex-direction:column; justify-content:space-between;
  transition:transform .25s, box-shadow .25s; cursor:pointer;
}
.insight:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.insight::after{ content:""; position:absolute; right:-30px; top:-30px; width:120px; height:120px; border-radius:50%; background:rgba(255,255,255,.12); }
.i1{ background:linear-gradient(135deg,#1D8ECB,#5AB0E0); }
.i2{ background:linear-gradient(135deg,#F5A623,#FF9E7D); }
.i3{ background:linear-gradient(135deg,#F56991,#FF8FB1); }
.i4{ background:linear-gradient(135deg,#23B389,#4CD9A6); }
.insight .ic{ font-size:1.5rem; opacity:.95; }
.insight .num{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:1.9rem; line-height:1; }
.insight .cap{ font-size:.84rem; opacity:.92; font-weight:600; }
.chips{ display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.chip{ background:rgba(255,255,255,.22); padding:3px 9px; border-radius:20px; font-size:.7rem; font-weight:600; }

/* ---------- Job cards ---------- */
.job{
  border:1px solid var(--line); border-radius:var(--r); padding:18px; transition:.25s; background:var(--card);
}
.job:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:transparent; }
.job-logo{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; font-weight:800; font-family:'Bricolage Grotesque'; color:#fff; font-size:1.05rem; }
.job-title{ font-weight:700; font-size:1rem; }
.job-co{ font-size:.82rem; color:var(--ink-soft); }
.job-meta{ display:flex; gap:14px; font-size:.78rem; color:var(--ink-soft); margin:12px 0; flex-wrap:wrap; }
.job-meta span{ display:inline-flex; align-items:center; gap:5px; }
.skilltag{ font-size:.72rem; font-weight:600; background:var(--indigo-soft); color:var(--indigo-deep); padding:4px 10px; border-radius:8px; white-space:nowrap; overflow-wrap:normal; word-break:keep-all; display:inline-block; }
.btn-apply{ background:var(--indigo); color:#fff; border:none; font-weight:700; font-size:.82rem; padding:9px 16px; border-radius:11px; transition:.2s; }
.btn-apply:hover{ background:var(--indigo-deep); color:#fff; transform:translateY(-2px); }
.btn-save{ border:1px solid var(--line); background:#fff; color:var(--ink-soft); border-radius:11px; width:38px; height:38px; transition:.2s; }
.btn-save:hover{ color:var(--coral); border-color:var(--coral); }

/* ---------- Course cards ---------- */
.course{ border:1px solid var(--line); border-radius:var(--r); overflow:hidden; background:#fff; transition:.25s; }
.course:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.course-top{ height:80px; display:grid; place-items:center; color:#fff; font-size:1.9rem; }
.course-body{ padding:15px; }

/* ---------- Right rail / profile ---------- */
.rail{ position:sticky; top:22px; display:flex; flex-direction:column; gap:18px; }
.profile-card{ text-align:center; }
.avatar{
  width:84px; height:84px; border-radius:26px; margin:0 auto 12px;
  background:linear-gradient(135deg,#F5A623,#FFB07D); display:grid; place-items:center;
  color:#fff; font-family:'Bricolage Grotesque'; font-weight:800; font-size:2rem;
  box-shadow:0 14px 28px -12px rgba(35,179,137,.7); position:relative;
}
.avatar .stat-dot{ position:absolute; bottom:6px; right:6px; width:18px; height:18px; border-radius:50%; background:var(--green); border:3px solid #fff; }
.profile-name{ font-family:'Bricolage Grotesque'; font-weight:700; font-size:1.2rem; }
.profile-mail{ font-size:.82rem; color:var(--ink-soft); }
.status-pill{ display:inline-flex; gap:6px; align-items:center; background:var(--green-soft); color:var(--green); padding:5px 13px; border-radius:30px; font-size:.78rem; font-weight:700; margin-top:8px; }

.mini-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:16px; }
.mini{ background:#FAF9FF; border:1px solid var(--line); border-radius:14px; padding:13px; text-align:center; }
.mini .v{ font-family:'Bricolage Grotesque'; font-weight:800; font-size:1.4rem; }
.mini .l{ font-size:.7rem; color:var(--ink-soft); font-weight:600; }

.score-ring{ position:relative; width:120px; height:120px; margin:6px auto 0; }
.score-ring svg{ transform:rotate(-90deg); }
.score-num{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; line-height:1; gap:1px; }
.score-num b{ font-family:'Bricolage Grotesque'; font-size:1.9rem; line-height:1; }
.score-num small{ line-height:1; }

/* ---------- Timeline ---------- */
.timeline{ position:relative; padding-left:26px; }
.timeline::before{ content:""; position:absolute; left:8px; top:6px; bottom:6px; width:2px; background:var(--line); }
.tl-item{ position:relative; padding-bottom:18px; }
.tl-item:last-child{ padding-bottom:0; }
.tl-dot{ position:absolute; left:-26px; top:2px; width:18px; height:18px; border-radius:50%; background:#fff; border:3px solid var(--indigo); display:grid; place-items:center; }
.tl-item.done .tl-dot{ background:var(--green); border-color:var(--green); color:#fff; font-size:.6rem; }
.tl-item.active .tl-dot{ background:var(--coral); border-color:var(--coral); box-shadow:0 0 0 5px var(--coral-soft); }
.tl-title{ font-weight:700; font-size:.9rem; }
.tl-time{ font-size:.74rem; color:var(--ink-soft); }

.quick-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.quick{
  border:1px solid var(--line); border-radius:14px; padding:14px 12px; text-align:center;
  font-size:.8rem; font-weight:700; color:var(--ink); cursor:pointer; transition:.2s; background:#fff;
}
.quick i{ display:block; font-size:1.4rem; margin-bottom:6px; }
.quick:hover{ transform:translateY(-3px); box-shadow:var(--shadow-sm); color:var(--indigo); border-color:var(--indigo-soft); }

/* ---------- Upload page ---------- */
.dropzone{
  border:2.5px dashed #CFC7F0; border-radius:var(--r-lg); padding:50px 30px; text-align:center;
  background:linear-gradient(180deg,#FBFAFF,#F6F3FF); transition:.25s; cursor:pointer;
}
.dropzone:hover, .dropzone.drag{ border-color:var(--indigo); background:var(--indigo-soft); transform:scale(1.005); }
.drop-ic{ width:84px; height:84px; margin:0 auto 16px; border-radius:26px; background:linear-gradient(135deg,var(--indigo),#5AB0E0); display:grid; place-items:center; color:#fff; font-size:2.2rem; box-shadow:0 16px 30px -14px rgba(20,90,150,.8); }
.fmt{ display:inline-flex; gap:8px; margin-top:16px; }
.fmt span{ background:#fff; border:1px solid var(--line); border-radius:9px; padding:5px 12px; font-size:.76rem; font-weight:700; color:var(--ink-soft); }
.success-card{
  background:linear-gradient(135deg,#E2F7EE,#F2FBF7); border:1px solid #BfeFD8; border-radius:var(--r-lg);
  padding:32px; text-align:center;
}
.success-ic{ width:74px; height:74px; margin:0 auto 14px; border-radius:50%; background:var(--green); color:#fff; display:grid; place-items:center; font-size:2.2rem; box-shadow:0 14px 28px -10px rgba(34,197,139,.7); }

/* ---------- AI chat flow ---------- */
.ai-stage{ max-width:680px; margin:0 auto; }
.ai-avatar{ width:60px; height:60px; border-radius:20px; background:linear-gradient(135deg,var(--indigo),#5AB0E0); display:grid; place-items:center; color:#fff; font-size:1.7rem; box-shadow:0 12px 24px -10px rgba(20,90,150,.7); }
.ai-bubble{ background:#fff; border:1px solid var(--line); border-radius:6px 22px 22px 22px; padding:18px 22px; box-shadow:var(--shadow-sm); font-size:1.05rem; font-weight:600; }
.opt-btn{
  width:100%; text-align:left; border:1.5px solid var(--line); background:#fff; border-radius:15px;
  padding:15px 18px; font-weight:600; color:var(--ink); transition:.2s; display:flex; align-items:center; gap:12px;
}
.opt-btn:hover{ border-color:var(--indigo); background:var(--indigo-soft); transform:translateX(4px); }
.opt-btn .k{ width:30px; height:30px; border-radius:9px; background:var(--indigo-soft); color:var(--indigo); display:grid; place-items:center; font-weight:800; font-size:.85rem; }
.progress-thin{ height:8px; border-radius:30px; background:var(--line); overflow:hidden; }
.progress-thin > div{ height:100%; background:linear-gradient(90deg,var(--indigo),var(--coral)); border-radius:30px; transition:width .4s; }

/* ---------- Track page ---------- */
.track-search{ display:flex; gap:12px; }
.track-search input{
  flex:1; border:1.5px solid var(--line); border-radius:16px; padding:16px 20px; font-size:1.05rem; font-weight:600;
  outline:none; transition:.2s; font-family:inherit;
}
.track-search input:focus{ border-color:var(--indigo); box-shadow:0 0 0 4px var(--indigo-soft); }

/* ---------- Table ---------- */
.tbl{ width:100%; border-collapse:separate; border-spacing:0 8px; }
.tbl-wrap{ width:100%; overflow-x:auto; }
.tbl th{ font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft); font-weight:700; padding:0 14px 4px; text-align:left; white-space:nowrap; }
.tbl th.num, .tbl td.num{ text-align:center; }
.tbl td{ background:#FAF9FF; padding:14px; font-size:.86rem; font-weight:600; vertical-align:middle; overflow-wrap:break-word; }
.tbl tr td:first-child{ border-radius:13px 0 0 13px; }
.tbl tr td:last-child{ border-radius:0 13px 13px 0; }
.tbl tr:hover td{ background:var(--indigo-soft); }
.u-ava{ width:34px; height:34px; border-radius:10px; display:grid; place-items:center; color:#fff; font-weight:700; font-size:.8rem; }
.ico-act{ border:none; background:#fff; width:32px; height:32px; border-radius:9px; color:var(--ink-soft); transition:.2s; display:inline-grid; place-items:center; }
.row-actions{ display:flex; gap:6px; justify-content:flex-end; align-items:center; }
.row-actions form{ margin:0; display:inline-flex; }
.ico-act.danger:hover{ color:var(--rose); border-color:var(--rose); }
.tbl td.actions-cell{ text-align:right; }
.tbl th.actions-cell{ text-align:right; }
.tbl th.num, .tbl td.num{ width:86px; }
.tbl th.actions-cell, .tbl td.actions-cell{ width:120px; }
.tbl td .inline-select{ white-space:nowrap; }
.inline-select{ border:1px solid var(--line); border-radius:9px; padding:5px 8px; font-size:.78rem; font-weight:600; font-family:inherit; background:#fff; color:var(--ink); }
.ico-act:hover{ color:var(--indigo); transform:translateY(-2px); }

/* ---------- View switching ---------- */
.view{ display:none; animation:fade .45s ease; }
.view.show{ display:block; }
@keyframes fade{ from{ opacity:0; transform:translateY(10px);} to{ opacity:1; transform:none;} }
.page-title{ font-size:1.7rem; font-weight:800; }
.page-sub{ color:var(--ink-soft); font-size:.92rem; }

.bar-list{ display:flex; flex-direction:column; gap:12px; }
.bar-row{ display:flex; align-items:center; gap:10px; font-size:.84rem; font-weight:600; }
.bar-row .nm{ width:120px; flex:0 0 auto; }
.bar-track{ flex:1; height:9px; border-radius:30px; background:var(--line); overflow:hidden; }
.bar-fill{ height:100%; border-radius:30px; }

/* mobile bottom nav */
.bottom-nav{ display:none; }

/* ---------- Responsive ---------- */
@media (max-width:1480px){ :root{ --rail-w:280px; } }
@media (max-width:1300px){
  .app{ grid-template-columns: var(--sidebar-w) minmax(0,1fr); }
  .rail{ display:none; }
  .rail.as-block{ display:flex; }
}
@media (max-width:992px){
  :root{ --sidebar-w:0px; }
  .app{ grid-template-columns: minmax(0,1fr); padding:16px; }
  .sidebar{
    position:fixed; left:16px; top:16px; bottom:16px; z-index:1050; width:264px;
    transform:translateX(-115%); transition:transform .3s; height:auto;
  }
  .sidebar.open{ transform:none; }
  .menu-toggle{ display:grid; place-items:center; }
  .backdrop{ position:fixed; inset:0; background:rgba(33,28,58,.4); z-index:1040; display:none; }
  .backdrop.show{ display:block; }
  .track-grid, .cat-grid{ grid-template-columns:repeat(2,1fr); }
  .insight-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .hero{ padding:26px 22px; }
  .hero h2{ font-size:1.55rem; }
  .cat-grid{ grid-template-columns:repeat(2,1fr); }
  .insight-grid{ grid-template-columns:1fr; }
  .track-grid{ grid-template-columns:1fr 1fr; }
  .app{ padding:14px 14px 90px; }
  .bottom-nav{
    display:flex; position:fixed; bottom:0; left:0; right:0; z-index:1030;
    background:#fff; box-shadow:0 -10px 30px -12px rgba(20,90,150,.25);
    justify-content:space-around; padding:10px 8px; border-radius:22px 22px 0 0;
  }
  .bn-item{ border:none; background:none; color:var(--ink-soft); font-size:1.4rem; padding:6px 12px; border-radius:12px; }
  .bn-item.active{ color:var(--indigo); background:var(--indigo-soft); }
  .tbl-wrap{ width:100%; overflow-x:auto; }
}

/* ===== Animated horizontal status bar (Track page) ===== */
.statusbar{ position:relative; display:flex; justify-content:space-between; margin:34px 6px 10px; }
.statusbar::before{ content:""; position:absolute; top:19px; left:18px; right:18px; height:5px; background:var(--line); border-radius:10px; }
.statusbar .sb-fill{ position:absolute; top:19px; left:18px; height:5px; border-radius:10px; background:linear-gradient(90deg,var(--indigo),var(--coral)); width:var(--p,0); transition:width 1.3s cubic-bezier(.4,0,.2,1); }
.statusbar.is-rejected .sb-fill{ background:linear-gradient(90deg,var(--rose),#ff8fa3); }
.sb-step{ position:relative; z-index:2; text-align:center; flex:1; }
.sb-dot{ width:42px; height:42px; border-radius:50%; background:#fff; border:3px solid var(--line); display:grid; place-items:center; margin:0 auto 9px; color:var(--ink-soft); font-size:1.05rem; transition:.4s; }
.sb-step.done .sb-dot{ background:var(--green); border-color:var(--green); color:#fff; }
.sb-step.active .sb-dot{ background:var(--coral); border-color:var(--coral); color:#fff; animation:sbpulse 1.6s infinite; }
.sb-step.rejected .sb-dot{ background:var(--rose); border-color:var(--rose); color:#fff; }
@keyframes sbpulse{ 0%{box-shadow:0 0 0 0 rgba(35,179,137,.55)} 70%{box-shadow:0 0 0 14px rgba(35,179,137,0)} 100%{box-shadow:0 0 0 0 rgba(35,179,137,0)} }
.sb-lbl{ font-size:.76rem; font-weight:700; color:var(--ink); }
.sb-time{ font-size:.68rem; color:var(--ink-soft); margin-top:2px; }
@media (max-width:640px){ .sb-lbl{ font-size:.64rem; } .sb-dot{ width:34px; height:34px; } }

/* ===== Extra mobile responsiveness pass ===== */
@media (max-width:992px){
  .topbar{ gap:10px; }
  .statusbar{ flex-wrap:nowrap; overflow-x:auto; gap:6px; }
}
@media (max-width:768px){
  .page-title{ font-size:1.4rem; }
  .hero h2{ font-size:1.5rem; }
  .track-grid{ grid-template-columns:1fr 1fr; }
  .insight-grid{ grid-template-columns:1fr 1fr; }
  .kpi-val{ font-size:1.4rem; }
  /* horizontal status bar -> vertical on small screens to avoid overlap */
  .statusbar{ flex-direction:column; align-items:flex-start; gap:0; padding-left:6px; }
  .statusbar::before{ left:24px; right:auto; top:8px; bottom:8px; width:4px; height:auto; }
  .statusbar .sb-fill{ left:24px; top:8px; width:4px !important; height:var(--p,0); transition:height 1.2s ease; }
  .sb-step{ display:flex; align-items:center; gap:12px; text-align:left; width:100%; margin-bottom:12px; flex:none; }
  .sb-dot{ margin:0; width:36px; height:36px; }
  .sb-lbl, .sb-time{ text-align:left; }
}
@media (max-width:640px){
  .insight-grid{ grid-template-columns:1fr; }
  .track-grid, .cat-grid{ grid-template-columns:1fr 1fr; }
  .searchbar input{ font-size:.85rem; }
  .card-x{ padding:16px; }
  .hero{ padding:22px 18px; }
  table.tbl{ min-width:560px; }   /* keep columns readable; tbl-wrap scrolls */
  .page-sub{ font-size:.85rem; }
  .btn-coral, .btn-apply{ width:100%; justify-content:center; }
  .d-flex.gap-2.flex-wrap > .btn-coral, .d-flex.gap-2.flex-wrap > .btn-apply{ width:auto; }
}

/* ===== Small-laptop polish (1024–1400) ===== */
@media (max-width:1400px) and (min-width:1024px){
  .course-body{ padding:14px; }
  .tbl td, .tbl th{ font-size:.82rem; }
}
.course-banner{ background-size:cover; background-position:center; }

/* ===== 3D resume-scanning loader ===== */
.scan-overlay{ position:fixed; inset:0; z-index:9999; display:none; flex-direction:column;
  align-items:center; justify-content:center; gap:16px;
  background:rgba(16,12,40,.58); backdrop-filter:blur(9px); -webkit-backdrop-filter:blur(9px); }
.scan-overlay.show{ display:flex; animation:fadeIn .25s ease; }
@keyframes fadeIn{ from{opacity:0} to{opacity:1} }
.scan-stage{ perspective:700px; margin-bottom:6px; }
.cube3d{ width:84px; height:84px; position:relative; transform-style:preserve-3d;
  animation:cubespin 2.6s infinite linear; }
.cube3d span{ position:absolute; width:84px; height:84px; border-radius:14px;
  background:linear-gradient(135deg, rgba(29,142,203,.92), rgba(35,179,137,.92));
  border:2px solid rgba(255,255,255,.55); box-shadow:0 0 28px rgba(20,90,150,.55);
  display:flex; align-items:center; justify-content:center; }
.cube3d span:nth-child(1){ transform:rotateY(0deg)   translateZ(42px); }
.cube3d span:nth-child(2){ transform:rotateY(90deg)  translateZ(42px); }
.cube3d span:nth-child(3){ transform:rotateY(180deg) translateZ(42px); }
.cube3d span:nth-child(4){ transform:rotateY(-90deg) translateZ(42px); }
.cube3d span:nth-child(5){ transform:rotateX(90deg)  translateZ(42px); }
.cube3d span:nth-child(6){ transform:rotateX(-90deg) translateZ(42px); }
@keyframes cubespin{ 0%{transform:rotateX(-22deg) rotateY(0)} 100%{transform:rotateX(-22deg) rotateY(360deg)} }
.scan-text{ color:#fff; font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:1.25rem; letter-spacing:-.02em; }
.scan-sub{ color:rgba(255,255,255,.82); font-size:.86rem; }

/* ===== Floating Trybinc Assistant ===== */
.ai-fab{ position:fixed; right:24px; bottom:24px; z-index:1200; width:60px; height:60px; border:none;
  border-radius:50%; cursor:pointer; color:#fff; font-size:1.5rem;
  background:linear-gradient(135deg,var(--indigo),var(--green));
  box-shadow:0 12px 30px rgba(20,90,150,.45); transition:transform .15s ease, box-shadow .15s ease; }
.ai-fab:hover{ transform:translateY(-2px) scale(1.04); box-shadow:0 16px 36px rgba(20,90,150,.55); }
.ai-fab:active{ transform:scale(.96); }
.ai-chat{ position:fixed; right:24px; bottom:96px; z-index:1200; width:370px; max-width:calc(100vw - 32px);
  height:520px; max-height:calc(100vh - 130px); background:var(--card); border-radius:22px;
  box-shadow:0 24px 60px rgba(20,16,50,.28); display:flex; flex-direction:column; overflow:hidden;
  opacity:0; transform:translateY(16px) scale(.98); pointer-events:none; transition:all .22s cubic-bezier(.2,.8,.2,1); }
.ai-chat.show{ opacity:1; transform:none; pointer-events:auto; }
.ai-head{ background:linear-gradient(135deg,var(--indigo),var(--coral)); color:#fff; padding:14px 16px;
  display:flex; align-items:center; justify-content:space-between; }
.ai-head-l{ display:flex; align-items:center; gap:10px; }
.ai-ava{ width:38px; height:38px; border-radius:12px; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.ai-title{ font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:1rem; }
.ai-status{ font-size:.74rem; opacity:.9; }
.ai-x{ background:rgba(255,255,255,.18); border:none; color:#fff; width:32px; height:32px; border-radius:10px; cursor:pointer; }
.ai-body{ flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:10px; background:var(--bg); }
.ai-msg{ max-width:84%; padding:10px 13px; border-radius:14px; font-size:.86rem; line-height:1.5; font-weight:500; word-wrap:break-word; }
.ai-msg.bot{ background:#fff; color:var(--ink); align-self:flex-start; border:1px solid var(--line); border-bottom-left-radius:5px; }
.ai-msg.user{ background:linear-gradient(135deg,var(--indigo),#5AB0E0); color:#fff; align-self:flex-end; border-bottom-right-radius:5px; }
.ai-msg a{ color:var(--indigo); font-weight:700; }
.ai-msg.user a{ color:#fff; text-decoration:underline; }
.ai-typing{ display:inline-flex; gap:4px; }
.ai-typing span{ width:7px; height:7px; border-radius:50%; background:var(--ink-soft); animation:aiblink 1.2s infinite both; }
.ai-typing span:nth-child(2){ animation-delay:.2s; } .ai-typing span:nth-child(3){ animation-delay:.4s; }
@keyframes aiblink{ 0%,80%,100%{opacity:.2} 40%{opacity:1} }
.ai-contact{ font-size:.74rem; color:var(--ink-soft); padding:8px 14px; background:var(--card); border-top:1px solid var(--line); }
.ai-contact a{ color:var(--indigo); font-weight:700; }
.ai-input{ display:flex; gap:8px; padding:12px 14px; background:var(--card); border-top:1px solid var(--line); }
.ai-input input{ flex:1; border:1.5px solid var(--line); border-radius:12px; padding:11px 14px; font-size:.88rem; outline:none; }
.ai-input input:focus{ border-color:var(--indigo); }
.ai-input button{ border:none; background:linear-gradient(135deg,var(--indigo),var(--coral)); color:#fff; width:46px; border-radius:12px; cursor:pointer; font-size:1rem; }
@media (max-width:640px){
  .ai-fab{ right:16px; bottom:84px; width:54px; height:54px; font-size:1.3rem; }
  .ai-chat{ right:12px; left:12px; bottom:78px; width:auto; height:70vh; }
}

/* ===== Blinking announcement bar + Ask modal ===== */
.top-ann{ position:sticky; top:0; z-index:1100; cursor:pointer;
  background:linear-gradient(90deg,var(--indigo),var(--green)); color:#fff;
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:9px 16px; font-size:.88rem; text-align:center; }
.top-ann .ann-txt b{ text-decoration:underline; }
.top-ann .ann-dot{ width:10px; height:10px; border-radius:50%; background:#FFD84D; box-shadow:0 0 0 0 rgba(255,216,77,.7); animation:annblink 1.1s infinite; flex:0 0 auto; }
@keyframes annblink{ 0%{opacity:1; box-shadow:0 0 0 0 rgba(255,216,77,.7)} 70%{opacity:.4; box-shadow:0 0 0 8px rgba(255,216,77,0)} 100%{opacity:1; box-shadow:0 0 0 0 rgba(255,216,77,0)} }
.ask-overlay{ position:fixed; inset:0; z-index:1300; display:none; align-items:center; justify-content:center; padding:18px; background:rgba(16,12,40,.5); backdrop-filter:blur(5px); }
.ask-overlay.show{ display:flex; animation:fadeIn .2s ease; }
.ask-card{ background:var(--card); width:100%; max-width:440px; border-radius:22px; box-shadow:0 30px 70px -30px rgba(20,90,150,.5); overflow:hidden; }
.ask-head{ background:linear-gradient(135deg,var(--indigo),var(--green)); color:#fff; padding:14px 18px; display:flex; align-items:center; justify-content:space-between; font-family:'Bricolage Grotesque',sans-serif; font-weight:800; }
.ask-x{ background:rgba(255,255,255,.18); border:none; color:#fff; width:32px; height:32px; border-radius:10px; cursor:pointer; }
#askBody{ padding:18px; }
@media (max-width:640px){ .top-ann{ font-size:.78rem; padding:8px 12px; } }
