/* ============================================================================
   OXTON — Premium admin dashboard (dark, SaaS enterprise). Self-contained.
   ============================================================================ */
*,*::before,*::after{box-sizing:border-box}
.adm-body{
  /* Light theme only (the dark/light switch was removed). Sidebar stays dark. */
  --bg:#f1f5f9; --bg2:#fff; --side:#0a1124; --card:#fff; --card2:#f8fafc;
  --line:rgba(15,23,42,.08); --line2:rgba(15,23,42,.12);
  --txt:#0f172a; --txt2:#475569; --txt3:#94a3b8;
  --blue:#1E5EFF; --blue2:#2563EB; --green:#10B981; --orange:#F59E0B; --red:#EF4444; --violet:#8B5CF6;
  --r:14px; --r-sm:10px; --sidew:290px; --sidew-collapsed:84px;
  margin:0;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--txt);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:14px;
}
.adm-body a{color:inherit;text-decoration:none}
.adm-body svg.ico{width:18px;height:18px;flex:0 0 auto}
.adm-body svg.ico--sm{width:14px;height:14px}
/* scrollbar — invisible (scroll still works) */
::-webkit-scrollbar{width:0;height:0;display:none}
html,.adm-body,.adm-side,.adm-nav,.adm-main,.adm-content{scrollbar-width:none;-ms-overflow-style:none}

.adm{display:flex;min-height:100vh}

/* ===================== SIDEBAR ===================== */
.adm-side{width:var(--sidew);flex:0 0 var(--sidew);background:var(--side);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden}
.adm-side__brand{padding:1.25rem 1.4rem .5rem}
.adm-logo{font-size:1.5rem;font-weight:800;letter-spacing:-.01em;color:#fff}
.adm-logo b{color:var(--blue)}
.adm-logo__mark{display:none;font-size:1.6rem;font-weight:800;letter-spacing:-.01em;color:#fff}
.adm-logo__mark b{color:var(--blue)}
.adm-logo__sub{display:block;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--txt3);margin-top:.15rem}
/* collapsed rail (desktop) */
.adm.is-collapsed .adm-side{width:var(--sidew-collapsed);flex:0 0 var(--sidew-collapsed)}
.adm.is-collapsed .adm-logo,.adm.is-collapsed .adm-logo__sub,.adm.is-collapsed .adm-nav__label,
.adm.is-collapsed .adm-nav__link span,.adm.is-collapsed .adm-side__foot,
.adm.is-collapsed .adm-workspace__txt,.adm.is-collapsed .adm-search{display:none}
.adm.is-collapsed .adm-logo__mark{display:block;text-align:center}
.adm.is-collapsed .adm-side__brand{text-align:center;padding-left:0;padding-right:0}
.adm.is-collapsed .adm-nav__link{justify-content:center;gap:0;padding-left:0;padding-right:0}
.adm.is-collapsed .adm-nav{padding-left:.4rem;padding-right:.4rem}
.adm-workspace{display:flex;align-items:center;gap:.6rem;margin:.75rem 1rem;padding:.6rem .75rem;background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm)}
.adm-workspace__ico{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--blue),var(--violet));color:#fff;flex:0 0 34px}
.adm-workspace__txt{min-width:0}
.adm-workspace__txt strong{display:block;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adm-workspace__txt span{font-size:.7rem;color:var(--txt2)}
.adm-search{display:flex;align-items:center;gap:.5rem;margin:0 1rem .5rem;padding:.5rem .7rem;background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--txt2)}
.adm-search input{border:0;background:none;outline:none;color:var(--txt);font:inherit;width:100%;font-size:.82rem}
.adm-nav{flex:1;overflow-y:auto;padding:.25rem .65rem 1rem}
.adm-nav__label{display:block;font-size:.64rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--txt3);padding:.9rem .65rem .35rem}
.adm-nav__link{display:flex;align-items:center;gap:.7rem;padding:.55rem .65rem;border-radius:var(--r-sm);color:var(--txt2);
  font-size:.86rem;font-weight:500;transition:background .15s,color .15s}
.adm-nav__link svg{color:var(--txt3);transition:color .15s}
.adm-nav__link:hover{background:rgba(255,255,255,.04);color:var(--txt)}
.adm-nav__link:hover svg{color:var(--txt2)}
.adm-nav__link.is-active{background:linear-gradient(90deg,rgba(30,94,255,.22),rgba(30,94,255,.06));color:#fff;
  box-shadow:inset 2px 0 0 var(--blue)}
.adm-nav__link.is-active svg{color:var(--blue)}
.adm-side__foot{border-top:1px solid var(--line);padding:.9rem 1rem;background:var(--side)}
.adm-user{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem}
.adm-avatar,.adm-headavatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.82rem;color:#fff;background:linear-gradient(135deg,var(--blue),var(--violet));flex:0 0 38px}
.adm-user__txt{min-width:0}
.adm-user__txt strong{display:block;font-size:.85rem}
.adm-user__txt span{font-size:.72rem;color:var(--txt2);display:block}
.adm-plan{color:var(--blue)!important;font-weight:600}
.adm-darktoggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:.8rem;color:var(--txt2)}
.adm-darktoggle>span{display:inline-flex;align-items:center;gap:.4rem}
.adm-darktoggle input{display:none}
.adm-switch{width:38px;height:20px;border-radius:99px;background:rgba(148,163,184,.3);position:relative;transition:background .2s;flex:0 0 38px}
.adm-switch::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}
.adm-darktoggle input:checked+.adm-switch{background:var(--blue)}
.adm-darktoggle input:checked+.adm-switch::after{transform:translateX(18px)}

