/* ============================================================
   JoFiSA — Job Fit And Satisfaction Assessment
   Corporate Design System — Navy Blue, Black And Gold
   Light, Dark And System Themes · Glassmorphism
   ============================================================ */
:root{
  --navy:#0b1f4b; --navy-2:#12306e; --navy-3:#1c4394;
  --gold:#c9a227; --gold-2:#e3bf4e; --gold-soft:rgba(201,162,39,.14);
  --black:#0b0d12;
  --radius:14px;
  --font:'Segoe UI',system-ui,-apple-system,'Helvetica Neue',Arial,sans-serif;
  --ok:#1a7f4e; --ok-soft:rgba(26,127,78,.14);
  --warn:#a66a00; --warn-soft:rgba(166,106,0,.14);
  --bad:#b3261e; --bad-soft:rgba(179,38,30,.12);
  --ease:cubic-bezier(.22,.8,.3,1);
}
html[data-theme="light"]{
  --bg:#eef1f6; --bg-glow-1:rgba(11,31,75,.10); --bg-glow-2:rgba(201,162,39,.12);
  --glass:rgba(255,255,255,.72); --glass-strong:rgba(255,255,255,.9);
  --ink:#10131c; --ink-2:#3d4557; --ink-3:#8a92a6;
  --line:rgba(11,31,75,.14); --line-gold:rgba(201,162,39,.4);
  --shadow:0 8px 28px rgba(11,31,75,.10);
  --side-grad:linear-gradient(180deg,#0b1f4b 0%,#0c2456 55%,#0b0d12 100%);
  --input-bg:rgba(255,255,255,.85);
  --hover:rgba(11,31,75,.05);
}
html[data-theme="dark"]{
  --bg:#0a0d16; --bg-glow-1:rgba(28,67,148,.25); --bg-glow-2:rgba(201,162,39,.10);
  --glass:rgba(18,26,46,.62); --glass-strong:rgba(18,26,46,.88);
  --ink:#eef1f8; --ink-2:#b6bfd2; --ink-3:#6e7891;
  --line:rgba(227,191,78,.14); --line-gold:rgba(201,162,39,.35);
  --shadow:0 10px 34px rgba(0,0,0,.45);
  --side-grad:linear-gradient(180deg,#0b1f4b 0%,#0a1533 55%,#05060a 100%);
  --input-bg:rgba(10,14,26,.6);
  --hover:rgba(227,191,78,.07);
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:15.5px}
body{
  font-family:var(--font);color:var(--ink);line-height:1.6;min-height:100vh;
  background:var(--bg);
  background-image:radial-gradient(560px 380px at 12% -4%,var(--bg-glow-1),transparent 65%),
                   radial-gradient(620px 420px at 96% 8%,var(--bg-glow-2),transparent 60%),
                   radial-gradient(500px 400px at 55% 110%,var(--bg-glow-1),transparent 65%);
  background-attachment:fixed;
  transition:background .35s var(--ease),color .35s var(--ease);
}
a{color:var(--navy-3);text-decoration:none}
html[data-theme="dark"] a{color:var(--gold-2)}

@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:250px;flex-shrink:0;background:var(--side-grad);color:#dbe3f5;padding:24px 14px;display:flex;flex-direction:column;gap:3px;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid rgba(201,162,39,.25)}
.sidebar .logo{display:flex;align-items:center;gap:11px;padding:2px 10px 20px}
.sidebar .logo .mark{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-2) 100%);display:grid;place-items:center;font-weight:800;font-size:15px;color:var(--navy);letter-spacing:-.5px;box-shadow:0 3px 12px rgba(201,162,39,.4)}
.sidebar .logo .name{font-weight:700;font-size:1.16rem;color:#fff;letter-spacing:.4px}
.sidebar .logo .tag{font-size:.6rem;color:var(--gold-2);letter-spacing:1px;text-transform:uppercase}
.nav-sec{font-size:.6rem;text-transform:uppercase;letter-spacing:1.4px;color:rgba(227,191,78,.75);padding:15px 12px 5px;font-weight:700}
.nav-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;color:#c3cde6;font-size:.9rem;transition:all .18s var(--ease);border:1px solid transparent}
.nav-link:hover{background:rgba(227,191,78,.1);color:#fff;transform:translateX(3px)}
.nav-link.active{background:rgba(201,162,39,.18);color:#fff;font-weight:600;border-color:rgba(201,162,39,.4)}
.nav-link .ico{width:20px;text-align:center;font-size:1rem;color:var(--gold-2)}
.sidebar .foot{margin-top:auto;padding:14px 12px 4px;font-size:.68rem;color:#8fa0c8;border-top:1px solid rgba(201,162,39,.2)}

.main{flex:1;min-width:0;padding:26px 36px 64px;animation:fadeIn .4s var(--ease)}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.topbar h1{font-size:1.5rem;font-weight:700;letter-spacing:-.3px}
.topbar h1::after{content:"";display:block;width:56px;height:3px;margin-top:7px;border-radius:3px;background:linear-gradient(90deg,var(--gold),transparent)}
.topbar .sub{color:var(--ink-2);font-size:.9rem;margin-top:8px;max-width:660px}
.topbar .actions{display:flex;gap:9px;flex-wrap:wrap;align-items:center}

/* Theme switcher + session chip */
.tswitch{display:inline-flex;border:1px solid var(--line);border-radius:99px;overflow:hidden;background:var(--glass);backdrop-filter:blur(10px)}
.tswitch button{border:none;background:transparent;color:var(--ink-2);padding:6px 12px;font-size:.78rem;cursor:pointer;font-family:inherit;transition:all .2s}
.tswitch button.on{background:linear-gradient(135deg,var(--navy),var(--navy-3));color:#fff}
.who{font-size:.78rem;color:var(--ink-2);background:var(--glass);border:1px solid var(--line);border-radius:99px;padding:6px 14px;backdrop-filter:blur(10px)}
.who b{color:var(--gold)}

/* ---------- Glass Cards ---------- */
.card{background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--line);border-top:1px solid var(--line-gold);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px 24px;margin-bottom:20px;animation:rise .45s var(--ease) both}
.card:nth-child(2){animation-delay:.05s}.card:nth-child(3){animation-delay:.1s}.card:nth-child(4){animation-delay:.15s}
.card h2{font-size:1.02rem;font-weight:700;margin-bottom:4px}
.card .hint{color:var(--ink-3);font-size:.82rem;margin-bottom:14px}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.g3{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.g4{grid-template-columns:repeat(auto-fit,minmax(185px,1fr))}

.kpi{background:var(--glass);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:17px 19px;display:flex;flex-direction:column;gap:2px;transition:transform .25s var(--ease),box-shadow .25s;animation:rise .45s var(--ease) both}
.kpi:hover{transform:translateY(-3px)}
.kpi .lab{font-size:.72rem;text-transform:uppercase;letter-spacing:.9px;color:var(--ink-3);font-weight:700}
.kpi .val{font-size:1.7rem;font-weight:800;letter-spacing:-.5px}
.kpi .det{font-size:.78rem;color:var(--ink-2)}
.kpi.b-navy{border-top:3px solid var(--navy-3)} .kpi.b-gold{border-top:3px solid var(--gold)}
.kpi.b-ok{border-top:3px solid var(--ok)} .kpi.b-bad{border-top:3px solid var(--bad)}
.kpi.b-warn{border-top:3px solid var(--warn)} .kpi.b-ink{border-top:3px solid var(--ink-3)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid transparent;border-radius:10px;padding:9px 17px;font-size:.88rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s var(--ease);white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn-p{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-3) 100%);color:#fff;box-shadow:0 4px 14px rgba(11,31,75,.3)}
.btn-p:hover{box-shadow:0 6px 20px rgba(11,31,75,.42);transform:translateY(-1px)}
.btn-g{background:linear-gradient(135deg,var(--gold) 0%,var(--gold-2) 100%);color:var(--navy);box-shadow:0 4px 14px rgba(201,162,39,.35);font-weight:700}
.btn-g:hover{box-shadow:0 6px 20px rgba(201,162,39,.5);transform:translateY(-1px)}
.btn-s{background:var(--glass-strong);color:var(--ink);border-color:var(--line)}
.btn-s:hover{border-color:var(--line-gold);background:var(--hover)}
.btn-ok{background:var(--ok);color:#fff}
.btn-d{background:var(--bad-soft);color:var(--bad);border-color:rgba(179,38,30,.3)}
.btn-sm{padding:4px 11px;font-size:.78rem;border-radius:8px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- Forms ---------- */
label.f{display:block;font-size:.8rem;font-weight:600;color:var(--ink-2);margin:12px 0 4px}
input[type=text],input[type=number],input[type=email],input[type=password],input[type=date],select,textarea{
  width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:.9rem;
  background:var(--input-bg);color:var(--ink);transition:border .2s,box-shadow .2s;backdrop-filter:blur(6px)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}
textarea{resize:vertical;min-height:76px}
.frow{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}

/* ---------- Tables ---------- */
.tbl-wrap{overflow-x:auto;border-radius:10px}
table.tbl{width:100%;border-collapse:collapse;font-size:.87rem}
.tbl th{text-align:left;padding:10px 12px;background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#e8ddb0;font-size:.7rem;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap}
.tbl th:first-child{border-radius:9px 0 0 0}.tbl th:last-child{border-radius:0 9px 0 0}
.tbl td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr{transition:background .15s}
.tbl tr:hover td{background:var(--hover)}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}

/* ---------- Badges, Bars ---------- */
.badge{display:inline-block;padding:3px 11px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.3px}
.bg-ok{background:var(--ok-soft);color:var(--ok)} .bg-warn{background:var(--warn-soft);color:var(--warn)}
.bg-bad{background:var(--bad-soft);color:var(--bad)}
.bg-navy{background:rgba(28,67,148,.15);color:var(--navy-3)}
html[data-theme="dark"] .bg-navy{color:#9db8ee}
.bg-gold{background:var(--gold-soft);color:var(--gold)}
.bg-mut{background:var(--hover);color:var(--ink-2)}

.bar{height:8px;background:var(--hover);border-radius:99px;overflow:hidden;min-width:70px;border:1px solid var(--line)}
.bar>i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--navy-3),var(--gold));transition:width .6s var(--ease)}
.bar>i.ok{background:var(--ok)} .bar>i.warn{background:var(--warn)} .bar>i.bad{background:var(--bad)}
.score-cell{display:flex;align-items:center;gap:9px}
.score-cell b{min-width:38px;text-align:right;font-variant-numeric:tabular-nums}

.empty{text-align:center;color:var(--ink-3);padding:38px 12px;font-size:.9rem}
.empty .big{font-size:2.1rem;margin-bottom:6px}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{background:var(--hover);border:1px solid var(--line);border-radius:999px;padding:2px 12px;font-size:.76rem;color:var(--ink-2)}
.divider{border:none;border-top:1px solid var(--line);margin:16px 0}
.muted{color:var(--ink-3);font-size:.82rem}
.right{text-align:right}
.flex{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.spacer{flex:1}

/* Likert */
.likert{display:flex;gap:5px}
.likert label{flex:1;text-align:center;border:1px solid var(--line);border-radius:8px;padding:7px 2px;font-size:.78rem;cursor:pointer;background:var(--input-bg);color:var(--ink-2);transition:all .18s var(--ease)}
.likert label:hover{border-color:var(--gold)}
.likert input{display:none}
.likert label:has(input:checked){background:var(--gold-soft);border-color:var(--gold);color:var(--ink);font-weight:700;transform:scale(1.05)}

/* Rating dots */
.rate{display:inline-flex;gap:5px}
.rate button{width:31px;height:31px;border-radius:50%;border:1.5px solid var(--line);background:var(--input-bg);cursor:pointer;font-size:.8rem;font-weight:700;color:var(--ink-3);transition:all .18s var(--ease)}
.rate button:hover{border-color:var(--gold)}
.rate button.on{background:linear-gradient(135deg,var(--navy),var(--navy-3));border-color:var(--gold);color:#fff;transform:scale(1.1)}

/* Dropzone */
.drop{border:2.5px dashed var(--line-gold);border-radius:var(--radius);padding:40px 20px;text-align:center;color:var(--ink-2);background:var(--gold-soft);cursor:pointer;transition:all .25s var(--ease)}
.drop:hover,.drop.over{border-color:var(--gold);background:var(--gold-soft);transform:scale(1.005);box-shadow:0 0 0 5px var(--gold-soft)}
.drop .big{font-size:2.3rem;margin-bottom:8px;color:var(--gold)}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(5,8,18,.6);backdrop-filter:blur(5px);display:none;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:60;overflow-y:auto}
.modal-bg.open{display:flex}
.modal{background:var(--glass-strong);backdrop-filter:blur(24px);border:1px solid var(--line-gold);border-radius:16px;max-width:740px;width:100%;padding:26px 28px;box-shadow:0 24px 70px rgba(0,0,0,.4);animation:popIn .3s var(--ease)}
.modal h3{font-size:1.1rem;margin-bottom:14px}
.modal .m-foot{display:flex;justify-content:flex-end;gap:9px;margin-top:20px}

/* Toast */
#toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy);border:1px solid var(--gold);color:#fff;padding:11px 24px;border-radius:11px;font-size:.88rem;opacity:0;pointer-events:none;transition:all .3s var(--ease);z-index:99;box-shadow:0 10px 30px rgba(0,0,0,.35)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Pipeline */
.pipe{display:flex;gap:0;flex-wrap:wrap}
.pipe .st{flex:1;min-width:110px;text-align:center;padding:11px 6px;background:var(--hover);border:1px solid var(--line);font-size:.78rem;color:var(--ink-2);transition:all .2s}
.pipe .st:first-child{border-radius:10px 0 0 10px}
.pipe .st:last-child{border-radius:0 10px 10px 0}
.pipe .st b{display:block;font-size:1.3rem;color:var(--ink)}
.pipe .st.hot{background:var(--gold-soft);border-color:var(--line-gold)}
.pipe .st.hot b{color:var(--gold)}

/* SWOT */
.swot{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.swot .q{border-radius:11px;padding:15px 17px;border:1px solid var(--line);background:var(--glass)}
.swot .q h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.9px;margin-bottom:8px}
.swot .q.s h4{color:var(--ok)} .swot .q.w h4{color:var(--bad)}
.swot .q.o h4{color:var(--navy-3)} .swot .q.t h4{color:var(--warn)}
html[data-theme="dark"] .swot .q.o h4{color:#9db8ee}
.swot .q.s{border-left:3px solid var(--ok)} .swot .q.w{border-left:3px solid var(--bad)}
.swot .q.o{border-left:3px solid var(--navy-3)} .swot .q.t{border-left:3px solid var(--warn)}
.swot ul{padding-left:18px;font-size:.85rem}

/* Animal cards */
.animal-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}
.animal{border:1px solid var(--line);border-radius:13px;padding:16px 12px;text-align:center;background:var(--glass);transition:all .25s var(--ease);position:relative;overflow:hidden}
.animal:hover{transform:translateY(-4px);border-color:var(--line-gold)}
.animal.dom{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft);background:var(--gold-soft)}
.animal .emo{font-size:2.3rem;display:block;margin-bottom:4px}
.animal .nm{font-weight:700;font-size:.92rem}
.animal .ttl{font-size:.72rem;color:var(--gold);font-weight:700;letter-spacing:.4px}
.animal .pc{font-size:1.25rem;font-weight:800;margin-top:6px}
.animal .crown{position:absolute;top:8px;right:10px;font-size:1rem}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:30px 16px}
.login-card{max-width:920px;width:100%;display:grid;grid-template-columns:1fr 1fr;border-radius:20px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.35);animation:popIn .5s var(--ease)}
.login-brand{background:var(--side-grad);color:#fff;padding:46px 40px;display:flex;flex-direction:column;justify-content:center;gap:14px;position:relative}
.login-brand::after{content:"";position:absolute;inset:0;background:radial-gradient(340px 260px at 90% 0%,rgba(201,162,39,.25),transparent 70%)}
.login-brand *{position:relative;z-index:1}
.login-panel{background:var(--glass-strong);backdrop-filter:blur(24px);padding:42px 40px}
.ltabs{display:flex;gap:8px;margin-bottom:22px}
.ltabs button{flex:1;padding:10px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--ink-2);font-family:inherit;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .2s}
.ltabs button.on{background:linear-gradient(135deg,var(--navy),var(--navy-3));color:#fff;border-color:var(--gold)}
.pwd-wrap{position:relative}
.pwd-wrap .eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;color:var(--ink-3)}

@media print{
  .sidebar,.topbar .actions,.no-print,#toast{display:none!important}
  .main{padding:0}
  body{background:#fff!important}
  .card{box-shadow:none;break-inside:avoid;background:#fff}
}
@media(max-width:980px){
  .login-card{grid-template-columns:1fr}
  .login-brand{padding:32px}
}
@media(max-width:900px){
  .app{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center;padding:14px}
  .sidebar .foot,.nav-sec{display:none}
  .main{padding:18px}
  .swot{grid-template-columns:1fr}
  html{font-size:14.5px}
}
@media(max-width:560px){
  .topbar{flex-direction:column}
  .modal{padding:20px 16px}
  .main{padding:14px}
}
@media(prefers-reduced-motion:reduce){
  *,.card,.kpi{animation:none!important;transition:none!important}
}
