:root{
  --bg:#0b0f14; --bg-elev:#121821; --bg-elev2:#172230; --line:#22303f; --line-soft:#1b2733;
  --txt:#e6edf3; --txt-dim:#9fb0c0; --txt-mut:#6b7d8f;
  --primary:#3b82f6; --primary-hi:#60a5fa; --primary-dim:#1d3a63;
  --accent:#14b8a6;
  --green:#22c55e; --amber:#f59e0b; --red:#ef4444; --purple:#a78bfa; --blue:#3b82f6; --grey:#64748b; --teal:#14b8a6; --orange:#fb923c;
  --radius:12px; --radius-sm:8px; --shadow:0 10px 30px rgba(0,0,0,.35);
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--txt);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--primary-hi);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0 0 .6rem;font-weight:650;letter-spacing:-.01em}
code{background:var(--bg-elev2);padding:.1rem .35rem;border-radius:4px;font-size:.85em}

/* ---- App shell ---- */
.app{display:flex;min-height:100vh}
.side{width:230px;background:var(--bg-elev);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:.6rem;padding:1.1rem 1.2rem;border-bottom:1px solid var(--line-soft)}
.brand .sub{font-size:.62rem;letter-spacing:.22em;color:var(--txt-mut);text-transform:uppercase;margin-top:2px}
.nav{padding:.6rem;flex:1;overflow:auto}
.nav a{display:flex;align-items:center;gap:.7rem;padding:.6rem .8rem;border-radius:var(--radius-sm);color:var(--txt-dim);font-weight:500;margin-bottom:2px}
.nav a:hover{background:var(--bg-elev2);color:var(--txt);text-decoration:none}
.nav a.active{background:var(--primary-dim);color:#fff}
.nav a svg{width:18px;height:18px;opacity:.9;flex:none}
.nav .grp{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--txt-mut);padding:.9rem .8rem .3rem}
/* Collapsible Admin group: a .grp styled as a full-width toggle button with a rotating chevron. */
.nav button.grp-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:0;cursor:pointer;font:inherit;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;font-weight:650}
.nav button.grp-toggle:hover{color:var(--txt-dim)}
.nav button.grp-toggle .chev{width:14px;height:14px;opacity:.8;transition:transform .15s ease}
html[data-adminnav="collapsed"] .nav button.grp-toggle .chev{transform:rotate(-90deg)}
html[data-adminnav="collapsed"] #adminItems{display:none}
.side .foot{border-top:1px solid var(--line-soft);padding:.8rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.side .foot .u{font-size:.82rem;color:var(--txt-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.6rem;border-bottom:1px solid var(--line);background:rgba(11,15,20,.7);backdrop-filter:blur(8px);position:sticky;top:0;z-index:5}
.topbar h1{font-size:1.15rem;margin:0}
.content{padding:1.6rem;max-width:1500px;width:100%}
.topsearch input{width:320px;max-width:38vw;border-radius:20px;padding:.45rem .9rem;background:var(--bg-elev2)}
th.sortable{cursor:pointer;user-select:none}
th.sortable:hover{color:var(--txt)}
th.sortable .ind{color:var(--primary-hi);margin-left:.2rem}

/* ---- logo / brand ---- */
.logo-appx{font-weight:800;font-size:1.35rem;letter-spacing:-.04em;color:#c7d2da;line-height:1}
.logo-appx .x{color:var(--primary-hi)}
.logo-onyx{font-weight:800;font-size:1.5rem;letter-spacing:-.03em;color:var(--txt);line-height:1}
.logo-onyx .x{color:var(--primary-hi)}
.gem{width:16px;height:16px;border-radius:3px;display:inline-block;flex:none;
     background:linear-gradient(135deg,var(--primary-hi),var(--accent));transform:rotate(45deg);
     box-shadow:0 0 14px rgba(59,130,246,.45)}
.brandmark{display:flex;align-items:center;gap:.7rem;justify-content:center}

/* ---- light theme ---- */
html[data-theme="light"]{
  --bg:#f5f7fa; --bg-elev:#ffffff; --bg-elev2:#eef2f7; --line:#d6dde6; --line-soft:#e7ecf2;
  --txt:#101722; --txt-dim:#3d4a5c; --txt-mut:#71808f;
  --primary:#2563eb; --primary-hi:#1d4ed8; --primary-dim:#dbe7fb;
  --shadow:0 10px 30px rgba(20,40,80,.12);
}
html[data-theme="light"] .topbar{background:rgba(245,247,250,.8)}
html[data-theme="light"] .st-1{color:#1d4ed8;background:rgba(37,99,235,.12)}
html[data-theme="light"] .st-2{color:#b45309;background:rgba(245,158,11,.16)}
html[data-theme="light"] .st-3{color:#6d28d9;background:rgba(124,58,237,.14)}
html[data-theme="light"] .st-4{color:#15803d;background:rgba(34,197,94,.16)}
html[data-theme="light"] .st-0{color:#0f766e;background:rgba(20,184,166,.14)}
html[data-theme="light"] .st-5,html[data-theme="light"] .st-7,html[data-theme="light"] .st-8{color:#475569;background:rgba(100,116,139,.14)}
html[data-theme="light"] .st-6{color:#b91c1c;background:rgba(239,68,68,.14)}
html[data-theme="light"] .pr-1{color:#b91c1c;background:rgba(239,68,68,.14)}
html[data-theme="light"] .pr-2{color:#c2410c;background:rgba(251,146,60,.16)}
html[data-theme="light"] .pr-3{color:#1d4ed8;background:rgba(37,99,235,.12)}
html[data-theme="light"] .pr-4{color:#475569;background:rgba(100,116,139,.14)}

/* ---- APPX brand theme (default) ---- */
html[data-theme="appx"]{
  --bg:#dcecef; --bg-elev:#ffffff; --bg-elev2:#eef4f5; --line:#9cb8c1; --line-soft:#cfe0e4;
  --txt:#274a57; --txt-dim:#5f7481; --txt-mut:#7c919b;
  --primary:#005872; --primary-hi:#2e7084; --primary-dim:#bfdce4;
  --accent:#2e7084;
  --shadow:0 14px 44px rgba(0,88,114,.12);
}
html[data-theme="appx"] .topbar{background:rgba(220,236,239,.85)}
html[data-theme="appx"] .nav a.active{background:var(--primary);color:#fff}
html[data-theme="appx"] .gem{background:linear-gradient(135deg,#005872,#2e7084);box-shadow:0 0 14px rgba(0,88,114,.4)}
html[data-theme="appx"] .st-1{color:#005872;background:rgba(0,88,114,.12)}
html[data-theme="appx"] .st-2{color:#b45309;background:rgba(245,158,11,.16)}
html[data-theme="appx"] .st-3{color:#3a6ea5;background:rgba(58,110,165,.14)}
html[data-theme="appx"] .st-4{color:#15803d;background:rgba(34,197,94,.16)}
html[data-theme="appx"] .st-0{color:#0f766e;background:rgba(20,184,166,.14)}
html[data-theme="appx"] .st-5,html[data-theme="appx"] .st-7,html[data-theme="appx"] .st-8{color:#5f7481;background:rgba(95,116,129,.14)}
html[data-theme="appx"] .st-6{color:#b91c1c;background:rgba(239,68,68,.14)}
html[data-theme="appx"] .pr-1{color:#b91c1c;background:rgba(239,68,68,.14)}
html[data-theme="appx"] .pr-2{color:#c2410c;background:rgba(251,146,60,.16)}
html[data-theme="appx"] .pr-3{color:#005872;background:rgba(0,88,114,.12)}
html[data-theme="appx"] .pr-4{color:#5f7481;background:rgba(95,116,129,.14)}
/* brand swap: real APPX logo on a teal banner, shown only in the APPX theme */
.brand-appx{display:none}
html[data-theme="appx"] .brand-onyx,html[data-theme="appx"] .gem{display:none}
html[data-theme="appx"] .brand{background:linear-gradient(135deg,#005872,#2e7084);border-bottom-color:#1f5566}
html[data-theme="appx"] .brand-appx{display:flex;flex-direction:column;line-height:1;gap:.4rem}
.brand-appx .appx-logo-img{width:150px;max-width:100%;height:auto;display:block}
.brand-appx .sub{font-size:.58rem;letter-spacing:.2em;color:#cfe8ef;text-transform:uppercase}

/* ============================================================
   High-contrast + large-text theme (accessibility).
   Selectable like the other data-theme variants (sidebar ◑ toggle / My account).
   Goals: near-maximum text contrast (black on white; "dim"/"muted" greys kept
   ≥7:1, AAA — not the low-contrast greys the visual themes use), a larger base
   font with roomier leading, always-underlined inline links (never colour
   alone — WCAG 1.4.1), and a strong visible focus ring on every control.
   Built on the same CSS variables as the other themes, so every surface
   inherits the palette automatically; only spots that pair text WITH a
   coloured background need an explicit override. --primary-dim stays a LIGHT
   tint (the hero/accent-tile gradients fade it toward the white bg), so
   active-nav is overridden to a SOLID deep blue instead.
   ============================================================ */
html[data-theme="contrast"]{
  --bg:#ffffff; --bg-elev:#ffffff; --bg-elev2:#f1f1f1; --line:#000000; --line-soft:#5c5c5c;
  --txt:#000000; --txt-dim:#161616; --txt-mut:#3a3a3a;
  --primary:#0b3d91; --primary-hi:#0b3d91; --primary-dim:#d3e0f7;
  --accent:#0a6c5f;
  --green:#136b2e; --amber:#8a4b00; --red:#a31515; --purple:#5b21b6; --blue:#0b3d91; --grey:#374151; --teal:#0a6c5f; --orange:#9a3412;
  --shadow:0 6px 22px rgba(0,0,0,.28);
  font-size:18px;                       /* lift the rem base -> whole UI scales up ~12.5% */
}
html[data-theme="contrast"] body{font-size:1rem;line-height:1.65}   /* body text 14px -> 18px, roomier */
html[data-theme="contrast"] .topbar h1{font-size:1.35rem}
html[data-theme="contrast"] .side{width:272px}                      /* room for the longest nav label at 18px */
html[data-theme="contrast"] .nav a{font-size:.95rem}
html[data-theme="contrast"] .btn{font-size:.95rem}
html[data-theme="contrast"] .btn-sm{font-size:.86rem}
html[data-theme="contrast"] .topbar{background:#fff}                 /* solid (the blurred translucent bar dilutes contrast) */
/* login screen: keep it high-contrast no matter which decorative backdrop the admin picked
   (wins on specificity over .login-page[data-login=...] — html+attr+class beats class+attr) */
html[data-theme="contrast"] .login-page{background:#fff}
html[data-theme="contrast"] .login-bg{display:none}
html[data-theme="contrast"] .login form{box-shadow:none}
/* inline links: underline everywhere (don't rely on colour); keep nav/buttons/pills clean */
html[data-theme="contrast"] a{text-decoration:underline}
html[data-theme="contrast"] .nav a,html[data-theme="contrast"] .btn,html[data-theme="contrast"] .qbtn,
html[data-theme="contrast"] a.card,html[data-theme="contrast"] .card.proj,html[data-theme="contrast"] .stat-tile,
html[data-theme="contrast"] .proj-tile,html[data-theme="contrast"] .seg a,html[data-theme="contrast"] .statrow,
html[data-theme="contrast"] .help-tab,html[data-theme="contrast"] .help-nav a,html[data-theme="contrast"] .gantt-showall,
html[data-theme="contrast"] .grow-label{text-decoration:none}
/* active nav: SOLID deep blue + white (not the faint --primary-dim tint) */
html[data-theme="contrast"] .nav a.active{background:var(--primary);color:#fff;font-weight:650}
html[data-theme="contrast"] .hero-badge{color:#fff}                 /* white on the dark-teal accent */
/* status / priority chips: dark saturated text, each clears AA on its light tint */
html[data-theme="contrast"] .st-0{color:#0a6c5f;background:rgba(10,108,95,.14)}
html[data-theme="contrast"] .st-1{color:#0b3d91;background:rgba(11,61,145,.12)}
html[data-theme="contrast"] .st-2{color:#8a4b00;background:rgba(138,75,0,.15)}
html[data-theme="contrast"] .st-3{color:#5b21b6;background:rgba(91,33,182,.13)}
html[data-theme="contrast"] .st-4{color:#136b2e;background:rgba(19,107,46,.15)}
html[data-theme="contrast"] .st-5,html[data-theme="contrast"] .st-7,html[data-theme="contrast"] .st-8{color:#374151;background:rgba(55,65,81,.14)}
html[data-theme="contrast"] .st-6{color:#a31515;background:rgba(163,21,21,.13)}
html[data-theme="contrast"] .pr-1{color:#a31515;background:rgba(163,21,21,.13)}
html[data-theme="contrast"] .pr-2{color:#9a3412;background:rgba(154,52,18,.15)}
html[data-theme="contrast"] .pr-3{color:#0b3d91;background:rgba(11,61,145,.12)}
html[data-theme="contrast"] .pr-4{color:#374151;background:rgba(55,65,81,.14)}
html[data-theme="contrast"] .flash.ok{color:#0f5132;background:rgba(19,107,46,.12);border-color:#136b2e}
html[data-theme="contrast"] .btn-danger{color:#a31515;border-color:#a31515}
html[data-theme="contrast"] .btn-danger:hover{background:rgba(163,21,21,.1);border-color:#a31515}
html[data-theme="contrast"] .chip b{color:#000}
html[data-theme="contrast"] .chip.warn b{color:#8a4b00}
html[data-theme="contrast"] .help-q{border-color:#000;color:#161616}
/* strong, always-visible keyboard focus ring on every interactive control */
html[data-theme="contrast"] a:focus-visible,html[data-theme="contrast"] button:focus-visible,
html[data-theme="contrast"] input:focus-visible,html[data-theme="contrast"] select:focus-visible,
html[data-theme="contrast"] textarea:focus-visible,html[data-theme="contrast"] summary:focus-visible,
html[data-theme="contrast"] [tabindex]:focus-visible{outline:3px solid var(--primary);outline-offset:2px}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .9rem;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--bg-elev2);color:var(--txt);font-weight:600;font-size:.86rem;cursor:pointer;transition:.12s}
.btn:hover{border-color:var(--primary);text-decoration:none}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-hi)}
.btn-sm{padding:.32rem .6rem;font-size:.78rem}
.btn-ghost{background:transparent}

/* ---- cards ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.4rem}
.card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.3rem}
.card .n{font-size:1.9rem;font-weight:750;letter-spacing:-.02em}
.card .l{color:var(--txt-mut);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem}
.card.accent .n{color:var(--primary-hi)}
a.card{display:block;text-decoration:none;color:inherit;transition:border-color .12s,transform .12s}
a.card:hover{border-color:var(--primary);transform:translateY(-2px);text-decoration:none}
.panel{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel .ph{padding:.9rem 1.2rem;border-bottom:1px solid var(--line-soft);font-weight:650;display:flex;align-items:center;justify-content:space-between}
.panel .pb{padding:1.2rem}

/* ---- tables ---- */
table.grid{width:100%;border-collapse:collapse}
table.grid th{text-align:left;padding:.6rem 1rem;color:var(--txt-mut);font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;font-weight:650;border-bottom:1px solid var(--line)}
table.grid td{padding:.62rem 1rem;border-bottom:1px solid var(--line-soft);vertical-align:top}
table.grid tr:last-child td{border-bottom:0}
table.grid tbody tr:hover{background:var(--bg-elev2)}
/* Each big list is its own scroll area: the header row sticks to the top, horizontal scroll handles wide
   tables, and the panel keeps its rounded corners + ⚙ Columns dropdown. max-height is set per list by rush.js. */
.grid-wrap{overflow:auto;scrollbar-width:thin}
.grid-wrap table.grid{min-width:max-content}
.grid-wrap table.grid thead th{position:sticky;top:0;z-index:3;background:var(--bg-elev);box-shadow:inset 0 -1px 0 var(--line)}
.mono{font-variant-numeric:tabular-nums;color:var(--txt-mut);white-space:nowrap}
p.mono{white-space:normal}
.truncate{max-width:420px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---- badges ---- */
.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.16rem .55rem;border-radius:20px;font-size:.74rem;font-weight:600;white-space:nowrap;border:1px solid transparent}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.9}
.st-0{color:#5eead4;background:rgba(20,184,166,.12)} .st-1{color:#7dd3fc;background:rgba(59,130,246,.14)}
.st-2{color:#fcd34d;background:rgba(245,158,11,.14)} .st-3{color:#c4b5fd;background:rgba(167,139,250,.16)}
.st-4{color:#4ade80;background:rgba(34,197,94,.14)} .st-5{color:#94a3b8;background:rgba(100,116,139,.16)}
.st-6{color:#f87171;background:rgba(239,68,68,.14)} .st-7{color:#cbd5e1;background:rgba(100,116,139,.14)}
.st-8{color:#94a3b8;background:rgba(100,116,139,.16)}
.pr-1{color:#f87171;background:rgba(239,68,68,.14)} .pr-2{color:#fb923c;background:rgba(251,146,60,.14)}
.pr-3{color:#7dd3fc;background:rgba(59,130,246,.12)} .pr-4{color:#94a3b8;background:rgba(100,116,139,.14)}

/* ---- forms ---- */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.1rem;align-items:end}
.field{display:flex;flex-direction:column;gap:.3rem}
.field label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--txt-mut)}
input,select,textarea{background:var(--bg);border:1px solid var(--line);color:var(--txt);border-radius:var(--radius-sm);padding:.5rem .65rem;font:inherit;font-size:.88rem}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}
textarea{min-height:120px;resize:vertical;width:100%}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.form-grid .full{grid-column:1/-1}
.form-row{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.form-row label{font-weight:600;font-size:.82rem;color:var(--txt-dim)}

/* ---- bug detail ---- */
.bughead{display:flex;align-items:start;justify-content:space-between;gap:1rem;margin-bottom:1.2rem}
.bughead .meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem;align-items:center}
.kv{display:grid;grid-template-columns:130px 1fr;gap:.4rem .8rem}
.kv dt{color:var(--txt-mut);font-size:.82rem}
.kv dd{margin:0}
.section{margin:1.4rem 0}
.section h3{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-mut);border-bottom:1px solid var(--line-soft);padding-bottom:.4rem}
.prose{white-space:pre-wrap;word-wrap:break-word;background:var(--bg-elev2);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:.9rem;color:var(--txt-dim)}

/* ---- timeline (notes) ---- */
.timeline{position:relative;padding-left:1.4rem}
.timeline::before{content:"";position:absolute;left:5px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;margin-bottom:1.1rem}
.tl-item::before{content:"";position:absolute;left:-1.4rem;top:4px;width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--primary)}
.tl-head{font-size:.82rem;color:var(--txt-dim);margin-bottom:.35rem;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.tl-head .who{font-weight:650;color:var(--txt)}
/* Pinned to the viewport bottom so the page number + controls stay visible while infinite-scrolling. */
.pager{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap;margin-top:0;justify-content:flex-end;color:var(--txt-mut);
  position:sticky;bottom:0;z-index:4;padding:.7rem .2rem;background:var(--bg);border-top:1px solid var(--line)}
.empty{padding:2.5rem;text-align:center;color:var(--txt-mut)}
.flash{padding:.7rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;border:1px solid}
.flash.ok{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.3);color:#86efac}

/* ---- project cards + chips + progress ---- */
.card.proj{display:block;text-decoration:none;transition:.12s}
.card.proj:hover{border-color:var(--primary);text-decoration:none}
.pname{font-weight:650;color:var(--txt);margin-bottom:.55rem;font-size:1rem}
.pstats{display:flex;gap:.4rem;flex-wrap:wrap}
.chip{background:var(--bg-elev2);border:1px solid var(--line);border-radius:20px;padding:.12rem .55rem;font-size:.72rem;color:var(--txt-dim);white-space:nowrap}
.chip b{color:var(--txt)}
.chip.warn b{color:var(--amber)}

/* dashboard */
.dash-hero{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;background:linear-gradient(120deg,var(--primary-dim),transparent 60%),var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.4rem;margin-bottom:1.3rem}
.dash-hero .hello{font-size:1.4rem;font-weight:760;letter-spacing:-.02em;display:flex;align-items:center;gap:.6rem}
.dash-hero .hero-sub{color:var(--txt-mut);font-size:.85rem;margin-top:.15rem}
.hero-badge{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;background:var(--accent);color:#04201c;padding:.12rem .5rem;border-radius:20px}
.quick{display:flex;gap:.5rem;flex-wrap:wrap}
.qbtn{display:inline-flex;align-items:center;gap:.35rem;background:var(--bg-elev2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.5rem .8rem;color:var(--txt-dim);font-weight:600;font-size:.85rem;text-decoration:none;transition:.12s}
.qbtn:hover{border-color:var(--primary);color:var(--txt);text-decoration:none}
.qbtn span{color:var(--primary-hi);font-weight:800}
.statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.3rem}
.stat-tile{display:block;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.3rem;text-decoration:none;color:inherit;transition:.12s}
.stat-tile:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow);text-decoration:none}
.stat-tile .st-n{font-size:2rem;font-weight:780;letter-spacing:-.03em;line-height:1}
.stat-tile .st-l{color:var(--txt-mut);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;margin-top:.35rem}
.stat-tile .st-sub{color:var(--txt-dim);font-size:.78rem;margin-top:.5rem}
.stat-tile .st-sub b{color:var(--amber)}
.stat-tile.accent{background:linear-gradient(135deg,var(--primary-dim),var(--bg-elev) 70%)}
.stat-tile.accent .st-n{color:var(--primary-hi)}
.dash-2col{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1.3rem}
@media(max-width:900px){.dash-2col{grid-template-columns:1fr}}
/* customizable list columns */
.col-hidden{display:none}
.colpicker{position:relative;display:inline-block}
.colpicker>summary{list-style:none;cursor:pointer;user-select:none}
.colpicker>summary::-webkit-details-marker{display:none}
.colpicker-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:20;min-width:200px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:.7rem .8rem}
.colpicker-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--txt-mut);font-weight:700;margin-bottom:.4rem}
.colpicker-item{display:flex;align-items:center;gap:.5rem;padding:.22rem 0;font-size:.86rem;color:var(--txt-dim);cursor:pointer}
.colpicker-item input{width:auto}
.act-row{display:flex;align-items:center;gap:.7rem;padding:.55rem .2rem;border-bottom:1px solid var(--line-soft)}
.act-row:last-child{border-bottom:none}
.act-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex:none}
.act-body{flex:1;min-width:0}
.act-detail{font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.act-meta{color:var(--txt-mut);font-size:.74rem;margin-top:.1rem}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.8rem}
.proj-tile{display:flex;flex-direction:column;gap:.4rem;background:var(--bg-elev2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.8rem .9rem;text-decoration:none;color:inherit;transition:.12s}
.proj-tile:hover{border-color:var(--primary);text-decoration:none}
.proj-name{font-weight:650;color:var(--txt)}
.proj-tag{font-size:.66rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent)}
/* settings rows */
.set-row{display:flex;align-items:flex-start;gap:1rem;padding:.7rem .2rem;border-bottom:1px solid var(--line-soft)}
.set-row:last-child{border-bottom:none}
.set-main{flex:1;min-width:0}
.set-label{font-weight:600;display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}
.set-key{font-size:.66rem;color:var(--txt-mut);font-weight:400}
.set-help{color:var(--txt-mut);font-size:.8rem;margin-top:.2rem;max-width:52ch;line-height:1.4}
.set-ctl{flex:none;width:240px;display:flex;justify-content:flex-end}
.set-ctl input,.set-ctl select{width:100%}
.help-q{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;background:var(--bg-elev2);border:1px solid var(--line);color:var(--txt-mut);font-size:.66rem;cursor:help}
.help-q:hover{border-color:var(--primary);color:var(--primary-hi)}
@media(max-width:700px){.set-row{flex-direction:column;gap:.4rem}.set-ctl{width:100%;justify-content:flex-start}}
/* error page */
.errpage{text-align:center;padding:3rem 1rem;max-width:540px;margin:1.5rem auto}
.err-code{font-size:5.5rem;font-weight:800;letter-spacing:-.04em;line-height:1;background:linear-gradient(135deg,var(--primary-hi),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.errpage h2{margin:.5rem 0 .4rem}
.errpage p{max-width:42ch;margin:0 auto;line-height:1.5}
.bar{height:6px;background:var(--bg-elev2);border-radius:3px;overflow:hidden;margin-bottom:.25rem;width:150px}
.bar-fill{display:block;height:100%;background:var(--green)}
.chip-ok{border-color:rgba(34,197,94,.4);color:var(--green)}
.btn-danger{border-color:rgba(239,68,68,.4);color:#fca5a5}
.btn-danger:hover{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.6)}
.muted{color:var(--txt-mut)}
.warn-txt{color:var(--amber)}
.lookup-link{font-size:.78rem;margin-left:.4rem;white-space:nowrap}
.xbtn{background:none;border:none;color:var(--txt-mut);cursor:pointer;font-size:1rem;line-height:1;padding:0 .15rem}
.xbtn:hover{color:#fca5a5}
.statrow{display:flex;align-items:center;gap:.7rem;padding:.32rem .4rem;text-decoration:none;color:inherit;border-radius:6px}
a.statrow:hover{background:color-mix(in srgb, var(--primary) 12%, transparent)}
a.statrow:hover .statlabel{color:var(--txt)}
.statlabel{width:130px;flex-shrink:0;color:var(--txt-dim);font-size:.85rem}
.statrow .bar{height:11px;border-radius:6px;background:color-mix(in srgb, var(--line) 55%, transparent)}
.statrow .bar-fill{background:linear-gradient(90deg, var(--primary), color-mix(in srgb, var(--primary) 55%, #7dd3fc));min-width:2px}
.statcount{min-width:48px;text-align:right;flex-shrink:0;white-space:nowrap;color:var(--txt);font-weight:600}

/* ---- print / report view: drop chrome + controls, ink-friendly ----
   One polished print stylesheet for EVERY screen, replacing Sirid's 11 separate
   *_printable.jsp pages. The topbar (which carries the page <h1>) is hidden, so a
   print-only `.print-head` letterhead supplies the title + "printed on · by". Lists
   live in a JS-height-capped `.grid-wrap` scroll box and are paged in by infinite
   scroll — onyxPrint() hydrates every page first, then this expands the box and lets
   the browser repeat the <thead> across printed pages. */
@page { margin: 14mm; }
@media print {
  .side, .topbar, .topsearch, .btn, .xbtn, form, .filters, .pager { display:none !important; }
  .main { margin:0 !important; }
  .content { padding:0 !important; max-width:none !important; }
  body, .panel, .card, .section { background:#fff !important; color:#000 !important; box-shadow:none !important; }
  .panel, .card, .grid td, .grid th, .data td, .data th { border-color:#bbb !important; }
  a { color:#000 !important; text-decoration:none !important; }
  .badge, .chip { border-color:#999 !important; color:#000 !important; background:#fff !important; }
  .prose, .kv, .timeline { color:#000 !important; }
  /* print-only letterhead */
  .print-head { display:block !important; }
  /* lists: expand the infinite-scroll scroll box so every loaded row prints, undo the
     sticky-header offset, and let the browser repeat the table header on each page */
  .grid-wrap { overflow:visible !important; max-height:none !important; }
  table.grid { min-width:0 !important; width:100% !important; }
  table.grid thead { display:table-header-group; }
  table.grid thead th { position:static !important; background:#fff !important; box-shadow:none !important; }
  table.grid tr, .lane, .card, .statrow, img { page-break-inside:avoid; break-inside:avoid; }
  h1, h2, h3, .help-sec { page-break-after:avoid; }
}
/* the letterhead is print-only (hidden on screen) */
.print-head { display:none; margin:0 0 1rem; }
.print-head .ph-brand { font-weight:800; font-size:1.05rem; letter-spacing:-.02em; color:#000 }
.print-head .ph-brand i { font-style:normal; font-weight:600; font-size:.8rem; color:#555; margin-left:.45rem }
.print-head h1 { margin:.15rem 0 .1rem; font-size:1.5rem; color:#000 }
.print-head .ph-meta { color:#555; font-size:.82rem; border-bottom:1px solid #999; padding-bottom:.5rem }
.right-row{display:grid;grid-template-columns:22px 200px 1fr;gap:.2rem .7rem;align-items:start;padding:.5rem 0;border-bottom:1px solid var(--line)}
.right-row:last-child{border-bottom:none}
.right-row input{width:auto;margin-top:.15rem}
.right-label{font-weight:600;color:var(--txt)}
.right-desc{color:var(--txt-mut);font-size:.85rem}
@media(max-width:640px){.right-row{grid-template-columns:22px 1fr}.right-desc{grid-column:2}}

/* ---- help / docs ---- */
.help-shell{display:grid;grid-template-columns:252px 1fr;gap:1.4rem;align-items:start}
.help-nav{position:sticky;top:90px;max-height:calc(100vh - 110px);overflow:auto;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:.8rem}
.help-head{padding:.1rem .3rem .7rem;border-bottom:1px solid var(--line-soft);margin-bottom:.6rem}
.help-logo{font-weight:800;font-size:1.3rem;letter-spacing:-.02em;color:var(--primary-hi)}
.help-logo span{color:var(--txt-mut);font-weight:600;font-size:.9rem}
.help-tabs{display:flex;gap:.3rem;margin-bottom:.6rem}
.help-tab{flex:1;padding:.42rem;border:1px solid var(--line);background:var(--bg-elev2);color:var(--txt-dim);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer}
.help-tab:hover{color:var(--txt)}
.help-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}
.help-group{margin-bottom:.4rem}
.help-sec{font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--primary-hi);margin:1rem 0 .4rem;font-weight:800;padding-bottom:.25rem;border-bottom:2px solid var(--line)}
.help-nav a{display:block;padding:.3rem .55rem;border-radius:6px;color:var(--txt-dim);font-size:.85rem}
.help-nav a:hover{background:var(--bg-elev2);color:var(--txt);text-decoration:none}
.help-nav a.active{background:var(--primary);color:#fff}
.help-search{display:flex;gap:.4rem;margin-bottom:.6rem}
.help-search input{flex:1;min-width:0}
.help-result{display:block;padding:.38rem .55rem;border-radius:6px}
.hr-title{font-weight:600;font-size:.86rem}
.help-resultlist{list-style:none;padding:0;margin:.6rem 0}
.hr-link{font-weight:650;font-size:1.02rem}
.hr-snip{font-size:.84rem;margin-top:.15rem}
@media(max-width:820px){.help-shell{grid-template-columns:1fr}.help-nav{position:static;max-height:none}}
.doc .pb{line-height:1.7}
.doc h1{font-size:1.5rem;margin-top:0;color:var(--txt)}
.doc h2{font-size:1.15rem;margin-top:1.4rem}
.doc p,.doc li{color:var(--txt-dim)}
.doc a{color:var(--primary-hi)}
.doc img{max-width:100%;border-radius:8px;border:1px solid var(--line)}
.doc table{border-collapse:collapse;margin:1rem 0}
.doc td,.doc th{border:1px solid var(--line);padding:.4rem .7rem}

/* ---- rich editor (quill) dark theme ---- */
.rich-editor{background:var(--bg);border-radius:0 0 var(--radius-sm) var(--radius-sm);min-height:140px}
.ql-toolbar.ql-snow{border-color:var(--line)!important;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:var(--bg-elev2)}
.ql-container.ql-snow{border-color:var(--line)!important}
.ql-snow .ql-stroke{stroke:var(--txt-dim)}
.ql-snow .ql-fill{fill:var(--txt-dim)}
.ql-snow .ql-picker{color:var(--txt-dim)}
.ql-editor{color:var(--txt);min-height:120px}
.ql-editor.ql-blank::before{color:var(--txt-mut);font-style:normal}
.ql-snow.ql-toolbar button:hover .ql-stroke{stroke:var(--primary-hi)}

/* ============================================================
   Login page themes — one look chosen by admin via data-login.
   Base card styles live here (login.html carries no inline CSS),
   then each variant restyles the stage around it.
   ============================================================ */
.login-page{display:flex;min-height:100vh;align-items:center;justify-content:center;position:relative;overflow:hidden}
.login{width:344px;position:relative;z-index:2}
.login .brandmark{justify-content:center;margin-bottom:.1rem}
.login .logo-onyx{font-size:2.4rem}
.login .gem{width:22px;height:22px}
.login .sub{text-align:center;color:var(--txt-mut);letter-spacing:.2em;text-transform:uppercase;font-size:.64rem;margin:.5rem 0 1.6rem}
.login form{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow)}
.login input{width:100%;margin:.35rem 0}
.login button{width:100%;margin-top:.8rem;justify-content:center}
/* decorative layers are opt-in per variant */
.login-bg,.login-brandpanel{display:none}
.login-brandpanel .lbp-inner{max-width:360px;padding:2.5rem}
.login-brandpanel .brandmark{justify-content:flex-start;margin-bottom:1.1rem}
.login-brandpanel .logo-onyx{font-size:2.6rem}
.login-brandpanel .gem{width:26px;height:26px}
.login-brandpanel .lbp-tag{text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;opacity:.85;margin-bottom:1.4rem}
.login-brandpanel .lbp-blurb{font-size:1.02rem;line-height:1.6;opacity:.92;font-weight:500}

/* --- Classic: the signature centered card on a soft radial glow --- */
.login-page[data-login="classic"]{background:radial-gradient(1100px 560px at 50% -10%, color-mix(in srgb, var(--primary) 22%, var(--bg)) 0%, var(--bg) 55%)}

/* --- Onyx Wallpaper: faint full-bleed mineral texture + frosted card --- */
.login-page[data-login="wallpaper"]{background:var(--bg)}
.login-page[data-login="wallpaper"] .login-bg{display:block;position:absolute;inset:0;z-index:0;opacity:.5;
  background:
    radial-gradient(900px 500px at 18% -8%, color-mix(in srgb, var(--primary) 26%, transparent) 0%, transparent 60%),
    radial-gradient(760px 520px at 88% 14%, color-mix(in srgb, #7dd3fc 16%, transparent) 0%, transparent 55%),
    repeating-linear-gradient(115deg, rgba(255,255,255,.045) 0 2px, transparent 2px 26px),
    repeating-linear-gradient( 67deg, rgba(255,255,255,.03) 0 1px, transparent 1px 19px),
    linear-gradient(160deg, #0b1417, #060b0d 70%)}
.login-page[data-login="wallpaper"] .login form{background:color-mix(in srgb, var(--bg-elev) 78%, transparent);
  -webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);border-color:color-mix(in srgb, var(--primary) 30%, var(--line))}

/* --- Split Brand: branded panel beside the form --- */
.login-page[data-login="split"]{display:grid;grid-template-columns:1.1fr .9fr;align-items:stretch}
.login-page[data-login="split"] .login-brandpanel{display:flex;align-items:center;justify-content:center;color:#fff;
  background:linear-gradient(150deg, #00485e 0%, #016981 45%, #2e7084 100%);position:relative;overflow:hidden}
.login-page[data-login="split"] .login-brandpanel::after{content:"";position:absolute;inset:0;
  background:radial-gradient(600px 380px at 80% 110%, rgba(255,255,255,.16), transparent 60%)}
.login-page[data-login="split"] .login-brandpanel .gem{box-shadow:0 0 16px rgba(255,255,255,.45)}
.login-page[data-login="split"] .login{justify-self:center;align-self:center}
@media(max-width:820px){.login-page[data-login="split"]{grid-template-columns:1fr}
  .login-page[data-login="split"] .login-brandpanel{display:none}}

/* --- Spotlight: dramatic dark stage with a glowing gem --- */
.login-page[data-login="spotlight"]{background:#05090b}
.login-page[data-login="spotlight"] .login-bg{display:block;position:absolute;inset:0;z-index:0;
  background:radial-gradient(680px 680px at 50% 38%, color-mix(in srgb, var(--primary) 40%, transparent) 0%, transparent 60%)}
.login-page[data-login="spotlight"] .login .brandmark{margin-bottom:.4rem}
.login-page[data-login="spotlight"] .login .gem{width:34px;height:34px;box-shadow:0 0 28px color-mix(in srgb, var(--primary) 70%, transparent)}
.login-page[data-login="spotlight"] .login .logo-onyx{font-size:3rem}
.login-page[data-login="spotlight"] .login form{background:color-mix(in srgb, var(--bg-elev) 86%, transparent);
  border-color:color-mix(in srgb, var(--primary) 22%, var(--line));box-shadow:0 24px 70px rgba(0,0,0,.6)}

/* --- Minimal: ultra-clean flat card, no flourishes --- */
.login-page[data-login="minimal"]{background:var(--bg)}
.login-page[data-login="minimal"] .login .sub{opacity:.7}
.login-page[data-login="minimal"] .login form{box-shadow:none;border-color:var(--line-soft)}

/* ============================================================
   Project Timeline — per-version Gantt.
   Bars are server-positioned by percentage (no JS chart lib). Gridlines, the
   "today" line and the bars share one CSS-grid track geometry so they align
   exactly. Phase colours come from the theme vars (--red/--amber/--green/--grey)
   so all four themes work; @media print expands + ink-adjusts it.
   ============================================================ */
/* segmented Gantt / Activity switch */
.seg{display:inline-flex;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.seg a{padding:.42rem .85rem;font-size:.82rem;font-weight:600;color:var(--txt-dim);background:var(--bg-elev2)}
.seg a:hover{color:var(--txt);text-decoration:none}
.seg a.on{background:var(--primary);color:#fff}
.seg a+a{border-left:1px solid var(--line)}
.card.over .n{color:var(--red)}

/* phase colour carrier — set once per element, reused by swatch/dot/bar */
.phase-notstarted{--ph:var(--red)}
.phase-progress{--ph:var(--amber)}
.phase-done{--ph:var(--green)}
.phase-other{--ph:var(--grey)}

.gantt-legend{display:flex;flex-wrap:wrap;gap:.35rem 1.1rem;margin-bottom:1rem;color:var(--txt-dim);font-size:.8rem}
.gantt-legend span{display:inline-flex;align-items:center;gap:.4rem}
.gantt-legend .sw{width:13px;height:13px;border-radius:3px;flex:none;background:var(--ph,var(--grey))}
.gantt-legend .sw-over{background:repeating-linear-gradient(45deg,var(--grey) 0 4px,color-mix(in srgb,var(--grey) 55%,#000) 4px 8px);box-shadow:0 0 0 1px var(--red)}
.gantt-legend .sw-today{background:var(--primary-hi)}

.gantt{--label-w:260px;display:flex;flex-direction:column;gap:1rem;overflow-x:auto;scrollbar-width:thin}
.lane{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);min-width:640px;overflow:hidden}
.lane-head{display:flex;align-items:center;justify-content:space-between;gap:.7rem;flex-wrap:wrap;padding:.65rem 1rem;border-bottom:1px solid var(--line-soft);background:var(--bg-elev2)}
.lane-title{display:flex;align-items:baseline;gap:.7rem;min-width:0}
.lane-ver{font-weight:700;font-size:1rem;color:var(--txt)}
.lane-range{font-size:.76rem}
.lane-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.lane-prog{width:90px;height:7px;border-radius:4px;background:color-mix(in srgb,var(--line) 60%,transparent);overflow:hidden;display:inline-block;vertical-align:middle}
.lane-prog-fill{display:block;height:100%;background:var(--green)}

/* the bar area; overlays inset to match the rows exactly (no horizontal padding on the body) */
.lane-body{position:relative;padding:20px 0 10px}
.lane-grid,.lane-today{position:absolute;inset:20px 0 10px 0;display:grid;grid-template-columns:var(--label-w) minmax(0,1fr);pointer-events:none}
.lane-grid{z-index:0}
.lane-today{z-index:3}
.lane-grid-track{grid-column:2;position:relative}
.tick{position:absolute;top:0;bottom:0;width:1px;background:var(--line-soft)}
.tick.major{background:var(--line)}
.tick-l{position:absolute;top:-17px;left:0;transform:translateX(-50%);font-size:.66rem;color:var(--txt-mut);white-space:nowrap}
.today-line{position:absolute;top:0;bottom:0;width:2px;background:var(--primary-hi);box-shadow:0 0 6px color-mix(in srgb,var(--primary-hi) 60%,transparent)}
.today-l{position:absolute;top:-17px;left:0;transform:translateX(-50%);font-size:.66rem;font-weight:700;color:var(--primary-hi);white-space:nowrap}

.gantt-rows{position:relative;z-index:1}
.grow{display:grid;grid-template-columns:var(--label-w) minmax(0,1fr);align-items:center;min-height:27px}
.grow:hover{background:color-mix(in srgb,var(--primary) 9%,transparent)}
.grow.extra{display:none}
.grow-label{display:flex;align-items:center;gap:.42rem;padding:.3rem .7rem .3rem 1rem;min-width:0;color:var(--txt-dim);font-size:.84rem;border-right:1px solid var(--line-soft)}
.grow-label:hover{text-decoration:none;color:var(--txt)}
.grow-label .dot{width:9px;height:9px;border-radius:50%;background:var(--ph,var(--grey));flex:none}
.grow-label .gl-id{color:var(--txt-mut);font-size:.74rem;flex:none}
.grow-label .gl-t{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.grow-label .gl-x{color:var(--red);font-weight:800;flex:none}
.bar-track{position:relative;min-height:27px}
/* Gantt bars — SCOPED to .bar-track so they don't hijack the inline meter `.bar`
   used on the dashboard / reports / statistics pages (those expect the flat
   `.bar`+`.bar-fill` rules above; a bare global `.bar{position:absolute}` here
   was ripping them out of flow and stacking them at 50% of the viewport). */
.bar-track .bar{position:absolute;top:50%;transform:translateY(-50%);height:14px;border-radius:7px;background:var(--ph,var(--grey));min-width:4px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.14);transition:filter .12s}
.bar-track .bar:hover{filter:brightness(1.13);text-decoration:none}
.bar-track .bar.overdue{background:repeating-linear-gradient(45deg,var(--ph) 0 6px,color-mix(in srgb,var(--ph) 52%,#000) 6px 12px);box-shadow:inset 0 0 0 1px rgba(255,255,255,.18),0 0 7px 1px var(--red)}

/* pure-CSS per-lane "show all" toggle (no JS) */
.gantt-showall{display:block;text-align:center;padding:.5rem;border-top:1px solid var(--line-soft);color:var(--primary-hi);font-size:.82rem;font-weight:600;cursor:pointer;user-select:none}
.gantt-showall:hover{background:var(--bg-elev2)}
.gantt-showall .less{display:none}
.gantt-all:checked ~ .lane-body .grow.extra{display:grid}
.gantt-all:checked ~ .gantt-showall .more{display:none}
.gantt-all:checked ~ .gantt-showall .less{display:inline}
@media(max-width:700px){.gantt{--label-w:148px}}

@media print{
  .seg,.gantt-showall{display:none !important}
  .grow.extra{display:grid !important}
  .gantt{overflow:visible !important}
  .lane{break-inside:avoid;page-break-inside:avoid}
  .bar-track .bar,.bar-fill,.lane-prog-fill,.dot,.gantt-legend .sw,.today-line{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* ============================================================
   Accessibility baselines (ALL themes).
   Placed last so the focus-visible rules win in source order over the
   earlier `input:focus{outline:none}` at equal specificity. :focus-visible
   only matches keyboard focus, so mouse clicks stay ring-free.
   ============================================================ */
:focus-visible{outline:2px solid var(--primary-hi);outline-offset:2px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--primary-hi);outline-offset:1px}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important}
}