/* ===================== MAIN + HEADER ===================== */
.adm-main{flex:1;min-width:0;display:flex;flex-direction:column}
/* topbar — preto piano */
.adm-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:1rem;padding:.7rem 1.5rem;
  background:linear-gradient(180deg,#17171a 0%,#0a0a0c 55%,#050506 100%);backdrop-filter:blur(8px);
  border-bottom:1px solid #000;box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 4px 18px rgba(0,0,0,.45)}
.is-light .adm-header{background:linear-gradient(180deg,#17171a 0%,#0a0a0c 55%,#050506 100%)}
.adm-header .adm-header__search{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);color:#c6cdda}
.adm-header .adm-header__search input{color:#fff}
.adm-header .adm-header__search input::placeholder{color:#8a92a4}
.adm-header .adm-icbtn{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);color:#c6cdda}
.adm-header .adm-icbtn:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.2)}
.adm-icbtn{position:relative;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--card);
  color:var(--txt2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.adm-icbtn:hover{color:var(--txt);border-color:var(--line2)}
.adm-header__search{flex:1;max-width:420px;display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;
  background:var(--card);border:1px solid var(--line);border-radius:10px;color:var(--txt2)}
.adm-header__search input{border:0;background:none;outline:none;color:var(--txt);font:inherit;width:100%;font-size:.85rem}
.adm-header__actions{margin-left:auto;display:flex;align-items:center;gap:.55rem}
.adm-badge{position:absolute;top:-5px;right:-5px;min-width:17px;height:17px;border-radius:99px;background:var(--blue);color:#fff;
  font-size:.62rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg)}
.adm-headavatar{position:relative}
.adm-online{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;background:var(--green);border:2px solid var(--side)}
.adm-content{padding:1.5rem;max-width:1600px;width:100%}

/* ===================== PAGE HEAD ===================== */
.adm-pagehead{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.4rem}
.adm-pagehead h1{margin:0;font-size:1.5rem;font-weight:700}
.adm-pagehead p{margin:.25rem 0 0;color:var(--txt2)}
.adm-period__btn{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem .9rem;background:var(--card);
  border:1px solid var(--line);border-radius:10px;color:var(--txt);font:inherit;font-size:.85rem;cursor:pointer}
.adm-period__btn:hover{border-color:var(--line2)}

/* ===================== KPI ===================== */
.adm-kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-bottom:18px}
.adm-kpis--4{grid-template-columns:repeat(4,1fr)}
.adm-kpis--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.adm-kpis--3,.adm-kpis--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.adm-kpis--3,.adm-kpis--4{grid-template-columns:1fr}}
/* CSV import example + inline code */
.adm-form code{background:var(--card2);border:1px solid var(--line);border-radius:6px;padding:.05rem .35rem;font-size:.8rem;color:var(--blue)}
.adm-example{margin-top:1rem;border-top:1px solid var(--line);padding-top:.8rem}
.adm-example>summary{cursor:pointer;font-size:.82rem;color:var(--txt2);font-weight:600;list-style:none}
.adm-example>summary::-webkit-details-marker{display:none}
.adm-example>summary::before{content:"▸ ";color:var(--txt3)}
.adm-example[open]>summary::before{content:"▾ "}
.adm-example pre{margin:.7rem 0 0;background:var(--card2);border:1px solid var(--line);border-radius:8px;padding:.7rem .8rem;font-size:.76rem;line-height:1.5;overflow-x:auto;color:var(--txt)}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:1rem 1.1rem;position:relative;overflow:hidden}
.kpi__top{display:flex;align-items:center;justify-content:space-between}
.kpi__ico{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  color:var(--c);background:color-mix(in srgb,var(--c) 16%,transparent)}
.kpi__delta{font-size:.74rem;font-weight:700}
.kpi__delta.is-up{color:#0a7d5a}.kpi__delta.is-down{color:#c2231a}
.kpi__label{color:var(--txt2);font-size:.78rem;margin-top:.7rem}
.kpi__value{font-size:1.55rem;font-weight:700;letter-spacing:-.01em;margin-top:.1rem}
.spark{display:block;height:34px;margin-top:.4rem}
.spark svg{width:100%;height:100%;display:block}

/* ===================== GRID & CARDS ===================== */
.adm-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;margin-bottom:18px;align-items:start}
.col-2{grid-column:span 2}.col-3{grid-column:span 3}.col-4{grid-column:span 4}
.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-7{grid-column:span 7}
.col-8{grid-column:span 8}.col-9{grid-column:span 9}.col-10{grid-column:span 10}
.col-11{grid-column:span 11}.col-12{grid-column:span 12}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:1.2rem}
.card__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.card__head h2{margin:0;font-size:1rem;font-weight:600}
.card__head h3{margin:0}
.card__head a{font-size:.78rem;color:var(--blue);font-weight:600}
.legend{display:flex;gap:1rem;flex-wrap:wrap;font-size:.74rem;color:var(--txt2)}
.legend i{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:.35rem;vertical-align:0}

