/* =====================================================================
   OTIS — base styles & design tokens
   Brand-aligned with Optiserve (navy + gold). Expand as the UI grows.
   ===================================================================== */
:root{
    --navy-900:#00102A; --navy-800:#0A1A3F; --navy-700:#0A1C45;
    --gold-600:#D4A017; --gold-500:#F2C94C;
    --gold-grad:linear-gradient(135deg,#F2C94C,#D4A017);
    --ink-900:#0A0E1A; --ink-700:#3A4252; --ink-500:#5A6378;
    --line:#E6E9F0; --bg:#F5F6F8; --white:#fff;
    --success:#1A7431; --warning:#B7791F; --danger:#C2282D;
    --radius:14px; --radius-sm:9px; --shadow:0 10px 40px rgba(0,16,42,.12);
    --font-display:'Bricolage Grotesque',system-ui,sans-serif;
    --font-body:'DM Sans',system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
body{margin:0;font-family:var(--font-body);color:var(--ink-900);background:var(--bg);line-height:1.6}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--navy-900);line-height:1.2;margin:0 0 .5rem}
a{color:var(--gold-600);text-decoration:none}
.container{width:100%;max-width:1100px;margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.btn{display:inline-block;border:0;border-radius:100px;padding:.85rem 1.6rem;font-weight:600;font-family:var(--font-body);cursor:pointer;font-size:.95rem}
.btn--gold{background:var(--gold-grad);color:var(--navy-900)}
.btn--ghost{background:transparent;border:1.5px solid var(--line);color:var(--navy-900)}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.6rem}

/* =====================================================================
   Assessment forms, profile bars, results
   ===================================================================== */
