/* ============================================================
 * UBIK by Forward Cyber — CTFd theme (fork of core-beta)
 * Loaded after CTFd's framework CSS. Imports the portal design
 * system, then maps every CTFd component onto the same look.
 * ============================================================ */
@import url("ubik-portal.css");

/* ---------- base / atmosphere ---------- */
/* Background IDENTICAL to the portal/challenges: dot-grid + targeting glows
   (body::before) + scanlines/grain (body::after), behind all content.
   IMPORTANT: html is the opaque canvas; body MUST stay transparent, otherwise
   the body's own background paints over body::before and hides the grid. */
html { background: var(--bg) !important; color: var(--ink) !important;
  font-family: var(--font-sans) !important; }
body { background: transparent !important; color: var(--ink) !important;
  font-family: var(--font-sans) !important;
  min-height:100vh; position:relative; overflow-x:hidden; display:flex; flex-direction:column;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
body::before { content:''; position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(110% 90% at 50% -20%, rgba(69,231,224,.07), transparent 60%),
    radial-gradient(80% 70% at 110% 0%, rgba(198,251,80,.06), transparent 55%),
    linear-gradient(rgba(160,182,190,.12) 1px, transparent 1px) 0 0 / 100% 44px,
    linear-gradient(90deg, rgba(160,182,190,.12) 1px, transparent 1px) 0 0 / 44px 100%,
    var(--bg);
  /* centred vignette so the square grid stays visible across the whole page */
  -webkit-mask-image: radial-gradient(135% 130% at 50% 38%, #000 72%, transparent 100%);
          mask-image: radial-gradient(135% 130% at 50% 38%, #000 72%, transparent 100%);
  opacity:1; }
body::after { content:''; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image: repeating-linear-gradient(0deg, rgba(0,0,0,.16) 0, rgba(0,0,0,.16) 1px, transparent 1px, transparent 3px);
  opacity:.35; mix-blend-mode:multiply; }
::selection { background: var(--lime); color: #07140a; }
main[role="main"] { flex:1 0 auto; padding: 2.5rem 0 3rem; }
h1,h2,h3,h4,h5 { font-family: var(--font-display); color: var(--ink); letter-spacing:-.01em; }
a { color: var(--cyan); } a:hover { color: var(--lime); text-decoration: none; }
code,kbd,pre,.text-monospace { font-family: var(--font-mono); color: var(--lime-bright); }
.text-muted,.text-secondary { color: var(--muted) !important; }
hr { border-color: var(--line) !important; }

/* ---------- navbar (forked markup) ---------- */
.ubik-logo img { height: 56px !important; width: auto;
  filter: drop-shadow(0 0 10px rgba(198,251,80,.22)); }
.ubik-navbar { padding: .55rem 0; }
.ubik-nav-main { display: flex; align-items: center; gap: .35rem; margin-left: 1.2rem; margin-right: auto; }
.ubik-nav-link { font-family: var(--font-mono); font-weight: 700; font-size: .82rem;
  text-transform: uppercase; letter-spacing: .03em; color: var(--ink-soft);
  text-decoration: none; padding: .45rem .7rem; border-radius: var(--r-sm); transition: all var(--fast); }
.ubik-nav-link:hover { color: var(--bg); background: var(--lime); }
.ubik-nav-account { display: flex; align-items: center; gap: .15rem; }
.ubik-nav-icon { position: relative; display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: var(--r-sm); color: var(--ink-soft);
  text-decoration: none; transition: all var(--fast); }
.ubik-nav-icon:hover { color: var(--lime); background: var(--panel-3); }
.ubik-nav-logout:hover { color: var(--danger); }
.ubik-nav-badge { position:absolute; top:4px; right:4px; min-width:15px; height:15px; padding:0 3px;
  font-family:var(--font-mono); font-size:.6rem; line-height:15px; text-align:center;
  background:var(--danger); color:#fff; border-radius:8px; }
.ubik-nav-burger { display:none; flex-direction:column; gap:4px; background:transparent; border:0;
  cursor:pointer; padding:.5rem; }
.ubik-nav-burger span { width:22px; height:2px; background:var(--ink); border-radius:2px; }

/* ---------- footer ---------- */
.ubik-footer { position: relative; z-index: 1; flex-shrink: 0; margin-top: 2rem;
  padding: 1.5rem 0; border-top: 1px solid var(--line-bright);
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.35)); }
.ubik-footer-inner { max-width: 1280px; margin: 0 auto; padding: 0 1.5rem;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .5rem; }
.ubik-footer-mark { font-family: var(--font-display); font-weight: 800; color: var(--ink); }
.ubik-footer-mark b { color: var(--lime); }
.ubik-footer small { color: var(--muted); }
.ubik-footer a { color: var(--cyan); font-weight: 600; } .ubik-footer a:hover { color: var(--lime); }

/* ---------- buttons (Bootstrap classes used by CTFd) ---------- */
.btn { font-family: var(--font-sans); font-weight: 600; border-radius: var(--r-sm); }
.btn-primary,.btn-info { background: var(--lime) !important; border-color: var(--lime) !important; color:#0a0c08 !important; font-weight:700; }
.btn-primary:hover,.btn-info:hover { background: var(--lime-bright) !important; border-color: var(--lime-bright) !important; box-shadow: var(--glow-lime); }
.btn-success { background: var(--success) !important; border-color: var(--success) !important; color:#06140c !important; font-weight:700; }
.btn-danger { background: var(--danger) !important; border-color: var(--danger) !important; }
.btn-secondary,.btn-outline-secondary { color: var(--ink) !important; border-color: var(--line-bright) !important; background: transparent !important; }
.btn-outline-secondary:hover,.btn-secondary:hover { background: var(--panel-3) !important; border-color: var(--cyan) !important; color: var(--cyan) !important; }
.btn-outline-danger { color: var(--danger) !important; border-color: var(--danger) !important; }
.btn-outline-danger:hover { background: var(--danger) !important; color:#fff !important; }

/* ---------- forms ---------- */
.form-control,.input-group-text,select,textarea,.form-select { background: var(--panel-2) !important;
  border: 1px solid var(--line-bright) !important; color: var(--ink) !important; border-radius: var(--r-sm); }
.form-control:focus,.form-select:focus { border-color: var(--lime) !important;
  box-shadow: 0 0 0 .15rem rgba(198,251,80,.18) !important; background: var(--panel-3) !important; color:var(--ink)!important; }
.form-control::placeholder { color: var(--dim) !important; }
label,.form-check-label,.col-form-label { color: var(--ink-soft) !important; }

/* ---------- cards / jumbotron / page heads ---------- */
.card,.modal-content,.list-group-item { background: var(--panel) !important; border: 1px solid var(--line) !important;
  border-radius: var(--r-lg); color: var(--ink) !important; }
.card-header,.modal-header,.card-footer,.modal-footer { background: var(--panel-2) !important; border-color: var(--line) !important; color: var(--ink) !important; }
.jumbotron,.bg-light { background: linear-gradient(180deg, rgba(14,16,18,.9), rgba(18,21,24,.6)) !important;
  color: var(--ink) !important; border: 1px solid var(--line) !important; border-radius: var(--r-xl); padding: 2.5rem; }
.jumbotron h1 { font-family: var(--font-display) !important; font-weight: 800 !important;
  font-size: clamp(2rem,5vw,3.1rem) !important; letter-spacing:-.02em; }
.jumbotron h1::before { content:"// "; color: var(--lime); font-family: var(--font-mono); font-weight:700; }

/* ---------- challenge board (CTFd JS-rendered) ---------- */
.category-header { display:flex; align-items:center; gap:.9rem; }
.category-header :is(h1,h2,h3,h4,h5){ font-family:var(--font-mono)!important; text-transform:uppercase;
  letter-spacing:.05em; font-size:.95rem!important; color:var(--ink)!important; margin:0; white-space:nowrap; }
.category-header :is(h1,h2,h3,h4,h5)::before{ content:"▸ "; color:var(--lime); }
.category-header::after{ content:""; flex:1 1 auto; height:1px; background:linear-gradient(90deg,var(--line-bright),transparent); }
.challenge-button.btn-dark{ position:relative; background:linear-gradient(180deg,var(--panel-2),var(--panel))!important;
  border:1px solid var(--line-bright)!important; border-radius:var(--r-md)!important; color:var(--ink)!important;
  padding:1.1rem .9rem!important; overflow:visible; min-height:96px;
  transition:transform .14s var(--ease),box-shadow .14s,border-color .14s; animation:ubik-rise .5s var(--ease-out) both; }
.challenge-button.btn-dark::before,.challenge-button.btn-dark::after{ content:""; position:absolute; width:11px; height:11px; border:1.5px solid var(--lime); opacity:0; transition:opacity .14s; }
.challenge-button.btn-dark::before{ top:7px; left:7px; border-right:0; border-bottom:0; }
.challenge-button.btn-dark::after{ bottom:7px; right:7px; border-left:0; border-top:0; }
.challenge-button.btn-dark:hover{ transform:translateY(-3px); border-color:var(--lvl,var(--lime))!important;
  box-shadow:0 0 0 1px var(--lvl,rgba(198,251,80,.4)),0 14px 30px -14px var(--lvl,rgba(198,251,80,.5))!important; }
.challenge-button.btn-dark:hover::before,.challenge-button.btn-dark:hover::after{ opacity:.9; }
/* tile text (board markup: .challenge-inner > p[name] + span[value]) */
.challenge-button.text-truncate{ white-space:normal!important; overflow:visible!important; }
.challenge-button .challenge-inner{ display:flex; flex-direction:column; gap:.55rem; height:100%; justify-content:space-between; }
.challenge-button .challenge-inner p{ font-family:var(--font-display)!important; font-weight:700!important;
  color:var(--ink)!important; margin:0; line-height:1.25; white-space:normal; }
.challenge-button .challenge-inner span{ font-family:var(--font-mono)!important; color:var(--lvl,var(--lime))!important; font-weight:700; }
.challenge-button .challenge-inner span::before{ content:"◇ "; opacity:.7; }
/* difficulty colouring (threat ramp), like the splash cards — set by board.js */
.challenge-button.ubik-lvl-1{ --lvl:var(--t1); } .challenge-button.ubik-lvl-2{ --lvl:var(--t2); }
.challenge-button.ubik-lvl-3{ --lvl:var(--t3); } .challenge-button.ubik-lvl-4{ --lvl:var(--t4); }
.challenge-button.btn-dark{ border-top:2px solid var(--lvl,var(--line-bright))!important; }
.challenge-button.btn-dark::before,.challenge-button.btn-dark::after{ border-color:var(--lvl,var(--lime)); }
.challenge-button.challenge-solved{ border-color:var(--success)!important; box-shadow:0 0 0 1px rgba(91,217,138,.4)!important; }
.challenge-button.challenge-solved .challenge-inner span{ color:var(--success)!important; }
.category-challenges .challenge-button:nth-child(1){animation-delay:.02s}
.category-challenges .challenge-button:nth-child(2){animation-delay:.07s}
.category-challenges .challenge-button:nth-child(3){animation-delay:.12s}
.category-challenges .challenge-button:nth-child(4){animation-delay:.17s}
.category-challenges .challenge-button:nth-child(n+5){animation-delay:.22s}
@keyframes ubik-rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.challenge-button.btn-dark{animation:none!important}}

/* ---------- challenge modal ---------- */
.challenge-inner{ background:var(--panel)!important; }
.challenge-submit.btn{ background:var(--lime)!important; border-color:var(--lime)!important; color:#0a0c08!important; font-weight:700; }
.challenge-input.form-control{ background:var(--panel-2)!important; border-color:var(--line-bright)!important; color:var(--ink)!important; }
.challenge-tag.badge{ background:var(--cyan)!important; color:#04201f!important; }
.challenge-connection-info,.challenge-connection-info code{ color:var(--lime-bright)!important; }

/* ---------- tables / scoreboard ---------- */
/* Bootstrap forces a dark --bs-table-color on the cells (higher specificity than
   .table), making text invisible on the dark theme -> re-point the vars to ink. */
.table{ color:var(--ink)!important; --bs-table-color:var(--ink); --bs-table-striped-color:var(--ink); --bs-table-hover-color:var(--ink); --bs-table-active-color:var(--ink); --bs-table-bg:transparent; }
.table thead th,.table thead td{ color:var(--lime)!important; border-color:var(--line-bright)!important; text-transform:uppercase;
  font-size:.78rem; letter-spacing:.04em; font-family:var(--font-mono)!important; }
.table td,.table th{ border-color:var(--line)!important; }
.table-striped tbody tr:nth-of-type(odd){ background:rgba(255,255,255,.02)!important; }
.table-hover tbody tr:hover{ background:rgba(69,231,224,.06)!important; }

/* ---------- misc ---------- */
.badge.badge-info,.badge.bg-info{ background:var(--cyan)!important; color:#04201f!important; }
.badge.badge-secondary,.badge.bg-secondary{ background:var(--panel-3)!important; color:var(--ink-soft)!important; }
.badge.badge-success,.badge.bg-success{ background:var(--success)!important; color:#06140c!important; }
.alert-success{ background:rgba(91,217,138,.12)!important; border-color:var(--success)!important; color:var(--success)!important; }
.alert-danger{ background:rgba(255,77,77,.12)!important; border-color:var(--danger)!important; color:#ff8a8a!important; }
.alert-warning{ background:rgba(255,194,71,.12)!important; border-color:var(--warning)!important; color:var(--warning)!important; }
.alert-info{ background:rgba(69,231,224,.1)!important; border-color:var(--cyan)!important; color:var(--cyan)!important; }
.page-link{ background:var(--panel-2)!important; border-color:var(--line)!important; color:var(--ink-soft)!important; }
.page-item.active .page-link{ background:var(--lime)!important; border-color:var(--lime)!important; color:#0a0c08!important; }
.nav-tabs .nav-link.active{ background:var(--panel)!important; border-color:var(--line-bright) var(--line-bright) var(--panel)!important; color:var(--lime)!important; }
.nav-tabs .nav-link{ color:var(--ink-soft)!important; }
/* nav-pills (settings tabs) were stock blue */
.nav-pills .nav-link{ color:var(--ink-soft)!important; }
.nav-pills .nav-link.active{ background:var(--lime)!important; color:var(--bg)!important; font-weight:700; }
.nav-pills .nav-link:hover:not(.active){ color:var(--lime)!important; }
/* kill Bootstrap's blue focus ring on inputs */
.form-control:focus,.form-select:focus{ border-color:var(--lime)!important; box-shadow:0 0 0 .2rem rgba(198,251,80,.15)!important; }
/* profile / users pages on the dark theme */
#score-graph{ display:none!important; }                 /* kill the stock Plotly "score over time" */
.jumbotron h2,.jumbotron h3,.jumbotron .h2,.jumbotron .h3{ color:var(--ink)!important; }  /* place / points were dark-on-dark */
.jumbotron small{ color:var(--muted)!important; }
.badge.bg-primary,.badge.badge-primary{ background:var(--lime)!important; color:#0a0c08!important; }  /* Official/affiliation/country were stock blue */
.progress{ background:var(--panel-3)!important; } .progress-bar{ background:var(--lime)!important; }
.modal-backdrop{ background:#000!important; }
.spinner,.fa-spin{ color:var(--lime); }

/* ============ bespoke challenge board (splash cards, API-driven) ============ */
.section-head{ max-width:1280px; margin:1.5rem auto 1.5rem; padding:0 1.5rem; display:flex; align-items:center; gap:1rem; }
.section-head .mono-label{ font-family:var(--font-mono); font-size:.82rem; letter-spacing:.04em; white-space:nowrap; color:var(--lime); text-transform:uppercase; }
.section-head.ctf .mono-label{ color:var(--cyan); }
.section-head .rule{ flex:1; height:1px; background:var(--line); }
.section-head .count{ font-family:var(--font-mono); font-size:.74rem; color:var(--muted); white-space:nowrap; }

.filter-tabs{ display:flex; flex-wrap:wrap; gap:.5rem; max-width:1280px; margin:0 auto 1.5rem; padding:0 1.5rem; }
.filter-tab{ padding:.5rem 1rem; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-sm);
  color:var(--muted); cursor:pointer; font-family:var(--font-mono); font-size:.76rem; letter-spacing:.03em;
  transition:all var(--fast); display:inline-flex; align-items:center; gap:.5rem; }
.filter-tab .tdot{ width:8px; height:8px; border-radius:50%; background:var(--dim); }
.filter-tab[data-filter="1"] .tdot{ background:var(--t1); } .filter-tab[data-filter="2"] .tdot{ background:var(--t2); }
.filter-tab[data-filter="3"] .tdot{ background:var(--t3); } .filter-tab[data-filter="4"] .tdot{ background:var(--t4); }
.filter-tab:hover{ color:var(--ink); border-color:var(--line-bright); }
.filter-tab.active{ color:#08130a; background:var(--lime); border-color:var(--lime); }
.filter-tab.active .tdot{ background:#08130a; }

.challenges-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:1.1rem;
  max-width:1280px; margin:0 auto 2.5rem; padding:0 1.5rem; }
.challenge-card-link{ text-decoration:none; display:block; opacity:0; transform:translateY(14px); cursor:pointer; }
.challenge-card-link.in{ animation:cardIn .5s var(--ease-out) forwards; animation-delay:var(--d,0ms); }
@keyframes cardIn{ to{ opacity:1; transform:translateY(0); } }
@media (prefers-reduced-motion:reduce){ .challenge-card-link{ opacity:1!important; transform:none!important; animation:none!important; } }
.challenge-card-item{ position:relative; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:1.5rem; height:100%; overflow:hidden; transition:border-color var(--norm),transform var(--norm),box-shadow var(--norm); }
.challenge-card-item::before{ content:''; position:absolute; top:0; left:0; right:0; height:3px; transform:scaleX(0); transform-origin:left; transition:transform var(--norm); }
.challenge-card-item.level-1::before{ background:var(--t1); } .challenge-card-item.level-2::before{ background:var(--t2); }
.challenge-card-item.level-3::before{ background:var(--t3); } .challenge-card-item.level-4::before{ background:var(--t4); }
.challenge-card-item .bracket{ position:absolute; width:14px; height:14px; opacity:0; transition:opacity var(--norm),transform var(--norm); border-color:var(--lime); }
.bracket.tl{ top:10px; left:10px; border-top:2px solid; border-left:2px solid; transform:translate(4px,4px); }
.bracket.br{ bottom:10px; right:10px; border-bottom:2px solid; border-right:2px solid; transform:translate(-4px,-4px); }
.challenge-card-link:hover .challenge-card-item{ border-color:var(--lime); transform:translateY(-4px); box-shadow:var(--glow-lime); }
.challenge-card-link:hover .challenge-card-item::before{ transform:scaleX(1); }
.challenge-card-link:hover .bracket{ opacity:1; transform:translate(0,0); }
.card-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:1.1rem; }
.card-id{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; color:var(--dim); }
.card-pts{ font-family:var(--font-mono); font-size:.78rem; color:var(--lvl,var(--lime)); font-weight:700; }
.card-solved{ font-family:var(--font-mono); font-size:.7rem; color:var(--success); font-weight:700; }
.card-team{ font-family:var(--font-mono); font-size:.7rem; color:var(--cyan); font-weight:700; opacity:.85; }
.card-icon{ width:46px; height:46px; border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; border:1px solid var(--line-bright); margin-bottom:1.1rem; font-size:1.1rem; }
.card-icon.level-1{ background:rgba(91,217,138,.12); color:var(--t1); } .card-icon.level-2{ background:rgba(255,194,71,.12); color:var(--t2); }
.card-icon.level-3{ background:rgba(255,122,61,.12); color:var(--t3); } .card-icon.level-4{ background:rgba(255,77,110,.12); color:var(--t4); }
.card-title{ font-family:var(--font-display); font-size:1.16rem; font-weight:700; color:var(--ink); margin-bottom:1rem; line-height:1.2; }
.card-foot{ display:flex; justify-content:space-between; align-items:center; gap:.5rem; }
.card-cat{ font-family:var(--font-mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft); }
.threat{ display:flex; align-items:center; gap:.5rem; } .threat-label{ font-family:var(--font-mono); font-size:.6rem; letter-spacing:.1em; color:var(--dim); }
.threat-bars{ display:flex; gap:3px; } .tbar{ width:13px; height:5px; border-radius:1px; background:var(--line-bright); }
.tbar.on.level-1{ background:var(--t1); } .tbar.on.level-2{ background:var(--t2); } .tbar.on.level-3{ background:var(--t3); } .tbar.on.level-4{ background:var(--t4); }
.card-launch{ margin-top:1.2rem; padding-top:1rem; border-top:1px dashed var(--line); font-family:var(--font-mono); font-size:.74rem; letter-spacing:.06em; color:var(--dim); display:flex; align-items:center; justify-content:space-between; transition:color var(--fast); }
.challenge-card-link:hover .card-launch{ color:var(--lime); } .card-launch .arrow{ transition:transform var(--fast); }
.challenge-card-link:hover .card-launch .arrow{ transform:translateX(4px); }
.challenge-card-item.is-solved{ border-color:var(--success); } .challenge-card-item.is-solved::before{ transform:scaleX(1); background:var(--success); }
/* team solved this, but the current user personally didn't — muted cyan accent */
.challenge-card-item.is-team-solved::before{ transform:scaleX(1); background:var(--cyan); opacity:.55; }
/* CTF labs variant (cyan accent) */
.challenge-card-link.ctf .challenge-card-item::before{ background:linear-gradient(90deg,var(--cyan),var(--lime)); }
.challenge-card-link.ctf:hover .challenge-card-item{ border-color:var(--cyan); box-shadow:var(--glow-cyan); }
.challenge-card-link.ctf:hover .bracket{ border-color:var(--cyan); } .challenge-card-link.ctf:hover .card-launch{ color:var(--cyan); }
.ubik-board-loading{ text-align:center; padding:4rem 0; color:var(--lime); }
.ubik-empty{ text-align:center; padding:3rem 0; color:var(--muted); font-family:var(--font-mono); }

/* ============ bespoke challenge modal ============ */
.ubik-modal[hidden]{ display:none; }
.ubik-modal{ position:fixed; inset:0; z-index:2000; display:flex; align-items:center; justify-content:center; padding:1.5rem; }
.ubik-modal-backdrop{ position:absolute; inset:0; background:rgba(3,4,5,.78); backdrop-filter:blur(4px); }
.ubik-modal-card{ position:relative; z-index:1; width:100%; max-width:640px; max-height:88vh; overflow:auto;
  background:linear-gradient(180deg,var(--panel-2),var(--panel)); border:1px solid var(--line-bright); border-radius:var(--r-xl);
  padding:2rem; box-shadow:0 30px 80px -20px rgba(0,0,0,.8); animation:cardIn .25s var(--ease-out); }
.ubik-modal-x{ position:absolute; top:1rem; right:1rem; width:34px; height:34px; border:1px solid var(--line-bright);
  background:transparent; color:var(--ink-soft); border-radius:var(--r-sm); cursor:pointer; transition:all var(--fast); }
.ubik-modal-x:hover{ color:var(--bg); background:var(--lime); border-color:var(--lime); }
.ubik-modal-head{ display:flex; gap:1rem; align-items:center; margin-bottom:.4rem; }
.ubik-modal-title{ font-family:var(--font-display); font-size:1.7rem; font-weight:800; color:var(--ink); margin:0 0 1rem; }
.ubik-modal-meta{ display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap; margin-bottom:1.3rem; padding-bottom:1.3rem; border-bottom:1px solid var(--line); }
.ubik-modal-pts{ font-family:var(--font-mono); font-weight:700; color:var(--lime); }
.ubik-modal-pts.level-1{ color:var(--t1); } .ubik-modal-pts.level-2{ color:var(--t2); } .ubik-modal-pts.level-3{ color:var(--t3); } .ubik-modal-pts.level-4{ color:var(--t4); }
.ubik-modal-solves{ font-family:var(--font-mono); font-size:.8rem; color:var(--muted); }
.ubik-modal-desc{ color:var(--ink-soft); line-height:1.65; margin-bottom:1.4rem; }
.ubik-modal-desc a{ color:var(--cyan); } .ubik-modal-desc code{ color:var(--lime-bright); }
.ubik-launch{ display:inline-flex; margin-bottom:1.4rem; }
.ubik-flag-form{ display:flex; gap:.6rem; }
.ubik-flag-input{ flex:1; font-family:var(--font-mono); }
.ubik-flag-result{ margin-top:.9rem; font-family:var(--font-mono); font-size:.85rem; min-height:1.2em; }
.ubik-flag-result.ok{ color:var(--success); } .ubik-flag-result.ko{ color:var(--danger); } .ubik-flag-result.warn{ color:var(--warning); } .ubik-flag-result.pending{ color:var(--muted); }
@media (max-width:768px){ .challenges-grid{ grid-template-columns:1fr; } }

/* ---------- bespoke scoreboard ---------- */
.ubik-sb-wrap{ max-width:1000px; margin:0 auto 3rem; padding:0 1.5rem; }
.sb-toggle{ display:inline-flex; gap:.3rem; margin-bottom:1.6rem; padding:.3rem; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-md); }
.sb-tab{ font-family:var(--font-mono); font-size:.8rem; letter-spacing:.02em; padding:.5rem 1.1rem; border:0; background:transparent; color:var(--muted); cursor:pointer; border-radius:var(--r-xs); transition:all var(--fast); }
.sb-tab:hover{ color:var(--ink); }
.sb-tab.active{ background:var(--lime); color:var(--bg); font-weight:700; }
.sb-sub{ display:block; font-family:var(--font-mono); font-size:.66rem; color:var(--muted); margin-top:.12rem; font-weight:400; letter-spacing:.02em; }
.sb-podium{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:2rem; }
.sb-podium-item{ position:relative; background:linear-gradient(180deg,var(--panel-2),var(--panel)); border:1px solid var(--line-bright);
  border-radius:var(--r-lg); padding:1.4rem; text-align:center; overflow:hidden; }
.sb-podium-item::before{ content:""; position:absolute; top:0; left:0; right:0; height:4px; background:var(--line-bright); }
.sb-podium-item.rank-1::before{ background:var(--lime); } .sb-podium-item.rank-2::before{ background:var(--cyan); } .sb-podium-item.rank-3::before{ background:var(--t2); }
.sb-podium-item.rank-1{ box-shadow:0 0 0 1px rgba(198,251,80,.25),0 18px 40px -22px rgba(198,251,80,.5); }
.sb-podium-item.me{ outline:1px dashed var(--cyan); }
.sb-podium-rank{ font-family:var(--font-mono); font-size:.9rem; color:var(--lime); }
.sb-podium-item.rank-2 .sb-podium-rank{ color:var(--cyan); } .sb-podium-item.rank-3 .sb-podium-rank{ color:var(--t2); }
.sb-podium-name{ font-family:var(--font-display); font-weight:700; font-size:1.15rem; color:var(--ink); margin:.4rem 0; word-break:break-word; }
.sb-podium-score{ font-family:var(--font-mono); font-size:1.4rem; font-weight:700; color:var(--ink); } .sb-podium-score span{ font-size:.8rem; color:var(--muted); }
.sb-list{ background:var(--panel); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; }
.sb-head,.sb-row{ display:grid; grid-template-columns:50px 1fr 2fr 80px; align-items:center; gap:1rem; padding:.8rem 1.2rem; }
.sb-head{ background:var(--panel-2); border-bottom:1px solid var(--line-bright); font-family:var(--font-mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.05em; color:var(--lime); }
.sb-row{ border-bottom:1px solid var(--line-soft); transition:background var(--fast); }
.sb-row:last-child{ border-bottom:0; } .sb-row:hover{ background:rgba(255,255,255,.02); }
.sb-row.me{ background:rgba(69,231,224,.07); }
.sb-rank{ font-family:var(--font-mono); color:var(--muted); }
.sb-name{ font-weight:600; color:var(--ink); }
.sb-you{ font-family:var(--font-mono); font-size:.62rem; text-transform:uppercase; letter-spacing:.08em; color:#04201f; background:var(--cyan); padding:.1rem .4rem; border-radius:var(--r-xs); margin-left:.4rem; }
.sb-bar{ height:8px; background:var(--panel-3); border-radius:6px; overflow:hidden; }
.sb-bar-fill{ display:block; height:100%; background:linear-gradient(90deg,var(--lime-deep),var(--lime)); border-radius:6px; }
.sb-score{ font-family:var(--font-mono); font-weight:700; color:var(--lime); text-align:right; }
.sb-head .sb-bar{ background:transparent; }
@media (max-width:680px){ .sb-podium{ grid-template-columns:1fr; } .sb-head,.sb-row{ grid-template-columns:36px 1fr 60px; } .sb-bar{ display:none; } }

/* ---------- logged-in home dashboard ---------- */
.ubik-dash{ max-width:1100px; margin:1rem auto 0; padding:0 1.5rem; }
.dash-head{ margin-bottom:1.8rem; }
.dash-eyebrow{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-mono); font-size:.74rem;
  letter-spacing:.1em; color:var(--lime); text-transform:uppercase; }
.dash-eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--lime); box-shadow:0 0 10px var(--lime); }
.dash-head h1{ font-family:var(--font-display); font-size:clamp(2rem,5vw,3rem); font-weight:800; margin:.4rem 0 .2rem; }
.dash-head h1 .accent{ color:var(--lime); }
.dash-team{ color:var(--muted); font-family:var(--font-mono); font-size:.85rem; }
.dash-team strong{ color:var(--cyan); }
.dash-team-score{ color:var(--lime); }
.dash-me{ display:inline-flex; align-items:center; flex-wrap:wrap; gap:.45rem; margin:.7rem 0 0; padding:.5rem .9rem; font-family:var(--font-mono);
  font-size:.82rem; color:var(--ink-soft); background:rgba(198,251,80,.06); border:1px solid var(--line-bright); border-radius:var(--r-md); }
.dash-me strong{ color:var(--lime); }
.dash-me .dash-rank{ color:var(--cyan); font-weight:700; }
.dash-me a{ color:var(--muted); text-decoration:none; border-bottom:1px dotted var(--line-bright); }
.dash-me a:hover{ color:var(--lime); }
/* bespoke "score over time" chart (profile pages) — replaces stock Plotly */
.ubik-chart-card{ background:var(--panel); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.3rem 1.4rem; margin:1rem 0; }
.ubik-chart-h{ margin-bottom:.9rem; } .ubik-chart-h .mono-label{ font-family:var(--font-mono); font-size:.8rem; color:var(--lime); letter-spacing:.04em; }
.ubik-chart-empty{ font-family:var(--font-mono); font-size:.85rem; color:var(--muted); padding:1.4rem 0; text-align:center; }
.ubik-score-svg{ width:100%; height:auto; display:block; overflow:visible; }
.uc-grid{ stroke:var(--line-soft); stroke-width:1; }
.uc-area{ fill:rgba(198,251,80,.10); stroke:none; }
.uc-line{ fill:none; stroke:var(--lime); stroke-width:2.5; stroke-linejoin:round; stroke-linecap:round; }
.uc-dot{ fill:var(--bg); stroke:var(--lime); stroke-width:2; }
.uc-lbl{ fill:var(--muted); font-family:var(--font-mono); font-size:11px; }
.dash-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:1.6rem; }
.dstat{ background:linear-gradient(180deg,var(--panel-2),var(--panel)); border:1px solid var(--line-bright);
  border-radius:var(--r-lg); padding:1.4rem 1.5rem; position:relative; overflow:hidden; }
.dstat::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:var(--lime); opacity:.8; }
.dstat:nth-child(2)::before{ background:var(--cyan); } .dstat:nth-child(3)::before{ background:var(--t2); }
.dstat-val{ font-family:var(--font-display); font-size:2.4rem; font-weight:800; color:var(--ink); line-height:1; }
.dstat-sub{ font-size:1.1rem; color:var(--muted); font-family:var(--font-mono); }
.dstat-label{ font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); margin-top:.5rem; }
.dash-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1.6rem; }
.dash-card{ background:var(--panel); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.4rem 1.5rem; }
.dash-card-h{ margin-bottom:1.1rem; } .dash-card-h .mono-label{ font-family:var(--font-mono); font-size:.8rem; color:var(--lime); letter-spacing:.04em; }
.dash-lvl{ display:flex; align-items:center; gap:.9rem; margin:.7rem 0; }
.dash-lvl-name{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-soft); width:74px; flex:0 0 74px; }
.dash-lvl-track{ flex:1; height:8px; background:var(--panel-3); border-radius:6px; overflow:hidden; }
.dash-lvl-fill{ height:100%; border-radius:6px; transition:width .6s var(--ease-out); }
.dash-lvl-fill.lvl-1{ background:var(--t1); } .dash-lvl-fill.lvl-2{ background:var(--t2); }
.dash-lvl-fill.lvl-3{ background:var(--t3); } .dash-lvl-fill.lvl-4{ background:var(--t4); }
.dash-lvl-num{ font-family:var(--font-mono); font-size:.74rem; color:var(--muted); width:42px; text-align:right; }
.dash-next-item{ display:flex; align-items:center; gap:.7rem; padding:.6rem .2rem; border-bottom:1px solid var(--line-soft); text-decoration:none; transition:all var(--fast); }
.dash-next-item:last-child{ border-bottom:0; } .dash-next-item:hover{ padding-left:.6rem; }
.dash-next-dot{ width:8px; height:8px; border-radius:50%; flex:0 0 8px; }
.dash-next-dot.lvl-1{ background:var(--t1); } .dash-next-dot.lvl-2{ background:var(--t2); } .dash-next-dot.lvl-3{ background:var(--t3); } .dash-next-dot.lvl-4{ background:var(--t4); }
.dash-next-name{ flex:1; color:var(--ink); font-weight:600; font-size:.92rem; }
.dash-next-item:hover .dash-next-name{ color:var(--lime); }
.dash-next-pts{ font-family:var(--font-mono); font-size:.8rem; color:var(--lime); }
.dash-done{ color:var(--success); font-family:var(--font-mono); }
.dash-cta{ display:flex; gap:1rem; flex-wrap:wrap; }
/* on-demand lab button (dashboard card + challenge modal "header") */
.ubik-lab-card{ margin-bottom:1.6rem; border-color:var(--line-bright)!important;
  background:linear-gradient(180deg,var(--panel-2),var(--panel))!important; }
.ubik-lab-sub{ color:var(--muted); margin:0 0 1rem; }
/* challenge modal: borderless, compact inline row (the modal is already a card) */
.ubik-modal-lab{ margin:0 0 1.1rem; }
.ubik-lab-slot{ display:flex; align-items:center; gap:.7rem .9rem; flex-wrap:wrap; }
.ubik-lab-btn{ display:inline-flex; align-items:center; gap:.5rem; padding:.5rem .95rem; font-size:.86rem; }
.ubik-lab-btn[disabled]{ opacity:.7; cursor:default; }
.ubik-lab-btn .ubik-lab-cd{ font-family:var(--font-mono); letter-spacing:.02em; }
.ubik-lab-dot{ display:inline-block; width:8px; height:8px; border-radius:50%; background:var(--success);
  box-shadow:0 0 9px var(--success); animation:pulse 1.6s infinite; margin-right:.4rem; vertical-align:middle; }
/* status sits inline next to the button; collapses (no reserved height) when empty */
.ubik-lab-msg{ margin:0; font-family:var(--font-mono); font-size:.78rem; color:var(--muted); }
.ubik-lab-msg:empty{ display:none; }
.ubik-lab-msg.live{ color:var(--success); } .ubik-lab-msg.ko{ color:var(--danger); }
.ubik-lab-msg.pending{ color:var(--warning); } .ubik-lab-msg.muted{ color:var(--muted); }
@media (max-width:760px){ .dash-stats{ grid-template-columns:1fr; } .dash-grid{ grid-template-columns:1fr; } }

/* ---------- home splash hero (index page) — ported verbatim from the portal ---------- */
.hero { position:relative; padding:4.5rem 1.5rem 3.5rem; max-width:1280px; margin:0 auto; overflow:hidden; }
.hero-eyebrow { display:inline-flex; align-items:center; gap:.6rem; font-family:var(--font-mono);
  font-size:.74rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted);
  margin-bottom:1.6rem; padding:.35rem .7rem; border:1px solid var(--line); border-radius:var(--r-xs); background:var(--panel); }
.hero-eyebrow .dot { width:7px; height:7px; border-radius:50%; background:var(--lime); box-shadow:0 0 10px var(--lime); animation:pulse 1.6s infinite; }
.hero-eyebrow b { color:var(--cyan); font-weight:700; }
.hero h1 { font-family:var(--font-display); font-weight:800; font-size:clamp(2.8rem,9vw,6.2rem);
  line-height:.94; letter-spacing:-.035em; margin:0 0 1.3rem; color:var(--ink); }
.hero h1 .accent { color:var(--lime); position:relative; }
.hero h1 .accent::after { content:'_'; color:var(--cyan); animation:blink 1.1s steps(1) infinite; margin-left:.05em; }
.hero-sub { max-width:640px; font-size:1.12rem; line-height:1.65; color:var(--ink-soft); margin:0 0 2.4rem; }
.hero-stats { display:flex; flex-wrap:wrap; gap:0; border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; width:fit-content; background:var(--panel); }
.stat-item { padding:1.1rem 1.8rem; border-right:1px solid var(--line); }
.stat-item:last-child { border-right:none; }
.stat-value { font-family:var(--font-display); font-size:2.4rem; font-weight:800; line-height:1; color:var(--lime); font-variant-numeric:tabular-nums; }
.stat-label { font-family:var(--font-mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.14em; color:var(--muted); margin-top:.4rem; }
.hero-scope { position:absolute; top:50%; right:-120px; transform:translateY(-50%); width:420px; height:420px; pointer-events:none; z-index:-1; opacity:.5; }
.hero-scope::before, .hero-scope::after { content:''; position:absolute; inset:0; border-radius:50%; border:1px solid var(--line); }
.hero-scope::after { inset:70px; border-color:var(--line-soft); }
@keyframes pulse { 0%,100%{ opacity:1; } 50%{ opacity:.45; } }
.hero-cta { display:flex; gap:1rem; flex-wrap:wrap; margin-top:2.4rem; }
.hero-cta .nav-login-cta { font-size:.9rem; padding:.8rem 1.4rem; }
.hero-cta-ghost { background:transparent !important; color:var(--cyan) !important; border:1px solid var(--line-bright); }
.hero-cta-ghost:hover { border-color:var(--lime); color:var(--lime) !important; box-shadow:none !important; }
@media (max-width:768px){ .hero{ padding-top:3rem; } .hero-scope{ display:none; } .stat-item{ padding:.9rem 1.1rem; } .stat-value{ font-size:1.9rem; } }
/* no-flash: authed users never see the hero (dashboard replaces it) */
.ubik-authed #ubik-home > .hero { display:none !important; }

/* hide stock footer if it ever renders */
footer.footer{ display:none!important; }

/* ---------- responsive navbar ---------- */
@media (max-width: 860px){
  .ubik-nav-burger{ display:flex; order:3; }
  .ubik-nav-main,.ubik-nav-account{ display:none; width:100%; }
  .ubik-navbar-content.open .ubik-nav-main,
  .ubik-navbar-content.open .ubik-nav-account{ display:flex; flex-wrap:wrap; margin:.5rem 0 0; }
  .ubik-navbar-content.open .ubik-nav-main{ margin-left:0; }
}