/* charts */
.chart-line{height:230px}
.chart-line--mini{height:70px;margin-top:.5rem}
.chart-line svg,.chart-bars svg{width:100%;height:100%;display:block;overflow:visible}
.chart-bars{height:120px}
.chart-bars--tall{height:200px}
.card-subgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:1.2rem}
.subcard{background:var(--card2);border:1px solid var(--line);border-radius:var(--r-sm);padding:1rem}
.subcard h3{margin:0 0 .8rem;font-size:.9rem;font-weight:600}
.donut-wrap{display:flex;align-items:center;gap:1.1rem}
.donut-wrap--col{flex-direction:column;align-items:stretch}
.donut{width:130px;height:130px;flex:0 0 130px;margin:0 auto}
.donut svg{width:100%;height:100%}
.donut-legend{list-style:none;margin:0;padding:0;flex:1;font-size:.8rem}
.donut-legend li{display:flex;align-items:center;gap:.5rem;padding:.2rem 0;color:var(--txt2)}
.donut-legend li b{margin-left:auto;color:var(--txt);font-weight:600}
.donut-legend i{width:9px;height:9px;border-radius:3px;flex:0 0 9px}
.rev-block{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.5rem}
.rev-block span{color:var(--txt2);font-size:.78rem;width:64px}
.rev-block strong{font-size:1.05rem}
.rev-block em{font-style:normal;font-size:.74rem;font-weight:700}
.is-up{color:var(--green)}.is-down{color:var(--red)}

/* feed / rank / fin / alerts / types / status */
.feed,.rank,.alerts,.types,.sysstatus{list-style:none;margin:0;padding:0}
.feed li{display:flex;align-items:center;gap:.7rem;padding:.6rem 0;border-top:1px solid var(--line)}
.feed li:first-child{border-top:0}
.feed__ico{width:34px;height:34px;border-radius:9px;flex:0 0 34px;display:flex;align-items:center;justify-content:center;color:var(--c);background:color-mix(in srgb,var(--c) 16%,transparent)}
.feed__txt{flex:1;min-width:0}
.feed__txt strong{display:block;font-size:.84rem;font-weight:600}
.feed__txt span{font-size:.76rem;color:var(--txt2)}
.feed__when{font-size:.72rem;color:var(--txt3);white-space:nowrap}
.rank{counter-reset:r}
.rank li{display:flex;align-items:center;gap:.6rem;padding:.55rem 0;border-top:1px solid var(--line)}
.rank li:first-child{border-top:0}
.rank__n{width:22px;height:22px;border-radius:7px;background:var(--card2);border:1px solid var(--line);font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;color:var(--txt2)}
.rank__ico{width:30px;height:30px;border-radius:8px;background:color-mix(in srgb,var(--blue) 16%,transparent);color:var(--blue);display:flex;align-items:center;justify-content:center}
.rank__txt{flex:1;min-width:0}
.rank__txt strong{display:block;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank__txt span{font-size:.72rem;color:var(--txt2)}
.rank__rate{display:inline-flex;align-items:center;gap:.2rem;font-size:.78rem;font-weight:600;color:var(--orange)}
.fin{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.5rem}
.fin>div{display:flex;align-items:baseline;gap:.5rem}
.fin span{color:var(--txt2);font-size:.78rem;width:92px}
.fin strong{font-size:1.05rem}
.fin em{font-style:normal;font-size:.74rem;font-weight:700;margin-left:auto}
.alerts li{display:flex;align-items:center;gap:.6rem;padding:.6rem 0;border-top:1px solid var(--line);font-size:.84rem;color:var(--txt2)}
.alerts li:first-child{border-top:0}
.alerts li svg{flex:0 0 auto}
.alerts li span{flex:1}
.alerts li.is-warn svg{color:var(--orange)}
.alerts li.is-info svg{color:var(--blue)}
.alerts li a{color:var(--txt2);font-weight:700}
.types li,.sysstatus li{display:flex;align-items:center;gap:.6rem;padding:.6rem 0;border-top:1px solid var(--line);font-size:.85rem}
.types li:first-child,.sysstatus li:first-child{border-top:0}
.types li svg,.sysstatus li svg{color:var(--txt3)}
.types li b{margin-left:auto;font-weight:700}
.sysstatus li .ok{margin-left:auto;display:inline-flex;align-items:center;gap:.3rem;color:var(--green);font-weight:600;font-size:.8rem}

/* ===================== RESPONSIVE ===================== */
.adm-icbtn[data-side-toggle]{display:inline-flex}
@media (max-width:1280px){ .adm-kpis{grid-template-columns:repeat(3,1fr)} .col-8,.col-9,.col-10,.col-11{grid-column:span 12} .col-4{grid-column:span 6} .col-3{grid-column:span 6} .col-2{grid-column:span 6} }
@media (max-width:900px){
  .adm-side{position:fixed;left:0;top:0;z-index:60;transform:translateX(-100%);transition:transform .25s}
  .adm[data-open] .adm-side{transform:none}
  .adm-icbtn[data-side-toggle]{display:inline-flex}
  .adm-kpis{grid-template-columns:repeat(2,1fr)}
  .col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-10,.col-11{grid-column:span 12}
  .card-subgrid{grid-template-columns:1fr}
  .adm-scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55;display:none}
  .adm[data-open] .adm-scrim{display:block}
}
@media (max-width:520px){ .adm-kpis{grid-template-columns:1fr} .adm-header__search{display:none} }

