/* ================================================================
   KLiC Courses Platform — style.css
   MKCL | Gateway to Knowledge Lit Careers
   ================================================================
   This file is auto-generated from the platform design system.
   Edit via admin.html > Logo Manager > CSS Variables section.
   ================================================================ */

/* Admin-editable logo size classes */
.logo-size-small  { height: 32px !important; }
.logo-size-medium { height: 46px !important; }
.logo-size-large  { height: 58px !important; }

/* Admin-editable brand color overrides — set via admin panel */
/* These vars can be overridden via the admin color picker */


/* ── ROOT ── */
:root{
  /* ── Exact KLiC/MKCL Brand Palette ── */
  /* Orange  — KLiC top-right triangle + MKCL wordmark */
  --orange:#F4821F; --orange-d:#D4680A; --orange-l:#FEF3E8; --orange-m:#FCDDB4;
  /* Hot Pink/Magenta — KLiC top-left triangle */
  --pink:#ED1651;   --pink-d:#C00D3C;   --pink-l:#FEE8EF;
  /* Royal Blue/Indigo — KLiC left dominant triangle */
  --blue:#2E3192;   --blue-d:#1E215E;   --blue-l:#ECEEFF;
  /* Purple — KLiC center-left triangle */
  --purple:#9A238D; --purple-l:#F8EAFF;
  /* Alias: nav/hero dark bg uses blue-d */
  --navy:#1E215E;   --navy-m:#2E3192;   --navy-l:#ECEEFF;
  /* red alias keeps existing refs from breaking */
  --red:#ED1651;    --red-d:#C00D3C;    --red-l:#FEE8EF;   --red-m:#FCDDE6;
  /* Supporting */
  --teal:#0D7377;   --teal-l:#E0F5F5;
  --gold:#FFAA20;   --gold-l:#FFF9E8;
  --green:#15803D;  --green-l:#F0FDF4;
  --amber:#D97706;  --amber-l:#FFFBEB;
  /* Neutrals — cool white bg to complement the blue-dominant palette */
  --bg:#F4F6FF;     --white:#fff;       --border:#E0E3F0;
  --text:#1A1C4B;   --muted:#5B6080;    --dim:#9CA3AF;
  --sh:0 2px 16px rgba(46,49,146,.1);   --sh2:0 8px 40px rgba(46,49,146,.18);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}
button,select,input{font-family:inherit}