.form-wrap{max-width:760px;margin-inline:auto}
.assess-hero{padding:.4rem 0 1.2rem}
.assess-hero h1{font-size:clamp(1.5rem,4vw,2.1rem);margin-bottom:.25rem}
.assess-hero p{color:var(--ink-500);margin:0}
.field{margin-bottom:1rem}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.35rem}
.field input{width:100%;padding:.7rem .9rem;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff}
.q{border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.2rem;margin:0 0 1rem;background:#fff}
.q legend{font-weight:600;font-size:.95rem;color:var(--navy-900);padding:0;margin-bottom:.7rem;float:none}
.scale{display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem}
.opt{display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center;font-size:.72rem;color:var(--ink-500);cursor:pointer;padding:.55rem .2rem;border:1px solid var(--line);border-radius:9px}
.opt input{accent-color:var(--gold-600)}
.opt:has(input:checked){border-color:var(--gold-600);background:#fbf6e6;color:var(--navy-900);font-weight:600}
@media (max-width:560px){.scale{grid-template-columns:1fr;gap:.3rem}.opt{flex-direction:row;justify-content:flex-start;gap:.6rem;text-align:left;font-size:.85rem}}
.err-box{background:#fdecec;border:1px solid var(--danger);color:var(--danger);border-radius:9px;padding:.7rem 1rem;margin-bottom:1.2rem;font-size:.9rem}
.ok-box{background:#e6f4ea;border:1px solid var(--success);color:var(--success);border-radius:9px;padding:.7rem 1rem;margin-bottom:1.2rem;font-size:.9rem}
.dimbar{display:grid;grid-template-columns:170px 1fr 36px;gap:.6rem;align-items:center;margin-bottom:.45rem;font-size:.84rem}
.dimbar .track{height:8px;background:var(--line);border-radius:100px;overflow:hidden}
.dimbar .track>span{display:block;height:100%;background:var(--gold-grad)}
.dimbar .v{text-align:right;font-weight:600;font-variant-numeric:tabular-nums}
@media (max-width:560px){.dimbar{grid-template-columns:120px 1fr 32px}}
.pill{display:inline-block;padding:.3rem .8rem;border-radius:100px;font-weight:600;font-size:.8rem}
.tone-success{background:#e6f4ea;color:var(--success)}
.tone-warning{background:#fbf2e0;color:var(--warning)}
.tone-danger{background:#fdecec;color:var(--danger)}
.ctable{width:100%;border-collapse:collapse;font-size:.88rem}
.ctable th{text-align:left;color:var(--ink-500);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}
.ctable th,.ctable td{padding:.6rem .5rem;border-bottom:1px solid var(--line);vertical-align:top}
.cip-link{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;background:#f5f6f8;border:1px solid var(--line);border-radius:9px;padding:.6rem .8rem;font-size:.84rem;word-break:break-all}

/* =====================================================================
   Authenticated console bar
   ===================================================================== */
.no-print{}
@media print{ .no-print{ display:none !important; } }
.app-bar{display:flex;align-items:center;gap:1.2rem;background:var(--navy-900);color:#fff;padding:.7rem 1.1rem;border-radius:12px;margin-bottom:1.4rem}
.app-bar__brand{color:#fff;font-family:var(--font-display);font-weight:800;font-size:1rem}
.app-bar__brand span{color:var(--gold-500);font-weight:600;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;margin-left:.25rem}
.app-bar__nav{display:flex;gap:1.1rem;margin-left:.6rem}
.app-bar__nav a{color:rgba(255,255,255,.82);font-size:.9rem}
.app-bar__nav a:hover{color:#fff}
.app-bar__user{margin-left:auto;display:flex;align-items:center;gap:.9rem;font-size:.85rem;color:rgba(255,255,255,.82)}
.app-bar__logout{color:var(--gold-500);font-weight:600}
@media (max-width:560px){
  .app-bar{flex-wrap:wrap;gap:.5rem .9rem}
  .app-bar__nav{margin-left:0}
  .app-bar__user{margin-left:0;width:100%;justify-content:space-between}
}

/* =====================================================================
   Sidebar navigation (desktop rail / mobile top bar)
   ===================================================================== */
.has-rail{padding-left:248px}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:248px;background:var(--navy-900);color:#fff;display:flex;flex-direction:column;padding:1.3rem 1rem;z-index:50;overflow-y:auto}
.sidebar__brand{color:#fff;font-family:var(--font-display);font-weight:800;font-size:1.2rem;padding:.2rem .6rem 1.2rem;line-height:1.1}
.sidebar__brand span{display:block;color:var(--gold-500);font-weight:600;font-size:.64rem;text-transform:uppercase;letter-spacing:.12em;margin-top:.2rem}
.sidebar__nav{display:flex;flex-direction:column;gap:.15rem}
.sidebar__nav a{color:rgba(255,255,255,.8);font-size:.92rem;font-weight:500;padding:.6rem .7rem;border-radius:9px;transition:background .15s,color .15s}
.sidebar__nav a:hover{background:rgba(255,255,255,.09);color:#fff}
.sidebar__user{margin-top:auto;border-top:1px solid rgba(255,255,255,.13);padding-top:.9rem;display:flex;flex-direction:column;gap:.35rem}
.sidebar__name{font-size:.85rem;color:rgba(255,255,255,.68);padding:0 .7rem}
.sidebar__logout{color:var(--gold-500);font-weight:600;font-size:.9rem;padding:.2rem .7rem}
@media (max-width:900px){
  .has-rail{padding-left:0}
  .sidebar{position:static;width:auto;flex-direction:row;align-items:center;flex-wrap:wrap;gap:.5rem 1rem;padding:.7rem 1rem;border-radius:12px;margin-bottom:1.4rem}
  .sidebar__brand{padding:0;font-size:1rem}
  .sidebar__brand span{display:inline;margin-left:.35rem;font-size:.6rem}
  .sidebar__nav{flex-direction:row;flex-wrap:wrap;gap:.2rem}
  .sidebar__nav a{padding:.4rem .6rem;font-size:.88rem}
  .sidebar__user{margin-top:0;margin-left:auto;border-top:0;padding-top:0;flex-direction:row;align-items:center;gap:.9rem}
  .sidebar__name{padding:0}
  .sidebar__logout{padding:0}
}
@media print{ .has-rail{padding-left:0 !important} }

/* =====================================================================
   Pipeline stage badges
   ===================================================================== */
.stage{display:inline-block;padding:.2rem .65rem;border-radius:100px;font-size:.74rem;font-weight:600;white-space:nowrap}
.stage-new{background:#eef1f5;color:#5a6473}
.stage-shortlisted{background:#e7eefb;color:#2f5fc0}
.stage-interviewed{background:#fbf2e0;color:#a9740f}
.stage-hired{background:#e6f4ea;color:#1f8b4c}
.stage-rejected{background:#fdecec;color:#c0392b}

/* Sidebar grouped nav sections */
.sidebar__section{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.11em;color:rgba(255,255,255,.38);padding:.6rem .7rem .2rem;margin-top:.45rem}
.sidebar__nav a{padding-left:1.15rem}
@media (max-width:900px){
  .sidebar__section{display:none}
  .sidebar__nav a{padding-left:.6rem}
}