/* Tables */
.adm-tablewrap{overflow-x:auto}
.adm-table{width:100%;border-collapse:collapse;font-size:.86rem}
.adm-table th{text-align:left;color:var(--txt3);font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:.55rem .5rem;border-bottom:1px solid var(--line);white-space:nowrap}
.adm-table td{padding:.65rem .5rem;border-bottom:1px solid var(--line)}
.adm-table tbody tr:last-child td{border-bottom:0}
.adm-table tbody tr:hover{background:rgba(148,163,184,.06)}
.adm-stars{color:#F59E0B;white-space:nowrap}
.adm-stars svg{width:14px;height:14px;vertical-align:-2px}
.adm-rowactions{display:inline-flex;gap:.4rem;justify-content:center;flex-wrap:wrap}
.adm-rowactions form{margin:0}
.cat-row{display:flex;align-items:center;gap:.7rem}
.cat-row__ico{width:36px;height:36px;flex:0 0 36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--blue) 13%,transparent);color:var(--blue)}
.cat-row__ico svg{width:17px;height:17px}
/* certificate template cards */
.cert-tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.cert-tpl{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--card2);display:flex;flex-direction:column}
.cert-tpl__thumb{display:block;position:relative;height:150px;overflow:hidden;background:#eef1f7;border-bottom:1px solid var(--line)}
.cert-tpl__thumb iframe{position:absolute;top:0;left:0;width:960px;height:678px;border:0;transform:scale(.27);transform-origin:top left;pointer-events:none}
.cert-tpl__body{padding:.85rem .9rem 1rem;display:flex;flex-direction:column;gap:.4rem}
.cert-tpl__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.cert-tpl__head strong{font-size:.95rem}
.cert-tpl__meta{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;font-size:.78rem;color:var(--txt2)}
.cert-tpl__sw{width:13px;height:13px;border-radius:4px;flex:0 0 13px}
.cert-tpl__desc{margin:0;font-size:.78rem;color:var(--txt3);line-height:1.45}
.cert-tpl__actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.3rem}
.cert-tpl__actions form{margin:0}
.adm-pill{display:inline-block;font-size:.7rem;font-weight:600;padding:.12rem .55rem;border-radius:99px;white-space:nowrap}
.adm-pill--ok{background:color-mix(in srgb,var(--green) 18%,transparent);color:var(--green)}
.adm-pill--warn{background:color-mix(in srgb,var(--orange) 18%,transparent);color:var(--orange)}
.adm-pill--info{background:color-mix(in srgb,var(--blue) 18%,transparent);color:var(--blue)}
.adm-pill--muted{background:color-mix(in srgb,var(--txt3) 22%,transparent);color:var(--txt2)}
/* Buttons */
.adm-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .9rem;border-radius:10px;border:1px solid transparent;
  font:inherit;font-size:.82rem;font-weight:600;cursor:pointer;background:var(--blue);color:#fff;text-decoration:none;transition:.15s}
.adm-btn:hover{background:var(--blue2);text-decoration:none}
.adm-btn--ghost{background:transparent;border-color:var(--line2);color:var(--txt)}
.adm-btn--ghost:hover{background:rgba(148,163,184,.1)}
.adm-btn--sm{padding:.38rem .7rem;font-size:.78rem}
/* Report cards */
.report-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:1100px){.report-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.report-grid{grid-template-columns:1fr}}
.report-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:1.2rem;display:flex;flex-direction:column;gap:.5rem}
.report-card__ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:var(--c);background:color-mix(in srgb,var(--c) 16%,transparent)}
.report-card h3{margin:.4rem 0 0;font-size:1rem;font-weight:600}
.report-card p{margin:0;color:var(--txt2);font-size:.82rem;flex:1}
.report-card__actions{display:flex;gap:.5rem;margin-top:.4rem}
/* Funnel */
.funnel{display:flex;flex-direction:column;gap:.75rem}
.funnel__row{display:flex;align-items:center;gap:.9rem}
.funnel__label{width:110px;font-size:.84rem;color:var(--txt2)}
.funnel__bar{flex:1;height:14px;background:var(--card2);border:1px solid var(--line);border-radius:99px;overflow:hidden}
.funnel__bar span{display:block;height:100%;border-radius:99px}
.funnel__val{width:84px;text-align:right;font-weight:700}
.funnel__pct{width:48px;text-align:right;color:var(--txt2);font-style:normal;font-size:.8rem}
@media (max-width:620px){.funnel__label{width:80px}.funnel__val{width:64px}}
/* Mini metric chips */
.metric-row{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:.5rem}
.metric{display:flex;flex-direction:column}
.metric b{font-size:1.3rem;font-weight:700}
.metric span{font-size:.76rem;color:var(--txt2)}