/* ── TOPBAR ── */
.topbar{background:linear-gradient(90deg,var(--navy) 0%,var(--blue) 100%);min-height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(.75rem,2vw,1.5rem);position:sticky;top:0;z-index:500;box-shadow:0 3px 20px rgba(30,33,94,.5);gap:.5rem;flex-wrap:nowrap}
.brand,.brand-wrap{display:flex;align-items:center;flex-shrink:0;min-width:0}
.brand-img{height:clamp(32px,5.5vw,46px);width:auto !important;max-width:none;object-fit:contain;object-position:left center;display:block;aspect-ratio:auto;padding:4px; background-color: #fff;border-radius: 6px;}


.tabs{display:flex;gap:1px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;min-width:0}
.tab{padding:6px 14px;border-radius:8px;border:none;background:transparent;color:rgba(255,255,255,.55);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .17s;white-space:nowrap;display:flex;align-items:center;gap:6px;font-family:inherit}
.tab:hover{background:rgba(244,130,31,.18);color:var(--orange)}
.tab.on{background:var(--orange);color:#fff;box-shadow:0 0 16px rgba(244,130,31,.55)}
.tab .gem{font-size:13px}
.nav-pill{background:rgba(244,130,31,.15);border:1px solid rgba(244,130,31,.3);color:var(--orange);font-size:.67rem;font-weight:700;padding:4px 12px;border-radius:100px;flex-shrink:0;white-space:nowrap}

/* ── PANES ── */
.pane{display:none;height:calc(100vh - 66px);overflow-y:auto;overflow-x:hidden}
.pane.on{display:block}
.pane::-webkit-scrollbar{width:5px}
.pane::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}

/* ── SHARED ── */
.sec{max-width:1260px;margin:0 auto;padding:2rem 1.5rem}
.sec-hdr{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1.1rem}
.sec-hdr h2{font-family:Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.4rem;font-weight:700}
.sec-hdr h2 em{color:var(--orange);font-style:normal}
.see-all{font-size:.76rem;color:var(--orange);font-weight:700;cursor:pointer;background:none;border:none}
.btn-r{padding:9px 20px;background:linear-gradient(135deg,var(--orange),var(--orange-d));color:#fff;border:none;border-radius:9px;font-size:.81rem;font-weight:700;cursor:pointer;transition:all .17s;box-shadow:0 4px 18px rgba(244,130,31,.45)}
.btn-r:hover{background:linear-gradient(135deg,var(--orange-d),#B45309);transform:translateY(-2px);box-shadow:0 6px 20px rgba(247,147,30,.5)}
.btn-w{padding:9px 20px;background:transparent;color:rgba(255,255,255,.75);border:1.5px solid rgba(255,255,255,.22);border-radius:9px;font-size:.81rem;font-weight:600;cursor:pointer;transition:all .17s}
.btn-w:hover{background:rgba(255,255,255,.07)}

/* ── HOME ── */
.hero{background:linear-gradient(135deg,var(--navy) 0%,var(--blue-d) 45%,#12103C 100%);padding:2.5rem 1.5rem 0;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 8% 55%,rgba(237,22,81,.18),transparent 48%),radial-gradient(ellipse at 82% 12%,rgba(244,130,31,.16),transparent 45%),radial-gradient(ellipse at 55% 95%,rgba(154,35,141,.12),transparent 55%);pointer-events:none}
.hdots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.03) 1px,transparent 1px);background-size:26px 26px;pointer-events:none}
.hero-in{max-width:1260px;margin:0 auto;position:relative;z-index:1}
.hero-row{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;padding-bottom:2rem;flex-wrap:wrap}
.hero-logo-wrap{margin-bottom:1.2rem}
.hero-logo-img{height:clamp(48px,8vw,82px);width:auto !important;max-width:none;object-fit:contain;display:block;filter:drop-shadow(0 2px 8px rgba(0,0,0,.25));aspect-ratio:auto; padding:8px 6px; background-color: #fff;border-radius: 8px;}
.hero-tagline-txt{font-size:.6rem;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:.3rem}
.hero-text h1{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:clamp(1.8rem,4vw,2.9rem);font-weight:700;color:#fff;line-height:1.1;letter-spacing:-.5px;margin-bottom:.55rem}
.hero-text h1 span{color:var(--orange)}
.hero-text p{font-size:.88rem;color:rgba(255,255,255,.48);max-width:460px;line-height:1.7;font-weight:300}
.hcta{display:flex;gap:9px;margin-top:1.2rem;flex-wrap:wrap}
.hstats{display:flex;gap:1.6rem;flex-wrap:wrap;align-items:flex-end}
.hs{text-align:center}
.hs-n{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.75rem;font-weight:700;color:var(--orange);line-height:1;text-shadow:0 0 20px rgba(244,130,31,.4)}
.hs-l{font-size:.6rem;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.dur-pills{display:flex;flex-direction:column;gap:3px;align-items:center}
.dur-pill{background:rgba(244,130,31,.18);color:var(--orange);border:1px solid rgba(244,130,31,.3);padding:2px 7px;border-radius:100px;font-size:.64rem;font-weight:700;white-space:nowrap}
.hbar{height:5px;background:linear-gradient(90deg,var(--blue),var(--pink),var(--orange),var(--gold),var(--purple))}

/* ── START HERE BANNER ── */
.start-here-banner{background:linear-gradient(90deg,#fff8f0,#fff3fb);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:.75rem 1.5rem}
.sh-inner{max-width:1260px;margin:0 auto;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.sh-icon{font-size:1.3rem;flex-shrink:0}
.sh-text{font-size:.82rem;color:var(--muted);line-height:1.6}
.sh-text strong{color:var(--text)}
.sh-btn{background:var(--navy);color:#fff;border:none;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s;margin:0 2px}
.sh-btn:hover{background:var(--red)}

/* ── Expanding Track Cards ── */
.track-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.track-card{background:#fff;border-radius:16px;border:1.5px solid var(--border);cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;display:flex;flex-direction:column}
.track-card::after{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--tc,var(--blue));transition:height .25s ease}
.track-card:hover{border-color:var(--tc,var(--orange));box-shadow:0 4px 16px rgba(0,0,0,.07);transform:translateY(-2px)}
.track-card.expanded{border-color:var(--tc,var(--orange));box-shadow:0 8px 32px rgba(0,0,0,.12);transform:translateY(-4px)}
.track-card:hover::after{height:5px}
.track-card.expanded::after{height:6px}
.tc-head{padding:1.1rem 1.1rem .7rem;display:flex;align-items:flex-start;gap:.7rem}
.ti{font-size:2rem;flex-shrink:0;line-height:1;margin-top:2px}
.tc-meta{flex:1;min-width:0}
.tn{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1rem;font-weight:700;line-height:1.2;color:var(--text)}
.tc-cnt{font-size:.68rem;color:var(--muted);margin-top:2px}
.tc-arrow{font-size:.75rem;color:var(--muted);margin-left:auto;transition:transform .3s ease;flex-shrink:0;margin-top:3px}
.track-card.expanded .tc-arrow{transform:rotate(180deg)}
.tc-body{max-height:0;overflow:hidden;visibility:hidden;transition:max-height .45s ease,padding .3s ease,visibility 0s .45s;padding:0 1.1rem}
.track-card.expanded .tc-body{max-height:800px;padding:0 1.1rem .9rem;visibility:visible;transition:max-height .45s ease,padding .3s ease,visibility 0s 0s}
.tc-desc{font-size:.76rem;color:var(--muted);line-height:1.6;margin-bottom:.75rem;border-top:1px solid var(--border);padding-top:.7rem}
.tc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:.8rem}
.ttag{padding:3px 9px;border-radius:100px;font-size:.63rem;font-weight:600;background:var(--bg);color:var(--muted);border:1px solid var(--border)}
.tc-sample{margin-bottom:.75rem}
.tc-sample-lbl{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--dim);margin-bottom:.35rem}
.tc-sample-course{font-size:.73rem;color:var(--text);padding:3px 0;display:flex;align-items:center;gap:5px;line-height:1.3}
.tc-sample-course::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--tc,var(--orange));flex-shrink:0}
.tc-explore{display:block;width:100%;padding:7px;background:var(--tc,var(--orange));color:#fff;border:none;border-radius:9px;font-family:'Plus Jakarta Sans',sans-serif;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .18s;text-align:center}
.tc-explore:hover{opacity:.88;transform:translateY(-1px)}

.qa-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:.8rem}
.qa{background:#fff;border-radius:12px;padding:1.1rem;border:1.5px solid var(--border);cursor:pointer;display:flex;align-items:center;gap:11px;transition:all .2s}
.qa:hover{box-shadow:var(--sh2);transform:translateY(-2px);border-color:var(--orange)}
.qa-ico{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.qa-text h4{font-size:.84rem;font-weight:700;margin-bottom:1px}
.qa-text p{font-size:.7rem;color:var(--muted);line-height:1.4}

/* ── COURSES ── */
.crs-layout{display:flex;align-items:flex-start;max-width:1260px;margin:0 auto;padding:0 1.5rem 3rem}
.sidebar{width:225px;flex-shrink:0;padding:1.3rem 1.2rem 1.3rem 0;border-right:1px solid var(--border)}
.cmain{flex:1;padding:1.3rem 0 0 1.5rem;min-width:0}
.fslbl{font-size:.66rem;font-weight:700;color:var(--dim);letter-spacing:1.4px;text-transform:uppercase;margin-bottom:7px;display:flex;justify-content:space-between;align-items:center}
.fs-clr{font-size:.66rem;color:var(--orange-d);cursor:pointer;font-weight:600;background:none;border:none}
.fsec{margin-bottom:1.2rem}
.fsopt{display:flex;align-items:center;gap:7px;padding:5px 8px;border-radius:7px;cursor:pointer;font-size:.77rem;color:var(--muted);transition:all .13s;user-select:none;margin-bottom:1px}
.fsopt:hover{background:var(--bg);color:var(--text)}
.fsopt.on{background:var(--orange-l);color:var(--orange-d);font-weight:600}
.pills{display:flex;flex-wrap:wrap;gap:4px}
.dc{padding:4px 10px;border-radius:100px;border:1.5px solid var(--border);background:#fff;font-size:.7rem;font-weight:700;cursor:pointer;color:var(--muted);transition:all .15s}
.dc.on,.dc:hover{background:var(--orange);color:#fff;border-color:var(--orange-d)}
.lc{padding:4px 10px;border-radius:100px;border:1.5px solid var(--border);background:#fff;font-size:.7rem;font-weight:700;cursor:pointer;color:var(--muted);transition:all .15s}
.lc.on,.lc:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.lgc{padding:4px 10px;border-radius:100px;border:1.5px solid var(--border);background:#fff;font-size:.7rem;font-weight:700;cursor:pointer;color:var(--muted);transition:all .15s;display:inline-block}
.lgc.on,.lgc:hover{background:var(--red);color:#fff;border-color:var(--red)}
.ctop{display:flex;justify-content:space-between;align-items:center;margin-bottom:.9rem;flex-wrap:wrap;gap:8px}
.srch{display:flex;align-items:center;gap:7px;background:#fff;border:1.5px solid var(--border);border-radius:9px;padding:6px 11px;min-width:230px;transition:border-color .17s}
.srch:focus-within{border-color:var(--red)}
.srch input{background:none;border:none;outline:none;font-size:.81rem;color:var(--text);flex:1}
.srch input::placeholder{color:var(--dim)}
.cinfo{font-size:.78rem;color:var(--muted)}
.cinfo strong{color:var(--text);font-weight:700}
.sort-s{background:#fff;border:1.5px solid var(--border);border-radius:8px;padding:6px 9px;font-size:.77rem;color:var(--text);cursor:pointer;outline:none}
.chips{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:.8rem;min-height:1px}
.ac{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--red-l);border:1px solid var(--red-m);border-radius:100px;font-size:.68rem;color:var(--red);font-weight:600}
.ac button{background:none;border:none;color:var(--red);cursor:pointer;font-size:9px;padding:0;line-height:1}
.cgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.85rem}
.cc{background:#fff;border-radius:12px;border:1.5px solid var(--border);overflow:hidden;transition:all .22s;display:flex;flex-direction:column}
.cc:hover{border-color:rgba(200,16,46,.25);box-shadow:0 7px 28px rgba(11,31,58,.1);transform:translateY(-2px)}
.cthumb{height:95px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.cemoji{font-size:2.4rem}
.bl{position:absolute;top:7px;left:7px;padding:2px 7px;border-radius:100px;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.blB{background:rgba(22,163,74,.87);color:#fff}
.blF{background:rgba(37,99,235,.87);color:#fff}
.blI{background:rgba(217,119,6,.87);color:#fff}
.blA{background:rgba(200,16,46,.87);color:#fff}
.bd{position:absolute;top:7px;right:7px;background:rgba(0,0,0,.58);color:#fff;padding:2px 7px;border-radius:100px;font-size:.58rem;font-weight:600}
.cbody{padding:9px 11px;flex:1;display:flex;flex-direction:column;gap:3px}
.ctrack{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--dim)}
.cname{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.9rem;font-weight:700;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cc120{font-size:.67rem;color:var(--muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ctags{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}
.ctag{padding:1px 5px;border-radius:4px;font-size:.58rem;font-weight:600;background:var(--bg);color:var(--muted);border:1px solid var(--border)}
.cfoot{display:flex;align-items:center;justify-content:space-between;padding:6px 11px;border-top:1px solid var(--border);background:#fafbfc;flex-shrink:0}
.clang{font-size:.62rem;color:var(--dim)}
.cmpbtn{padding:4px 10px;background:var(--navy);color:#fff;border:none;border-radius:6px;font-size:.67rem;font-weight:700;cursor:pointer;transition:all .17s}
.cmpbtn:hover{background:var(--red)}
.cmpbtn.added{background:var(--green)}
.empty-state{text-align:center;padding:3rem;display:none}
.empty-state.show{display:block}

/* ── GAME ── */
.game-pane{background:var(--bg)}
.game-hero{background:linear-gradient(135deg,var(--navy) 0%,#1a1860 55%,#0F0D3A 100%);padding:2rem 1.5rem;position:relative;overflow:hidden}
.game-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 60%,rgba(105,65,198,.25),transparent 55%),radial-gradient(ellipse at 80% 20%,rgba(200,16,46,.15),transparent 50%);pointer-events:none}
.game-hero-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:22px 22px;pointer-events:none}
.gh-in{max-width:1260px;margin:0 auto;position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.gh-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(105,65,198,.25);border:1px solid rgba(105,65,198,.4);color:#c4b5fd;font-size:.64rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 11px;border-radius:100px;margin-bottom:.8rem}
.gh-title{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;color:#fff;line-height:1.1;margin-bottom:.5rem}
.gh-title span{color:#c084fc}
.gh-desc{font-size:.85rem;color:rgba(255,255,255,.5);max-width:420px;line-height:1.7;font-weight:300}
.gh-right{display:flex;flex-direction:column;align-items:flex-end;gap:.8rem}
.gbar{height:3px;background:linear-gradient(90deg,var(--orange-d),var(--orange),#c084fc,var(--red))}

/* Game progress nav */
.game-progress{max-width:1260px;margin:0 auto;padding:1.2rem 1.5rem .5rem;display:flex;align-items:center;gap:.5rem;overflow-x:auto}
.gp-step{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.gp-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;color:var(--muted);transition:all .3s;cursor:default;flex-shrink:0}
.gp-dot.done{background:var(--green);border-color:var(--green);color:#fff}
.gp-dot.active{background:var(--orange-l);border-color:var(--orange);color:var(--orange-d);box-shadow:0 0 0 3px rgba(247,147,30,.15)}
.gp-line{width:28px;height:2px;background:var(--border);border-radius:1px;flex-shrink:0}
.gp-line.done{background:var(--orange-d)}
.gp-label{font-size:.62rem;color:var(--muted);white-space:nowrap;display:none}

/* Game stages */
.stage{display:none;max-width:1260px;margin:0 auto;padding:1.5rem 1.5rem 3rem}
.stage.on{display:block}

/* Stage 0: Welcome */
.welcome-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem}
.wcard{background:rgba(255,255,255,.08);border-radius:14px;border:1px solid rgba(255,255,255,.12);padding:1.4rem;text-align:center;position:relative;overflow:hidden}
.wcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--wc,var(--orange-d))}
.wcard-ico{font-size:2.2rem;margin-bottom:.7rem}
.wcard h3{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1rem;font-weight:700;margin-bottom:.4rem}
.wcard p{font-size:.74rem;color:var(--muted);line-height:1.5}
.start-btn{display:block;width:100%;padding:13px;background:linear-gradient(135deg,var(--orange),var(--pink));color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;letter-spacing:.5px;margin-top:1.5rem}
.start-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(247,147,30,.35)}

/* Stage question cards */
.qstage-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.3rem;gap:1rem;flex-wrap:wrap}
.qstage-meta{display:flex;flex-direction:column;gap:.3rem}
.qstage-num{font-size:.68rem;font-weight:700;color:var(--purple);text-transform:uppercase;letter-spacing:1px}
.qstage-title{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.5rem;font-weight:700;line-height:1.2}
.qstage-sub{font-size:.83rem;color:var(--muted);line-height:1.6;max-width:520px}
.qprogbar{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:.9rem 1.2rem;display:flex;align-items:center;gap:1rem;min-width:200px}
.qprogbar-track{flex:1;height:8px;background:var(--bg);border-radius:4px;overflow:hidden}
.qprogbar-fill{height:100%;background:linear-gradient(90deg,var(--orange),var(--pink));border-radius:4px;transition:width .4s ease}
.qprogbar-pct{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.9rem;font-weight:700;color:var(--purple);min-width:32px;text-align:right}

/* Choice cards — the main game mechanic */
.choice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.85rem;margin-bottom:1.5rem}
.choice{background:#fff;border-radius:14px;border:2px solid var(--border);padding:1.2rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;text-align:left}
.choice::before{content:'';position:absolute;top:0;left:0;bottom:0;width:4px;background:var(--cc,var(--orange-d));transition:width .2s}
.choice:hover{border-color:var(--orange-d);box-shadow:0 4px 20px rgba(247,147,30,.12)}
.choice:hover::before{width:6px}
.choice.picked{border-color:var(--orange-d);background:var(--purple-l);box-shadow:0 4px 20px rgba(247,147,30,.15)}
.choice.picked::before{width:100%;background:rgba(247,147,30,.04)}
.choice.picked .choice-check{opacity:1;transform:scale(1)}
.choice.correct{border-color:var(--green);background:var(--green-l)}
.choice.correct::before{background:var(--green);width:6px}
.choice.wrong{border-color:var(--red);background:var(--red-l)}
.choice.wrong::before{background:var(--red);width:6px}
.choice-ico{font-size:2rem;margin-bottom:.7rem;display:block}
.choice-lbl{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.98rem;font-weight:700;margin-bottom:.3rem;line-height:1.2}
.choice-desc{font-size:.72rem;color:var(--muted);line-height:1.4}
.choice-check{position:absolute;top:10px;right:10px;width:20px;height:20px;border-radius:50%;background:var(--orange-d);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.65rem;opacity:0;transform:scale(.5);transition:all .2s}
.choice-pts{position:absolute;bottom:8px;right:10px;font-size:.63rem;font-weight:700;color:var(--purple);opacity:.7}

/* Stage navigation */
.stage-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.snav-info{font-size:.78rem;color:var(--muted)}
.btn-game{padding:10px 22px;background:linear-gradient(135deg,var(--orange),var(--orange-d));color:#fff;border:none;border-radius:10px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .18s}
.btn-game:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(247,147,30,.4)}
.btn-game:disabled{opacity:.35;pointer-events:none}
.btn-ghost{padding:10px 20px;background:transparent;color:var(--muted);border:1.5px solid var(--border);border-radius:10px;font-size:.83rem;font-weight:600;cursor:pointer;transition:all .17s}
.btn-ghost:hover{border-color:var(--text);color:var(--text)}

/* Feedback popup */
.feedback{display:none;background:#fff;border-radius:14px;border:2px solid var(--border);padding:1.3rem 1.5rem;margin-bottom:1.3rem;position:relative;overflow:hidden}
.feedback.show{display:flex;align-items:flex-start;gap:1rem;animation:slideDown .3s ease}
.feedback::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--fb-color,var(--orange-d))}
.feedback-ico{font-size:2rem;flex-shrink:0}
.feedback-title{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1rem;font-weight:700;margin-bottom:.3rem}
.feedback-txt{font-size:.8rem;color:var(--muted);line-height:1.5}
.feedback.correct-fb::before{background:var(--green)}
.feedback.wrong-fb::before{background:var(--red)}
.feedback.info-fb::before{background:var(--orange-d)}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* Career path reveal */
.path-card{background:#fff;border-radius:16px;border:1.5px solid var(--border);padding:1.5rem;margin-bottom:1rem;position:relative;overflow:hidden}
.path-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--blue),var(--pink),var(--orange))}
.path-icon{font-size:2.5rem;margin-bottom:.7rem}
.path-title{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.4rem;font-weight:700;margin-bottom:.4rem}
.path-desc{font-size:.83rem;color:var(--muted);line-height:1.6;margin-bottom:1rem}
.path-tracks{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.path-track-badge{padding:4px 12px;border-radius:100px;font-size:.72rem;font-weight:700;background:var(--orange-l);color:var(--orange-d);border:1px solid rgba(247,147,30,.25)}
.path-cta{display:flex;gap:.7rem;flex-wrap:wrap}

/* Course recommendation cards for game */
.grec-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.85rem;margin-top:1rem}
.grec{background:#fff;border-radius:13px;border:1.5px solid var(--border);padding:1.1rem;position:relative;overflow:hidden;transition:all .2s}
.grec::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--gc,var(--orange-d))}
.grec:hover{border-color:rgba(247,147,30,.3);box-shadow:0 5px 20px rgba(247,147,30,.1)}
.grec-rank{position:absolute;top:10px;right:10px;font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.75rem;font-weight:700;background:var(--purple-l);color:var(--purple);border:1px solid rgba(247,147,30,.2);padding:2px 8px;border-radius:100px}
.grec-track{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--dim);margin-bottom:3px}
.grec-name{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.9rem;font-weight:700;line-height:1.3;margin-bottom:.4rem;padding-right:50px}
.grec-meta{display:flex;flex-wrap:wrap;gap:.4rem}
.grec-badge{padding:2px 7px;border-radius:4px;font-size:.62rem;font-weight:700}
.grec-match{background:var(--orange-l);color:var(--orange-d)}
.grec-dur{background:var(--navy-l);color:var(--navy-m)}
.grec-lv{background:var(--green-l);color:var(--green)}

/* Score summary */
.score-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.8rem;margin-bottom:1.5rem}
.scard{background:#fff;border-radius:12px;border:1.5px solid var(--border);padding:1rem;text-align:center}
.scard-n{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.8rem;font-weight:700;line-height:1;color:var(--orange)}
.scard-l{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-top:3px}
.badge-earned{background:var(--orange-l);border:1px solid rgba(247,147,30,.2);border-radius:12px;padding:1rem 1.2rem;display:flex;align-items:center;gap:.9rem;margin-bottom:.8rem}
.badge-ico{font-size:2rem;flex-shrink:0}
.badge-info h4{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.95rem;font-weight:700;color:var(--orange-d);margin-bottom:.2rem}
.badge-info p{font-size:.74rem;color:var(--muted);line-height:1.4}
.action-row{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.5rem}


/* Spin wheel */
.spin-area{text-align:center;margin:1.5rem 0}
.wheel-wrap{position:relative;width:260px;height:260px;margin:0 auto 1rem}
.wheel-svg{width:100%;height:100%;filter:drop-shadow(0 4px 20px rgba(247,147,30,.2))}
.wheel-pointer{position:absolute;top:-10px;left:50%;transform:translateX(-50%);font-size:1.5rem;z-index:2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}
.wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:#fff;border:3px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;text-align:center;line-height:1.2;padding:4px;z-index:2;box-shadow:0 2px 8px rgba(0,0,0,.1);cursor:pointer;transition:all .2s;word-break:break-word}
.wheel-center:hover{transform:translate(-50%,-50%) scale(1.05)}
.spin-btn{padding:11px 32px;background:linear-gradient(135deg,var(--orange),var(--pink));color:#fff;border:none;border-radius:12px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;letter-spacing:.3px}
.spin-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(247,147,30,.3)}
.spin-btn:disabled{opacity:.4;pointer-events:none}
.spin-result{background:var(--purple-l);border:1.5px solid rgba(247,147,30,.2);border-radius:12px;padding:1rem 1.3rem;margin-top:1rem;display:none;animation:slideDown .3s ease}
.spin-result.show{display:block}
.spin-result h4{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1rem;font-weight:700;color:var(--purple);margin-bottom:.3rem}
.spin-result p{font-size:.78rem;color:var(--muted);line-height:1.5}

/* ── COUNSELLING (existing) ── */
.q-wrap{max-width:800px;margin:0 auto;padding:2rem 1.5rem}
.q-hero{background:linear-gradient(135deg,var(--navy),var(--blue));border-radius:16px;padding:1.8rem;margin-bottom:1.3rem;position:relative;overflow:hidden}
.q-hero::after{content:'';position:absolute;right:-25px;top:-25px;width:160px;height:160px;border-radius:50%;background:rgba(200,16,46,.08);pointer-events:none}
.q-hero h2{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.55rem;font-weight:700;color:#fff;margin-bottom:.35rem}
.q-hero p{font-size:.83rem;color:rgba(255,255,255,.5);line-height:1.65;max-width:440px;font-weight:300}
.sp-row{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap}
.sp{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:4px 10px;font-size:.7rem;color:rgba(255,255,255,.65)}
.sp span{background:var(--red);color:#fff;width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:700;flex-shrink:0}
.qcard{background:#fff;border-radius:14px;border:1.5px solid var(--border);overflow:hidden;box-shadow:var(--sh)}
.qprog{height:4px;background:var(--border)}
.qbar{height:100%;background:linear-gradient(90deg,var(--orange),var(--pink));border-radius:4px;transition:width .35s ease}
.qhead{padding:1rem 1.6rem .8rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.qstep{font-size:.7rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:1px}
.qbody{padding:1.6rem}
.qq{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.2rem;font-weight:700;margin-bottom:.25rem;line-height:1.3}
.qsub{font-size:.79rem;color:var(--muted);margin-bottom:1.2rem;line-height:1.5}
.qopts{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.qopts.single{grid-template-columns:1fr}
.qopt{padding:9px 13px;border-radius:9px;border:1.5px solid var(--border);background:#fff;cursor:pointer;text-align:left;font-size:.8rem;color:var(--text);transition:all .15s;display:flex;align-items:center;gap:8px;font-weight:500;width:100%}
.qopt:hover,.qopt.sel{border-color:var(--red);background:var(--red-l);color:var(--red);font-weight:700}
.qopt-i{font-size:1.05rem;flex-shrink:0}
.qfoot{padding:.9rem 1.6rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:#fafbfc}
.btn-nxt{padding:8px 22px;background:linear-gradient(135deg,var(--orange),var(--orange-d));color:#fff;border:none;border-radius:9px;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .17s;opacity:.35;pointer-events:none}
.btn-nxt.rdy{opacity:1;pointer-events:all}
.btn-nxt.rdy:hover{background:var(--red-d)}
.btn-bk{padding:8px 16px;background:transparent;color:var(--muted);border:1.5px solid var(--border);border-radius:9px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .17s}
.btn-bk:hover{border-color:var(--text);color:var(--text)}
.rswrap{display:none}.rswrap.show{display:block}
.rshead{text-align:center;padding:1.5rem 1.6rem 1.1rem;border-bottom:1px solid var(--border)}
.rshead .tro{font-size:2.3rem;margin-bottom:.5rem}
.rshead h3{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}
.rshead p{font-size:.8rem;color:var(--muted);max-width:420px;margin:0 auto;line-height:1.55}
.rs-tags{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-top:.9rem}
.rs-tag{padding:3px 12px;border-radius:100px;font-size:.7rem;font-weight:700;background:var(--navy-l);color:var(--navy);border:1px solid var(--border)}
.rec-list{padding:1.2rem 1.6rem 1.6rem}
.rec-list h4{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.95rem;font-weight:700;margin-bottom:.8rem;color:var(--navy)}
.rc{display:flex;align-items:flex-start;gap:11px;padding:12px;border-radius:11px;border:1.5px solid var(--border);margin-bottom:7px;background:#fff;transition:all .17s}
.rc:hover{border-color:var(--red);box-shadow:0 3px 14px rgba(200,16,46,.06)}
.rc-rank{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.88rem;font-weight:700;flex-shrink:0}
.r1{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}
.r2{background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff}
.r3{background:linear-gradient(135deg,#b45309,#78350f);color:#fff}
.rN{background:var(--navy-l);color:var(--navy)}
.rc-info{flex:1;min-width:0}
.rc-name{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.87rem;font-weight:700;margin-bottom:2px;line-height:1.3}
.rc-meta{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:2px}
.rc-m{font-size:.64rem;color:var(--muted)}
.mbar{display:flex;align-items:center;gap:7px;margin-top:4px}
.mpct{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.79rem;font-weight:700;color:var(--green);min-width:32px}
.mtrack{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.mfill{height:100%;background:linear-gradient(90deg,var(--green),#4ade80);border-radius:2px;transition:width .7s ease .15s}
.rc-act{flex-shrink:0;padding:4px 9px;background:var(--navy);color:#fff;border:none;border-radius:6px;font-size:.67rem;font-weight:700;cursor:pointer;transition:all .17s;align-self:flex-start}
.rc-act:hover{background:var(--red)}
.restart-btn{display:block;margin:1.2rem auto 0;padding:9px 24px;background:transparent;color:var(--red);border:2px solid var(--red);border-radius:9px;font-size:.81rem;font-weight:700;cursor:pointer;transition:all .17s}
.restart-btn:hover{background:var(--red);color:#fff}

/* ── COMPARE ── */
.cmp-wrap{max-width:1260px;margin:0 auto;padding:1.6rem 1.5rem 3rem}
.cmp-hero{background:linear-gradient(135deg,var(--navy),var(--navy-m));border-radius:16px;padding:1.6rem 1.8rem;margin-bottom:1.3rem;display:flex;align-items:flex-start;justify-content:space-between;gap:1.3rem;flex-wrap:wrap}
.cmp-hero h2{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.5rem;font-weight:700;color:#fff}
.cmp-hero p{font-size:.8rem;color:rgba(255,255,255,.46);margin-top:.2rem;line-height:1.55}
.cslots{display:flex;gap:7px;flex-wrap:wrap}
.cslot{min-width:155px;padding:8px 11px;border-radius:9px;border:1.5px dashed rgba(255,255,255,.2);background:rgba(255,255,255,.04);color:rgba(255,255,255,.35);font-size:.72rem;cursor:default;text-align:center;transition:all .17s}
.cslot.filled{border-color:var(--orange);background:rgba(247,147,30,.1);color:var(--text);border-style:solid}
.cslot .csn{font-weight:700;font-size:.76rem;margin-bottom:2px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cslot .css_{font-size:.6rem;opacity:.5}
.cslot .csr{font-size:.64rem;color:rgba(255,150,150,.85);margin-top:3px;cursor:pointer}
.cctrl{background:#fff;border-radius:12px;border:1.5px solid var(--border);padding:.9rem 1.2rem;margin-bottom:1.1rem;display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.csrch{display:flex;align-items:center;gap:7px;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:6px 9px;flex:1;min-width:170px;transition:border-color .17s}
.csrch:focus-within{border-color:var(--red)}
.csrch input{background:none;border:none;outline:none;font-size:.78rem;color:var(--text);flex:1}
.csel{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:6px 9px;font-size:.76rem;color:var(--text);cursor:pointer;outline:none}
.clbl{font-size:.73rem;color:var(--muted);white-space:nowrap}
.pw{background:#fff;border-radius:12px;border:1.5px solid var(--border);overflow:hidden;margin-bottom:1.2rem}
.phdr{padding:.85rem 1.2rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.phdr h4{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.92rem;font-weight:700;color:var(--navy)}
.phdr span{font-size:.72rem;color:var(--muted)}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.45rem;padding:.9rem;max-height:360px;overflow-y:auto}
.pgrid::-webkit-scrollbar{width:4px}
.pgrid::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.pcard{background:var(--bg);border-radius:8px;border:1.5px solid var(--border);padding:8px 10px;cursor:pointer;transition:all .17s;display:flex;align-items:flex-start;gap:7px}
.pcard:hover,.pcard.sel{border-color:var(--red);background:var(--red-l)}
.pck{width:15px;height:15px;border-radius:4px;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .17s;margin-top:1px;font-size:.58rem}
.pcard.sel .pck{background:var(--red);border-color:var(--red);color:#fff}
.pname{font-weight:700;font-size:.74rem;line-height:1.3;color:var(--text)}
.pmeta{font-size:.62rem;color:var(--muted);margin-top:2px;display:flex;gap:4px;flex-wrap:wrap;align-items:center}
.pb{padding:1px 5px;border-radius:3px;font-size:.58rem;font-weight:700}
.pbB{background:rgba(22,163,74,.1);color:#15803d}
.pbF{background:rgba(37,99,235,.1);color:#1d4ed8}
.pbI{background:rgba(217,119,6,.1);color:#b45309}
.pbA{background:rgba(200,16,46,.1);color:var(--red)}
.no-cmp{text-align:center;padding:3rem;color:var(--muted)}
.cmptbl{background:#fff;border-radius:13px;border:1.5px solid var(--border);overflow:auto;box-shadow:var(--sh)}

@media(max-width:840px){
  .crs-layout,.gh-in,.hero-row{flex-direction:column}
  .sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);padding-right:0}
  .cmain{padding-left:0}
  .qopts{grid-template-columns:1fr}
  .trivia-opts{grid-template-columns:1fr}
  .tabs{overflow-x:auto}
  .tab{font-size:.72rem;padding:6px 10px}
}

/* ── Topbar responsive breakpoints ── */
@media(max-width:600px){
  .topbar{min-height:52px;padding:0 .75rem;gap:.25rem}
  .brand-img{height:clamp(28px,7vw,38px);width:auto !important;max-width:none}
  .tab span:not(.gem){display:none}
  .tab{padding:5px 8px;gap:0}
  .nav-pill{display:none}
}
@media(max-width:380px){
  .brand-img{height:28px;width:auto !important;max-width:none}
  .tab{padding:4px 6px;font-size:.7rem}
}

/* ── Result Stage Sections ── */
.res-profile-card{background:#fff;border-radius:18px;border:1.5px solid var(--border);padding:1.5rem;margin-bottom:1.2rem;position:relative;overflow:hidden}
.res-profile-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--blue),var(--pink),var(--orange))}
.res-profile-left{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}
.res-profile-icon{font-size:3rem;line-height:1;flex-shrink:0}
.res-profile-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--orange);margin-bottom:.25rem}
.res-profile-title{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.5rem;font-weight:800;color:var(--text);line-height:1.1;margin-bottom:.4rem}
.res-profile-desc{font-size:.8rem;color:var(--muted);line-height:1.6}
.res-profile-tracks{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.9rem}
.res-profile-tracks .path-track-badge{padding:4px 12px;border-radius:100px;font-size:.7rem;font-weight:700;background:var(--purple-l);color:var(--purple);border:1px solid rgba(247,147,30,.2)}
.res-profile-cta{display:flex;gap:.6rem;flex-wrap:wrap}
.res-section{background:#fff;border-radius:16px;border:1.5px solid var(--border);padding:1.3rem 1.5rem;margin-bottom:1.2rem}
.res-sec-title{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.1rem;font-weight:800;color:var(--text);margin-bottom:.2rem}
.res-sec-sub{font-size:.73rem;color:var(--muted);margin-bottom:1rem}

/* Career Probability Chart */
.prob-chart{display:flex;flex-direction:column;gap:.65rem}
.prob-row{display:grid;grid-template-columns:150px 1fr 44px;align-items:center;gap:.75rem}
.prob-label{font-size:.78rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prob-bar-bg{height:10px;background:var(--bg);border-radius:5px;overflow:hidden;border:1px solid var(--border)}
.prob-bar-fill{height:100%;border-radius:5px;transition:width 1.2s cubic-bezier(.34,1.1,.64,1);width:0%}
.prob-pct{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.85rem;font-weight:700;text-align:right}
.prob-row.top-match .prob-label{color:var(--orange-d)}
.prob-row.top-match .prob-bar-fill{background:linear-gradient(90deg,var(--orange),var(--red))}
.prob-row.top-match .prob-pct{color:var(--orange-d)}

/* Career Market Insight */
.market-grid{display:grid;grid-template-columns:1fr 1.8fr;gap:1rem}
@media(max-width:600px){.market-grid{grid-template-columns:1fr}}
.market-hero{background:linear-gradient(135deg,var(--navy),var(--navy-mid));border-radius:13px;padding:1.2rem;color:#fff}
.mh-demand-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.5);margin-bottom:.5rem}
.mh-bar-bg{height:10px;background:rgba(255,255,255,.15);border-radius:5px;overflow:hidden;margin-bottom:.5rem}
.mh-bar-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,#34d399,#10b981);transition:width 1.4s cubic-bezier(.34,1.1,.64,1);width:0%}
.mh-demand-pct{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:2.2rem;font-weight:800;color:#34d399;line-height:1;margin-bottom:.6rem}
.mh-openings{font-size:.72rem;color:rgba(255,255,255,.7);margin-bottom:.5rem;line-height:1.4}
.mh-trend{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:700;padding:4px 10px;border-radius:100px;background:rgba(255,255,255,.12);color:#fff}
.market-table-wrap{overflow:hidden}
.market-table{width:100%;border-collapse:collapse}
.market-table td{padding:.55rem .7rem;font-size:.78rem;border-bottom:1px solid var(--border);vertical-align:top}
.market-table td:first-child{font-weight:700;color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;width:38%}
.market-table td:last-child{color:var(--text);font-weight:500}
.market-table tr:last-child td{border-bottom:none}
.market-company-list{display:flex;flex-wrap:wrap;gap:4px}
.market-company-chip{padding:2px 8px;background:var(--navy-l);color:var(--navy);border-radius:4px;font-size:.65rem;font-weight:700;border:1px solid rgba(11,31,58,.12)}

/* Skill Gap Meter */
.skill-gap-list{display:flex;flex-direction:column;gap:.7rem}
.skill-gap-item{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.75rem}
.sg-left{flex:1}
.sg-name{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:.3rem;display:flex;align-items:center;gap:.5rem}
.sg-name::before{content:'';width:8px;height:8px;border-radius:2px;background:var(--sg-color,var(--orange-d));flex-shrink:0}
.sg-bar-bg{height:8px;background:var(--bg);border-radius:4px;overflow:hidden;border:1px solid var(--border)}
.sg-bar-fill{height:100%;border-radius:4px;transition:width 1.3s cubic-bezier(.34,1.1,.64,1);width:0%}
.sg-status{font-size:.68rem;font-weight:700;padding:3px 9px;border-radius:100px;white-space:nowrap;flex-shrink:0}
.sg-status.low{background:var(--red-l);color:var(--red);border:1px solid rgba(200,16,46,.2)}
.sg-status.mid{background:var(--amber-l);color:var(--amber);border:1px solid rgba(224,123,0,.2)}
.sg-status.high{background:var(--green-l);color:var(--green);border:1px solid rgba(26,122,74,.2)}
.sg-klic-hint{font-size:.65rem;color:var(--muted);margin-top:.2rem}


/* Game vs Counselling explainer bar */
.game-vs-bar{display:grid;grid-template-columns:1fr auto 1fr;gap:0;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:16px;overflow:hidden;margin-bottom:1.5rem}
.gvb-col{padding:1.2rem 1.3rem;display:flex;flex-direction:column;gap:.45rem}
.gvb-game{background:rgba(247,147,30,.12);border-right:1px solid rgba(255,255,255,.1)}
.gvb-counsel{background:rgba(200,16,46,.1)}
.gvb-vs{display:flex;align-items:center;justify-content:center;padding:0 .8rem;font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.1rem;font-weight:800;color:rgba(255,255,255,.35);background:rgba(255,255,255,.04)}
.gvb-icon{font-size:1.6rem;line-height:1}
.gvb-title{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1rem;font-weight:800;color:#fff}
.gvb-desc{font-size:.73rem;color:rgba(255,255,255,.65);line-height:1.5}
.gvb-badge{display:inline-block;padding:3px 10px;background:rgba(247,147,30,.3);border:1px solid rgba(247,147,30,.5);border-radius:100px;font-size:.65rem;font-weight:700;color:var(--orange);margin-top:.2rem;width:fit-content}
.gvb-cta{padding:7px 14px;background:linear-gradient(135deg,var(--orange),var(--orange-d));color:#fff;border:none;border-radius:9px;font-size:.74rem;font-weight:700;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;margin-top:.2rem;transition:opacity .15s;width:fit-content}
.gvb-cta:hover{opacity:.85}
@media(max-width:500px){.game-vs-bar{grid-template-columns:1fr}.gvb-vs{padding:.4rem;text-align:center}.gvb-game{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}}



/* ── Site Footer ── */
.site-footer{background:linear-gradient(90deg,var(--navy) 0%,var(--blue) 100%);padding:1.5rem 1.5rem 1.2rem;border-top:1px solid rgba(255,255,255,.1)}
.ft-topbar{height:4px;background:linear-gradient(90deg,var(--blue),var(--pink),var(--orange),var(--gold),var(--purple));margin-bottom:0;border-radius:0}
.footer-inner{max-width:1260px;margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem}
@media(max-width:700px){.footer-inner{grid-template-columns:1fr;gap:1rem;text-align:center}.footer-right{text-align:center}.footer-brand{justify-content:center}}
.footer-brand{display:flex;align-items:center;gap:.9rem}
.footer-mkcl-img{width:clamp(48px,8vw,72px);height:auto;object-fit:contain;background:#fff;border-radius:10px;padding:5px 7px;box-shadow:0 2px 12px rgba(0,0,0,.3);aspect-ratio:auto}
.footer-mkcl-name{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:1.05rem;font-weight:800;color:var(--orange);letter-spacing:.5px}
.footer-mkcl-tag{font-size:.62rem;color:rgba(255,255,255,.4);margin-top:2px}
.footer-mkcl-url{font-size:.6rem;color:rgba(255,255,255,.25);margin-top:2px;letter-spacing:.5px}
.footer-center{text-align:center}
.footer-product-name{font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;font-size:.95rem;font-weight:700;color:#fff;letter-spacing:.5px}
.footer-product-sub{font-size:.63rem;color:rgba(255,255,255,.38);margin-top:4px;line-height:1.5}
.footer-swatch-row{display:flex;justify-content:center;gap:5px;margin-top:.65rem}
.footer-swatch{width:30px;height:5px;border-radius:3px;display:inline-block}
.footer-right{text-align:right}
.footer-copy{font-size:.62rem;color:rgba(255,255,255,.28)}
.footer-ext-link{display:inline-flex;align-items:center;gap:4px;margin-top:7px;font-size:.72rem;font-weight:700;color:var(--orange);text-decoration:none;border:1px solid rgba(244,130,31,.3);padding:4px 12px;border-radius:7px;transition:all .15s}
.footer-ext-link:hover{background:rgba(244,130,31,.12);border-color:var(--orange)}



/* ════════════════════════════════════════════════════
   FIX 1 — COURSE CARDS (were completely missing styles)
   ════════════════════════════════════════════════════ */
.course-card{
  background:#fff;
  border-radius:12px;
  border:1.5px solid var(--border);
  padding:1rem 1.1rem 1rem;
  display:flex;
  flex-direction:column;
  gap:.55rem;
  transition:all .2s ease;
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.course-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:var(--tc,var(--orange));
  transition:height .2s;
}
.course-card:hover{
  border-color:var(--orange);
  box-shadow:0 6px 22px rgba(0,0,0,.09);
  transform:translateY(-3px);
}
.course-card:hover::before{ height:5px; }

.card-track{
  display:flex;
  align-items:center;
  gap:5px;
  font-size:.68rem;
  font-weight:700;
  color:var(--tc,var(--orange));
  text-transform:uppercase;
  letter-spacing:.6px;
}
.card-track-ico{ font-size:.9rem; }

.card-name{
  font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;
  font-size:.92rem;
  font-weight:700;
  color:var(--text);
  line-height:1.35;
  flex:1;
}

.card-pathway{
  font-size:.7rem;
  color:var(--teal);
  font-weight:600;
  margin-bottom:4px;
  display:flex;
  align-items:center;
  gap:4px;
  background:var(--teal-l);
  border-radius:5px;
  padding:2px 7px;
  width:fit-content;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:5px;
  align-items:center;
}
.card-level{
  font-size:.65rem;
  font-weight:700;
  padding:2px 7px;
  border-radius:20px;
}
.card-dur,.card-lang{
  font-size:.67rem;
  color:var(--muted);
  background:var(--bg);
  padding:2px 7px;
  border-radius:20px;
  border:1px solid var(--border);
}

.card-tools{
  display:flex;
  flex-wrap:wrap;
  gap:4px;
}
.card-tool{
  font-size:.6rem;
  background:#f1f5f9;
  color:#475569;
  padding:2px 6px;
  border-radius:4px;
  white-space:nowrap;
}

.cmp-btn{
  margin-top:auto;
  padding:5px 10px;
  border-radius:7px;
  border:1.5px solid var(--border);
  background:#fff;
  color:var(--muted);
  font-size:.7rem;
  font-weight:600;
  cursor:pointer;
  transition:all .15s;
  align-self:flex-start;
}
.cmp-btn:hover{ border-color:var(--navy); color:var(--navy); }
.cmp-btn.added{ background:var(--navy); color:#fff; border-color:var(--navy); }

/* View Syllabus button on card */
.syllabus-btn{
  padding:5px 10px;
  border-radius:7px;
  border:1.5px solid var(--teal);
  background:#fff;
  color:var(--teal);
  font-size:.7rem;
  font-weight:600;
  cursor:pointer;
  transition:all .15s;
  align-self:flex-start;
}
.syllabus-btn:hover{ background:var(--teal); color:#fff; }

.card-btns{ display:flex; gap:6px; flex-wrap:wrap; margin-top:2px; }

/* ════════════════════════════════════════════════════
   FIX 2 — COUNSELLING OPTION HIGHLIGHT (.picked)
   CSS had .sel but JS uses .picked — fixed both
   ════════════════════════════════════════════════════ */
.qopt.picked,
.qopt.sel {
  border-color:var(--red) !important;
  background:var(--red) !important;
  color:#fff !important;
  font-weight:700 !important;
  box-shadow:0 0 0 3px rgba(237,22,81,.25);
  transform: scale(1.02);
}
.qopt.picked .qopt-ico,
.qopt.sel .qopt-ico { transform:scale(1.15); filter: brightness(5); }

/* ════════════════════════════════════════════════════
   FIX 3 — SYLLABUS MODAL
   ════════════════════════════════════════════════════ */
.syllabus-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(11,31,58,.65);
  z-index:10000;
  align-items:center;
  justify-content:center;
  padding:1rem;
  backdrop-filter:blur(3px);
}
.syllabus-overlay.open{ display:flex; }

.syllabus-modal{
  background:#fff;
  border-radius:18px;
  max-width:680px;
  width:100%;
  max-height:88vh;
  overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.22);
  animation:slideUp .25s ease;
}
@keyframes slideUp{
  from{ transform:translateY(30px);opacity:0; }
  to{ transform:translateY(0);opacity:1; }
}
.syl-header{
  position:sticky;
  top:0;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff;
  padding:1.2rem 1.5rem .9rem;
  border-radius:18px 18px 0 0;
  z-index:1;
}
.syl-close{
  position:absolute;
  top:.9rem; right:1rem;
  background:rgba(255,255,255,.15);
  border:none;
  color:#fff;
  width:30px; height:30px;
  border-radius:50%;
  font-size:1rem;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.syl-close:hover{ background:rgba(255,255,255,.3); }
.syl-badge{
  font-size:.65rem;
  background:var(--orange);
  color:#fff;
  padding:2px 8px;
  border-radius:10px;
  margin-bottom:.4rem;
  display:inline-block;
  font-weight:700;
  letter-spacing:.5px;
}
.syl-title{
  font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;
  font-size:1.2rem;
  font-weight:800;
  line-height:1.3;
  padding-right:2rem;
}
.syl-dur{ font-size:.72rem; opacity:.65; margin-top:3px; }

.syl-body{ padding:1.3rem 1.5rem; }

.syl-section{ margin-bottom:1.2rem; }
.syl-section-title{
  font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;
  font-size:.82rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:var(--navy);
  margin-bottom:.5rem;
  padding-bottom:.3rem;
  border-bottom:2px solid var(--border);
}
.syl-list{
  list-style:none;
  padding:0; margin:0;
  display:flex;
  flex-direction:column;
  gap:.35rem;
}
.syl-list li{
  font-size:.78rem;
  color:var(--text);
  padding:.35rem .5rem .35rem 1.4rem;
  position:relative;
  line-height:1.45;
  background:var(--bg);
  border-radius:6px;
}
.syl-list li::before{
  content:'▸';
  position:absolute;
  left:.4rem;
  color:var(--orange);
  font-size:.7rem;
}
.syl-modules{ display:flex; flex-wrap:wrap; gap:.4rem; }
.syl-module-tag{
  font-size:.7rem;
  background:#eef3fb;
  color:var(--navy);
  border:1px solid #c7d6ec;
  padding:.3rem .7rem;
  border-radius:7px;
  font-weight:600;
}
.syl-no-data{
  text-align:center;
  padding:2rem;
  color:var(--muted);
  font-size:.82rem;
}
.syl-no-data .syl-no-ico{ font-size:2rem; margin-bottom:.5rem; }


/* ════════════════════════════════════════════════════
   FIX — COMPARE TAB: Full Layout Repair
   ════════════════════════════════════════════════════ */

/* ── Course Picker Items (pgrid) ── */
.cp-item{
  background:var(--bg);
  border-radius:9px;
  border:1.5px solid var(--border);
  padding:8px 10px;
  cursor:pointer;
  transition:all .17s;
  display:flex;
  align-items:center;
  gap:8px;
}
.cp-item:hover{ border-color:var(--red); background:var(--red-l); }
.cp-item.sel{   border-color:var(--red); background:var(--red-l); }

.cp-ico{
  font-size:1.3rem;
  flex-shrink:0;
  width:30px;
  text-align:center;
}
.cp-info{ flex:1; min-width:0; }
.cp-name{
  font-size:.75rem;
  font-weight:700;
  color:var(--text);
  line-height:1.3;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.cp-sub{
  font-size:.65rem;
  color:var(--muted);
  margin-top:2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.cp-sel-btn{
  flex-shrink:0;
  width:24px; height:24px;
  border-radius:50%;
  border:1.5px solid var(--border);
  background:#fff;
  font-size:.75rem;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .15s;
  color:var(--muted);
  font-weight:700;
}
.cp-sel-btn.on{
  background:var(--red);
  border-color:var(--red);
  color:#fff;
}

/* ── Selected Slot content ── */
.cs-name{
  font-size:.72rem;
  font-weight:700;
  color:var(--text);
  line-height:1.3;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  padding-right:.5rem;
  flex:1;
}
.cs-empty{
  color:rgba(255,255,255,.3);
  font-size:.72rem;
  text-align:center;
  width:100%;
  padding:.2rem 0;
}
.cslot.filled{
  display:flex;
  align-items:flex-start;
  gap:5px;
  text-align:left;
  cursor:default;
}
.cs-rm{
  background:rgba(255,255,255,.15);
  border:none;
  color:rgba(255,255,255,.7);
  border-radius:50%;
  width:18px; height:18px;
  font-size:.7rem;
  cursor:pointer;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .15s;
  margin-top:1px;
}
.cs-rm:hover{ background:rgba(255,80,80,.5); color:#fff; }

/* ── Comparison Table ── */
.cmptbl-inner{
  overflow-x:auto;
  border-radius:13px;
}
.cmp-row{
  display:grid;
  border-bottom:1px solid var(--border);
  transition:background .13s;
}
.cmp-row:last-child{ border-bottom:none; }
.cmp-row:not(.cmp-hdr):hover{ background:#fafbff; }

.cmp-hdr{
  background:linear-gradient(135deg,var(--navy),#1a2a6c);
  border-radius:13px 13px 0 0;
  position:sticky;
  top:0;
  z-index:2;
}
.cmp-cell{
  padding:.8rem 1rem;
  font-size:.78rem;
  color:var(--text);
  line-height:1.4;
  vertical-align:top;
  border-right:1px solid var(--border);
}
.cmp-cell:last-child{ border-right:none; }

.cmp-lbl-cell{
  font-weight:800;
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:var(--muted);
  background:#f8fafc;
  white-space:nowrap;
  min-width:110px;
  max-width:130px;
}
.cmp-hdr .cmp-lbl-cell{
  background:transparent;
  color:rgba(255,255,255,.35);
}
.cmp-course-hdr{
  font-family:'Rajdhani',Georgia,'Times New Roman',system-ui,sans-serif;
  font-size:.88rem;
  font-weight:800;
  color:#fff;
  line-height:1.35;
}
.cmp-hdr .cmp-cell{ border-right-color:rgba(255,255,255,.1); }

/* Dynamic column count for table */
.cmp-row.cols-1{ grid-template-columns:130px 1fr; }
.cmp-row.cols-2{ grid-template-columns:130px 1fr 1fr; }
.cmp-row.cols-3{ grid-template-columns:130px 1fr 1fr 1fr; }

/* ── Responsive fixes ── */
@media(max-width:600px){
  .cmp-wrap{ padding:1rem .75rem 2rem; }
  .cmp-hero{ flex-direction:column; gap:.8rem; }
  .cslots{ width:100%; justify-content:stretch; }
  .cslot{ flex:1; min-width:0; }
  .cctrl{ flex-direction:column; align-items:stretch; }
  .csrch{ min-width:0; }
  .pgrid{ grid-template-columns:1fr; }
  .cmp-lbl-cell{ min-width:90px; max-width:100px; font-size:.65rem; }
}

/* ══════════════════════════════════════════════════════════
   PROFESSION FINDER — Smart Course Finder by Profession
   ══════════════════════════════════════════════════════════ */

/* Hero */
.prof-finder-wrap { background: var(--bg); }

.prof-finder-hero {
  position: relative;
  background: linear-gradient(135deg, var(--navy) 0%, #1a2a4a 60%, #0f1e38 100%);
  padding: 2.5rem 2rem 2rem;
  overflow: hidden;
}
.prof-hero-dots {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 22px 22px;
  pointer-events: none;
}
.prof-hero-in {
  position: relative;
  max-width: 900px; margin: 0 auto; text-align: center;
}
.prof-hero-badge {
  display: inline-block;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 20px;
  padding: .25rem .9rem;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  margin-bottom: .75rem;
}
.prof-hero-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 2rem; font-weight: 800;
  color: #fff; margin: 0 0 .5rem;
  line-height: 1.15;
}
.prof-hero-title span { color: var(--red); }
.prof-hero-sub {
  font-size: .88rem; color: rgba(255,255,255,.55);
  max-width: 540px; margin: 0 auto;
  line-height: 1.6;
}

/* Dropdown card */
.prof-dropdowns-card {
  max-width: 1100px; margin: 0 auto;
  padding: 1.8rem 1.5rem 2.5rem;
}

.prof-dd-row {
  display: flex; gap: 1rem; align-items: flex-end;
  flex-wrap: wrap;
}
.prof-dd-group { flex: 1; min-width: 200px; }
.prof-dd-btn-group { flex: 0 0 auto; min-width: 150px; }

.prof-dd-label {
  display: block;
  font-size: .7rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .8px;
  color: var(--muted); margin-bottom: .45rem;
}

.prof-select-wrap { position: relative; }
.prof-select {
  width: 100%;
  padding: .7rem 2.2rem .7rem .9rem;
  border: 1.5px solid var(--border);
  border-radius: 10px;
  background: #fff;
  font-size: .85rem;
  color: var(--text);
  font-family: inherit;
  appearance: none;
  cursor: pointer;
  transition: border-color .2s, box-shadow .2s;
}
.prof-select:focus {
  outline: none;
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(196,18,48,.1);
}
.prof-select:disabled { background: #f4f4f5; color: var(--muted); cursor: not-allowed; }
.prof-dd-arrow {
  position: absolute; right: .85rem; top: 50%;
  transform: translateY(-50%);
  font-size: .7rem; color: var(--muted);
  pointer-events: none;
}

.prof-find-btn {
  width: 100%;
  padding: .72rem 1.4rem;
  background: linear-gradient(135deg, var(--red), var(--red-d, #a00));
  color: #fff;
  font-family: 'Rajdhani', sans-serif;
  font-size: 1rem; font-weight: 700;
  border: none; border-radius: 10px;
  cursor: pointer; transition: opacity .2s, transform .1s;
  letter-spacing: .3px;
}
.prof-find-btn:hover:not(:disabled) { opacity: .9; transform: translateY(-1px); }
.prof-find-btn:active:not(:disabled) { transform: translateY(0); }
.prof-find-btn:disabled { opacity: .4; cursor: not-allowed; }

/* Results */
.prof-results { margin-top: 1.8rem; animation: fadeIn .3s; }

.prof-res-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem;
}
.prof-res-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.25rem; font-weight: 800; color: var(--navy);
}
.prof-res-sub { font-size: .78rem; color: var(--muted); margin-top: .15rem; }
.prof-res-count-badge {
  background: var(--red); color: #fff;
  font-family: 'Rajdhani', sans-serif;
  font-size: 1rem; font-weight: 700;
  padding: .3rem .9rem; border-radius: 20px;
  white-space: nowrap;
}

/* Track filter chips */
.prof-track-filters {
  display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.2rem;
}
.prof-track-chip {
  padding: .28rem .75rem;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  font-size: .72rem; font-weight: 700;
  color: var(--muted);
  cursor: pointer;
  transition: all .18s;
  background: #fff;
}
.prof-track-chip:hover { border-color: var(--red); color: var(--red); }
.prof-track-chip.active {
  background: var(--red); color: #fff;
  border-color: var(--red);
}

/* Course grid */
.prof-courses-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 1rem;
}

.prof-course-card {
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 1rem 1.1rem;
  background: #fff;
  transition: border-color .18s, box-shadow .18s, transform .18s;
  cursor: default;
}
.prof-course-card:hover {
  border-color: var(--red);
  box-shadow: 0 4px 18px rgba(196,18,48,.1);
  transform: translateY(-2px);
}
.prof-course-badge {
  display: inline-block;
  font-size: .62rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .6px;
  padding: .15rem .55rem;
  border-radius: 4px;
  margin-bottom: .55rem;
  background: rgba(196,18,48,.08);
  color: var(--red);
}
.prof-course-name {
  font-size: .82rem; font-weight: 700;
  color: var(--navy); line-height: 1.4;
  margin-bottom: .6rem;
}
.prof-course-meta {
  display: flex; flex-wrap: wrap; gap: .4rem;
}
.prof-course-pill {
  font-size: .65rem; font-weight: 600;
  padding: .18rem .5rem;
  border-radius: 4px;
  background: #f0f4f8; color: var(--muted);
}

/* Empty state */
.prof-empty {
  text-align: center; padding: 3rem 1rem;
  animation: fadeIn .3s;
}
.prof-empty h3 {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.1rem; color: var(--navy); margin: .5rem 0 .25rem;
}
.prof-empty p { font-size: .8rem; color: var(--muted); }

/* Divider between finder and quiz */
.prof-divider {
  display: flex; align-items: center; gap: 1rem;
  max-width: 900px; margin: 0 auto 1.5rem;
  padding: 0 1.5rem;
}
.prof-divider-line { flex: 1; height: 1px; background: var(--border); }
.prof-divider-label {
  font-size: .72rem; font-weight: 700; color: var(--muted);
  text-transform: uppercase; letter-spacing: .6px; white-space: nowrap;
}

@keyframes fadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }

@media(max-width:600px) {
  .prof-dd-row { flex-direction: column; }
  .prof-dd-btn-group { min-width: 0; width: 100%; }
  .prof-finder-hero { padding: 1.5rem 1rem 1.2rem; }
  .prof-hero-title { font-size: 1.4rem; }
  .prof-courses-grid { grid-template-columns: 1fr; }
}

/* ── Profession Finder hero steps ── */
.prof-hero-steps {
  display: flex; align-items: center; gap: .6rem;
  justify-content: center; margin-top: 1.1rem; flex-wrap: wrap;
}
.phs {
  display: flex; align-items: center; gap: .4rem;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 20px; padding: .3rem .85rem;
}
.phs-n {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1.3rem; height: 1.3rem;
  background: var(--red); color: #fff;
  border-radius: 50%; font-size: .68rem; font-weight: 800;
  flex-shrink: 0;
}
.phs-l { font-size: .72rem; font-weight: 700; color: rgba(255,255,255,.8); }
.phs-arrow { color: rgba(255,255,255,.3); font-size: .85rem; }

/* ── Profession Finder CTA bar ── */
.prof-cta-bar {
  margin-top: 2rem;
  background: linear-gradient(135deg, #f0f7ff 0%, #e8f4ff 100%);
  border: 1.5px solid #bdd8f8;
  border-radius: 12px;
  padding: 1rem 1.4rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
}
.prof-cta-text {
  font-size: .85rem; color: #1e3a5f; font-weight: 600;
}
.prof-cta-btn {
  padding: .5rem 1.2rem;
  background: var(--navy); color: #fff;
  font-family: 'Rajdhani', sans-serif;
  font-size: .9rem; font-weight: 700;
  border: none; border-radius: 8px;
  cursor: pointer; white-space: nowrap;
  transition: opacity .18s;
}
.prof-cta-btn:hover { opacity: .85; }

/* ── Counselling: duration section labels ── */
.rs-section-lbl {
  font-size: .72rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .7px;
  color: #fff;
  background: var(--navy);
  border-radius: 6px;
  padding: .35rem .8rem;
  margin: .8rem 0 .4rem;
}
.rs-section-lbl-other {
  background: var(--muted);
}
.rc-dur-match {
  border-left: 3px solid #10b981 !important;
}
.rc-dur-badge {
  color: #10b981 !important;
  font-weight: 700 !important;
}

/* ── Prof finder: second row spacing ── */
.prof-dd-row2 { margin-top: .85rem; }

/* ── Prof finder: match tags ── */
.prof-match-bar-wrap {
  display: flex; align-items: center; gap: .5rem; margin: .45rem 0 .4rem;
}
.prof-match-bar-track {
  flex: 1; height: 5px; background: #eee; border-radius: 3px; overflow: hidden;
}
.prof-match-bar-fill { height: 100%; border-radius: 3px; transition: width .4s ease; }
.prof-match-pct { font-size: .68rem; font-weight: 800; color: var(--muted); white-space: nowrap; }

.prof-match-tags { display: flex; flex-wrap: wrap; gap: .3rem; margin-bottom: .45rem; }
.prof-match-tag {
  font-size: .6rem; font-weight: 700; padding: .15rem .45rem;
  border-radius: 4px; letter-spacing: .3px;
}
.tag-strong  { background: #dcfce7; color: #166534; }
.tag-good    { background: #dbeafe; color: #1e40af; }
.tag-keyword { background: #fef9c3; color: #854d0e; }
.tag-level   { background: #f3e8ff; color: #6b21a8; }
.tag-tool    { background: #ffe4e6; color: #9f1239; }
.tag-goal    { background: #ffedd5; color: #9a3412; }
.tag-edu     { background: #e0f2fe; color: #0369a1; }

.prof-rank {
  font-size: .65rem; font-weight: 800;
  padding: .18rem .5rem; border-radius: 4px;
  margin-bottom: .4rem; display: inline-block;
}
.r1 { background: #fef3c7; color: #92400e; }
.r2 { background: #f1f5f9; color: #475569; }
.r3 { background: #fce7f3; color: #9d174d; }

/* ── Counselling: closest duration note ── */
.rs-closest-note {
  font-weight: 400; font-size: .68rem;
  opacity: .85; font-style: italic;
}