/* ===================== Users / Roles section ===================== */
/* Flash messages */
.adm-flash{padding:.7rem 1rem;border-radius:var(--r-sm);margin-bottom:1rem;font-size:.86rem;font-weight:500;border:1px solid transparent}
.adm-flash--ok{background:color-mix(in srgb,var(--green) 14%,transparent);color:var(--green);border-color:color-mix(in srgb,var(--green) 30%,transparent)}
.adm-flash--danger{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red);border-color:color-mix(in srgb,var(--red) 30%,transparent)}
.adm-flash--info{background:color-mix(in srgb,var(--blue) 14%,transparent);color:var(--blue);border-color:color-mix(in srgb,var(--blue) 30%,transparent)}
.adm-flash--warn{background:color-mix(in srgb,var(--orange) 14%,transparent);color:var(--orange);border-color:color-mix(in srgb,var(--orange) 30%,transparent)}

/* Pill danger variant */
.adm-pill--danger{background:color-mix(in srgb,var(--red) 18%,transparent);color:var(--red)}

/* Page header tabs */
.adm-tabs{display:flex;gap:.3rem;background:var(--card2);border:1px solid var(--line);border-radius:99px;padding:.25rem}
.adm-tab{padding:.4rem .9rem;border-radius:99px;font-size:.8rem;font-weight:600;color:var(--txt2);text-decoration:none;transition:.15s}
.adm-tab:hover{color:var(--txt)}
.adm-tab.is-active{background:var(--blue);color:#fff}

/* Filter bar inside card head */
.adm-filter{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.adm-filter .adm-search{margin:0;flex:1;min-width:200px}
.adm-filter select{padding:.45rem .7rem;background:var(--card);border:1px solid var(--line);border-radius:10px;color:var(--txt);font:inherit;font-size:.8rem;cursor:pointer}
.adm-filter .adm-search input{background:transparent;border:0;outline:0;color:var(--txt);font:inherit;font-size:.84rem;width:100%}
.adm-filter .adm-search input::placeholder{color:var(--txt3)}

/* User cell */
.adm-userc{display:flex;align-items:center;gap:.7rem}
.adm-userc__av{width:38px;height:38px;border-radius:10px;flex:0 0 38px;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.78rem;color:#fff;background:linear-gradient(135deg,var(--blue),var(--violet))}
.adm-userc__txt{display:flex;flex-direction:column;line-height:1.3}
.adm-userc__txt strong{font-size:.88rem;color:var(--txt)}
.adm-userc__txt span{font-size:.76rem;color:var(--txt2)}
.adm-muted{color:var(--txt2);font-size:.82rem}
.adm-center{text-align:center}
.adm-empty{text-align:center;color:var(--txt2);padding:2rem 1rem}

/* Row actions + popovers */
.adm-actions{display:flex;align-items:center;gap:.4rem;justify-content:flex-end}
.adm-actions form{display:inline}
.adm-icbtn--sm{width:32px;height:32px;border-radius:9px}
.adm-icbtn--danger{color:var(--red);border-color:color-mix(in srgb,var(--red) 30%,transparent)}
.adm-icbtn--danger:hover{color:#fff;background:var(--red);border-color:var(--red)}
.adm-pop{position:relative;display:inline-block}
.adm-pop>summary{list-style:none;cursor:pointer}
.adm-pop>summary::-webkit-details-marker{display:none}
.adm-pop__panel{position:absolute;right:0;top:calc(100% + 6px);z-index:30;width:210px;text-align:left;
  background:var(--card);border:1px solid var(--line2);border-radius:var(--r-sm);padding:.8rem;box-shadow:0 12px 30px rgba(2,6,23,.25);display:flex;flex-direction:column;gap:.45rem}
.adm-pop--left .adm-pop__panel{right:auto;left:0}
.adm-pop__panel--wide{width:280px}
.adm-pop__panel{max-width:calc(100vw - 32px)}
.adm-pop__title{font-size:.78rem;color:var(--txt2);text-transform:uppercase;letter-spacing:.04em}
.adm-pop__panel textarea{width:100%;background:var(--card2);border:1px solid var(--line);border-radius:8px;color:var(--txt);font:inherit;font-size:.82rem;padding:.5rem;resize:vertical}
.adm-check{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--txt);font-weight:500}
.adm-check input{width:auto}
.adm-btn--block{width:100%;justify-content:center;margin-top:.2rem}
.adm-btn--danger{background:var(--red)}
.adm-btn--danger:hover{background:#dc2626}
summary.adm-btn--danger{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red);border:1px solid color-mix(in srgb,var(--red) 30%,transparent)}
summary.adm-btn--danger:hover{background:var(--red);color:#fff}

/* Callout banner */
.adm-callout{display:flex;align-items:center;gap:.9rem;background:color-mix(in srgb,var(--orange) 10%,var(--card));
  border:1px solid color-mix(in srgb,var(--orange) 30%,transparent);border-radius:var(--r);padding:.9rem 1.1rem;margin-bottom:18px;text-decoration:none;color:var(--txt)}
.adm-callout__ico{width:40px;height:40px;border-radius:11px;flex:0 0 40px;display:flex;align-items:center;justify-content:center;color:var(--orange);background:color-mix(in srgb,var(--orange) 18%,transparent)}
.adm-callout__txt{flex:1;font-size:.88rem}
.adm-callout .adm-btn{background:var(--orange)}
.adm-callout .adm-btn:hover{background:#d97706}
.adm-callout--info{background:color-mix(in srgb,var(--blue) 8%,var(--card));border-color:color-mix(in srgb,var(--blue) 25%,transparent)}
.adm-callout--info .adm-callout__ico{background:transparent}

/* Verified badge (Instagram-style) */
.vbadge{width:16px;height:16px;display:inline-block;vertical-align:-2px}
.vbadge--sm{width:15px;height:15px}
.vbadge--lg{width:30px;height:30px}
.vbadge--btn{width:15px;height:15px;--vb:#fff;vertical-align:-2px}
.adm-sub{font-size:.72rem;color:var(--txt3)}

/* Role cards */
.rolecard{display:flex;flex-direction:column;gap:.4rem}
.rolecard__ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--c);background:color-mix(in srgb,var(--c) 16%,transparent)}
.rolecard h3{margin:.4rem 0 0;font-size:1rem;font-weight:600}
.rolecard p{margin:0;color:var(--txt2);font-size:.82rem;flex:1}
.rolecard__foot{display:flex;align-items:baseline;gap:.35rem;margin-top:.5rem;padding-top:.6rem;border-top:1px solid var(--line)}
.rolecard__foot b{font-size:1.3rem;font-weight:700}
.rolecard__foot span{font-size:.76rem;color:var(--txt2)}

/* Permission matrix */
.adm-table--matrix td:first-child{font-size:.85rem}
.adm-yes{display:inline-flex;color:var(--green)}
.adm-no{color:var(--txt3)}
.adm-note{margin:1rem 0 0;font-size:.8rem;color:var(--txt2)}
.adm-note a{color:var(--blue);font-weight:600}

/* Application cards */
.appcard{margin-bottom:1rem}
.appcard__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.appcard__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.1rem}
@media (max-width:760px){.appcard__grid{grid-template-columns:1fr}}
.appcard__k{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--txt3)}
.appcard__grid p{margin:.3rem 0 0;font-size:.85rem;color:var(--txt2)}
.appcard__actions{display:flex;align-items:flex-start;gap:.6rem;margin-top:1.1rem}
.appcard__note{margin:1rem 0 0;font-size:.82rem;color:var(--red);display:flex;align-items:center;gap:.4rem}

/* ===================== Support thread ===================== */
.adm-thread{display:flex;flex-direction:column;gap:.9rem}
.adm-thread__msg{background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:.85rem 1rem;max-width:88%}
.adm-thread__msg.is-staff{align-self:flex-end;background:color-mix(in srgb,var(--blue) 10%,var(--card));border-color:color-mix(in srgb,var(--blue) 25%,transparent)}
.adm-thread__head{display:flex;justify-content:space-between;gap:1rem;margin-bottom:.35rem;font-size:.78rem}
.adm-thread__head strong{color:var(--txt)}
.adm-thread__head span{color:var(--txt3)}
.adm-thread__body{font-size:.9rem;line-height:1.6;color:var(--txt)}

/* ===================== Platform / forms ===================== */
.adm-form .card{margin-bottom:0}
.adm-field{margin-bottom:1rem}
.adm-field:last-child{margin-bottom:0}
.adm-field label{display:block;font-size:.8rem;font-weight:600;color:var(--txt2);margin-bottom:.35rem}
.adm-form input[type=text],.adm-form input[type=email],.adm-form input[type=password],.adm-form input[type=number],.adm-form textarea,.adm-form select{
  width:100%;background:var(--card2);border:1px solid var(--line);border-radius:10px;color:var(--txt);font:inherit;font-size:.88rem;padding:.6rem .75rem;transition:.15s}
.adm-form input:focus,.adm-form textarea:focus,.adm-form select:focus{outline:0;border-color:var(--blue);background:var(--card)}
.adm-form textarea{resize:vertical;min-height:90px}
.adm-form input::placeholder,.adm-form textarea::placeholder{color:var(--txt3)}
.adm-field-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}
.adm-form__foot{margin-top:18px;display:flex;justify-content:flex-end}
.adm-form--tight .adm-field{margin-bottom:.75rem}

/* Toggle switch */
.adm-toggle{display:flex;align-items:flex-start;gap:.7rem;cursor:pointer;margin-bottom:1rem}
.adm-toggle:last-child{margin-bottom:0}
.adm-toggle input{position:absolute;opacity:0;width:0;height:0}
.adm-toggle__track{flex:0 0 42px;width:42px;height:24px;border-radius:99px;background:var(--line2);position:relative;transition:.18s;margin-top:2px}
.adm-toggle__track::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.18s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.adm-toggle input:checked+.adm-toggle__track{background:var(--blue)}
.adm-toggle input:checked+.adm-toggle__track::after{transform:translateX(18px)}
.adm-toggle__txt strong{display:block;font-size:.88rem;color:var(--txt)}
.adm-toggle__txt em{font-style:normal;font-size:.78rem;color:var(--txt2)}
.adm-note code{background:var(--card2);border:1px solid var(--line);border-radius:6px;padding:.1rem .4rem;font-size:.78rem;color:var(--blue);word-break:break-all}

/* Gateway radio options */
.gw-options{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:720px){.gw-options{grid-template-columns:1fr}}
.gw-option{position:relative;display:flex;flex-direction:column;gap:.3rem;padding:1.1rem;border:1.5px solid var(--line);border-radius:var(--r-sm);cursor:pointer;transition:.15s}
.gw-option:hover{border-color:var(--line2)}
.gw-option.is-active{border-color:var(--blue);background:color-mix(in srgb,var(--blue) 6%,transparent)}
.gw-option input{position:absolute;opacity:0}
.gw-option__ico{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--blue) 14%,transparent);color:var(--blue)}
.gw-option strong{font-size:.95rem}
.gw-option em{font-style:normal;font-size:.78rem;color:var(--txt2)}
.gw-option.is-active::after{content:"✓";position:absolute;top:.7rem;right:.8rem;color:var(--blue);font-weight:700}

/* ===================== Finance ===================== */
.kpi__value--sm{font-size:1.35rem}
.plancard{display:flex;flex-direction:column;gap:.5rem}
.plancard__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.plancard__head h3{margin:0;font-size:1.05rem;font-weight:600}
.plancard__price{font-size:1.7rem;font-weight:700;color:var(--txt)}
.plancard__price span{font-size:.85rem;font-weight:500;color:var(--txt2)}
.plancard__perks{list-style:none;margin:.4rem 0 0;padding:0;display:flex;flex-direction:column;gap:.4rem;flex:1}
.plancard__perks li{display:flex;align-items:center;gap:.45rem;font-size:.84rem;color:var(--txt2)}
.plancard__perks li svg{color:var(--green);flex:0 0 auto}
.plancard__foot{display:flex;align-items:baseline;gap:.35rem;margin-top:.6rem;padding-top:.7rem;border-top:1px solid var(--line)}
.plancard__foot b{font-size:1.25rem;font-weight:700}
.plancard__foot span{font-size:.76rem;color:var(--txt2)}

/* ===================== Courses / Curation ===================== */
.adm-tabs--wrap{flex-wrap:wrap;width:fit-content;max-width:100%}
.adm-btn--warn{background:var(--orange)}
.adm-btn--warn:hover{background:#d97706}
summary.adm-btn--warn{background:color-mix(in srgb,var(--orange) 14%,transparent);color:var(--orange);border:1px solid color-mix(in srgb,var(--orange) 30%,transparent)}
summary.adm-btn--warn:hover{background:var(--orange);color:#fff}
.curation-note{margin-top:1rem;padding:.7rem .9rem;border-radius:10px;font-size:.85rem;display:flex;gap:.4rem;align-items:flex-start;
  background:color-mix(in srgb,var(--orange) 10%,var(--card2));border:1px solid color-mix(in srgb,var(--orange) 25%,transparent);color:var(--txt)}

/* ===================== Content (Articles / E-books) ===================== */
.adm-tabcount{display:inline-block;min-width:18px;padding:0 5px;border-radius:99px;background:rgba(148,163,184,.25);font-size:.68rem;font-weight:700;line-height:18px;text-align:center}
.adm-tab.is-active .adm-tabcount{background:rgba(255,255,255,.25)}
.adm-back{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--txt2);text-decoration:none;margin-bottom:.4rem}
.adm-back:hover{color:var(--blue)}

/* Article review body (renders author HTML) */
.article-review__excerpt{font-size:1.02rem;color:var(--txt);font-weight:500;margin:0 0 1rem;padding-left:.9rem;border-left:3px solid var(--blue)}
.article-review__body{font-size:.95rem;line-height:1.75;color:var(--txt)}
.article-review__body h2{font-size:1.15rem;margin:1.4rem 0 .5rem}
.article-review__body p{margin:0 0 1rem}
.article-review__body img{max-width:100%;border-radius:10px}

/* E-book review */
.ebook-review{display:flex;gap:1.3rem;flex-wrap:wrap}
.ebook-review__cover{width:150px;flex:0 0 150px;aspect-ratio:3/4;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.ebook-review__cover--ph{display:flex;align-items:center;justify-content:center;background:var(--card2);color:var(--txt3)}
.ebook-review__cover--ph svg{width:46px;height:46px}
.ebook-review__meta{flex:1;min-width:220px}
.ebook-review__facts{list-style:none;margin:1.1rem 0 0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.ebook-review__facts li{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:.5rem;font-size:.86rem}
.ebook-review__facts span{color:var(--txt2)}
.ebook-review__facts a{color:var(--blue);font-weight:600}

/* The sidebar is always dark — keep its text light regardless of the theme. */
.adm-side{color:#cdd9e8}
.adm-nav__link{color:#94A3B8}
.adm-nav__link svg{color:#64748B}
.adm-nav__link:hover{color:#fff}
.adm-nav__link:hover svg{color:#94A3B8}
.adm-nav__link.is-active{color:#fff}
.adm-nav__link.is-active svg{color:var(--blue)}
.adm-nav__label{color:#64748B}
.adm-logo__sub{color:#64748B}
.adm-user__txt strong{color:#F8FAFC}
.adm-user__txt span{color:#94A3B8}

/* Profile page */
.profile-head{display:flex;align-items:center;gap:1.1rem;margin-bottom:1.1rem}
.profile-avatar{width:72px;height:72px;border-radius:18px;flex:0 0 72px;overflow:hidden;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1.4rem;color:#fff;background:linear-gradient(135deg,var(--blue),var(--violet))}
.profile-avatar img{width:100%;height:100%;object-fit:cover}

/* Sidebar footer — brand (like the instructor layout) */
.adm-side__foot--brand{color:#64748B;font-size:.72rem;text-align:left}

/* Header user dropdown */
.adm-usermenu{position:relative}
.adm-usermenu>summary{list-style:none;cursor:pointer}
.adm-usermenu>summary::-webkit-details-marker{display:none}
.adm-usermenu__panel{position:absolute;right:0;top:calc(100% + 8px);z-index:50;width:230px;
  background:var(--card);border:1px solid var(--line2);border-radius:12px;padding:.5rem;
  box-shadow:0 16px 40px rgba(2,6,23,.18);display:flex;flex-direction:column;gap:.1rem}
.adm-usermenu__head{display:flex;align-items:center;gap:.6rem;padding:.5rem .55rem .7rem;border-bottom:1px solid var(--line);margin-bottom:.35rem}
.adm-usermenu__head .adm-avatar{width:40px;height:40px;flex:0 0 40px}
.adm-usermenu__txt{min-width:0}
.adm-usermenu__txt strong{display:block;font-size:.86rem;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adm-usermenu__txt span{font-size:.74rem;color:var(--txt2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.adm-usermenu__form{margin:0}
.adm-usermenu__item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.55rem .55rem;border-radius:8px;
  font:inherit;font-size:.85rem;color:var(--txt);background:none;border:0;cursor:pointer;text-align:left;text-decoration:none}
.adm-usermenu__item:hover{background:var(--card2);color:var(--blue)}
.adm-usermenu__item svg{color:var(--txt3)}
.adm-usermenu__item:hover svg{color:var(--blue)}
.adm-usermenu__item--danger{color:#c2231a}
.adm-usermenu__item--danger:hover{background:color-mix(in srgb,var(--red) 10%,transparent);color:#c2231a}
.adm-usermenu__item--danger svg,.adm-usermenu__item--danger:hover svg{color:#c2231a}

/* KPI icons: translucent circle (match the instructor dashboard) */
.kpi__ico{border-radius:50%}

/* ===================== Toasts (flash → bottom-right) ===================== */
.adm-toasts{position:fixed;right:1.2rem;bottom:1.2rem;z-index:300;display:flex;flex-direction:column;gap:.6rem;max-width:380px;width:calc(100% - 2.4rem);pointer-events:none}
.adm-toasts .adm-flash{margin:0;pointer-events:auto;border-radius:12px;padding:.85rem 1.1rem;box-shadow:0 14px 34px rgba(2,6,23,.18);
  animation:admToastIn .28s cubic-bezier(.2,.7,.3,1);transition:opacity .3s ease,transform .3s ease;cursor:pointer}
.adm-toasts .adm-flash.is-out{opacity:0;transform:translateX(26px)}
@keyframes admToastIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}
@media(max-width:600px){.adm-toasts{left:1rem;right:1rem;max-width:none}}

/* Toast high-contrast restyle (white card + dark text + colored accent) */
.adm-toasts .adm-flash{background:#fff;color:#0f172a;border:1px solid var(--line2);border-left:4px solid var(--blue);font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:.5rem}
.adm-toasts .adm-flash::before{content:"";width:9px;height:9px;border-radius:50%;flex:0 0 9px;background:var(--blue)}
.adm-toasts .adm-flash--ok{border-left-color:#10B981}.adm-toasts .adm-flash--ok::before{background:#10B981}
.adm-toasts .adm-flash--danger{border-left-color:#EF4444}.adm-toasts .adm-flash--danger::before{background:#EF4444}
.adm-toasts .adm-flash--info{border-left-color:#1E5EFF}.adm-toasts .adm-flash--info::before{background:#1E5EFF}
.adm-toasts .adm-flash--warn{border-left-color:#F59E0B}.adm-toasts .adm-flash--warn::before{background:#F59E0B}

/* Toast close button */
.adm-toasts .adm-flash{cursor:default}
.adm-flash__msg{flex:1;min-width:0}
.adm-flash__close{flex:0 0 auto;width:24px;height:24px;border:0;background:transparent;color:var(--txt3);border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s;padding:0}
.adm-flash__close:hover{background:rgba(15,23,42,.07);color:var(--txt)}
.adm-flash__close svg{width:14px;height:14px}
